Index: webkit/fileapi/file_system_path_manager_unittest.cc |
=================================================================== |
--- webkit/fileapi/file_system_path_manager_unittest.cc (revision 79142) |
+++ webkit/fileapi/file_system_path_manager_unittest.cc (working copy) |
@@ -17,6 +17,8 @@ |
#include "base/scoped_temp_dir.h" |
#include "googleurl/src/gurl.h" |
#include "testing/gtest/include/gtest/gtest.h" |
+#include "webkit/fileapi/file_system_util.h" |
+#include "webkit/fileapi/sandbox_mount_point_provider.h" |
using namespace fileapi; |
@@ -212,7 +214,7 @@ |
FilePath data_path() { return data_dir_.path(); } |
FilePath file_system_path() { |
return data_dir_.path().Append( |
- FileSystemPathManager::kFileSystemDirectory); |
+ SandboxMountPointProvider::kFileSystemDirectory); |
} |
private: |
@@ -345,16 +347,24 @@ |
TEST_F(FileSystemPathManagerTest, VirtualPathFromFileSystemPathTest) { |
scoped_ptr<FileSystemPathManager> manager(NewPathManager(false, false)); |
- FilePath root_path; |
- EXPECT_TRUE(GetRootPath(manager.get(), GURL("http://foo.com/"), |
- fileapi::kFileSystemTypeTemporary, |
- true /* create */, &root_path)); |
+ GURL root_url = GetFileSystemRootURI( |
+ GURL("http://foo.com/"), fileapi::kFileSystemTypeTemporary); |
+ FilePath root_path = FilePath().AppendASCII(root_url.spec()); |
for (size_t i = 0; i < ARRAYSIZE_UNSAFE(kPathToVirtualPathTestCases); ++i) { |
SCOPED_TRACE(testing::Message() << "PathToVirtualPath #" |
<< i << " " << kPathToVirtualPathTestCases[i]); |
- FilePath absolute_path = root_path.AppendASCII( |
- kPathToVirtualPathTestCases[i]); |
+ FilePath absolute_path; |
+ // TODO(ericu): Clean this up when we've got more sane path-handling. |
+ // This hack is necessary because root_path is actually a URL [ending with a |
+ // forward slash], and AppendASCII("") on Windows will delete the trailing |
+ // slash, making the path invalid as far as CrackFileSystemPath is |
+ // concerned. |
+ if (strlen(kPathToVirtualPathTestCases[i])) |
+ absolute_path = root_path.AppendASCII( |
+ kPathToVirtualPathTestCases[i]); |
+ else |
+ absolute_path = root_path; |
FilePath virtual_path; |
EXPECT_TRUE(manager->CrackFileSystemPath(absolute_path, NULL, NULL, |
&virtual_path)); |
@@ -369,19 +379,18 @@ |
TEST_F(FileSystemPathManagerTest, TypeFromFileSystemPathTest) { |
scoped_ptr<FileSystemPathManager> manager(NewPathManager(false, false)); |
- FilePath root_path; |
fileapi::FileSystemType type; |
- EXPECT_TRUE(GetRootPath(manager.get(), GURL("http://foo.com/"), |
- fileapi::kFileSystemTypeTemporary, |
- true /* create */, &root_path)); |
+ GURL root_url = GetFileSystemRootURI( |
+ GURL("http://foo.com/"), fileapi::kFileSystemTypeTemporary); |
+ FilePath root_path = FilePath().AppendASCII(root_url.spec()); |
FilePath path = root_path.AppendASCII("test"); |
EXPECT_TRUE(manager->CrackFileSystemPath(path, NULL, &type, NULL)); |
EXPECT_EQ(fileapi::kFileSystemTypeTemporary, type); |
- EXPECT_TRUE(GetRootPath(manager.get(), GURL("http://foo.com/"), |
- fileapi::kFileSystemTypePersistent, |
- true /* create */, &root_path)); |
+ root_url = GetFileSystemRootURI( |
+ GURL("http://foo.com/"), fileapi::kFileSystemTypePersistent); |
+ root_path = FilePath().AppendASCII(root_url.spec()); |
path = root_path.AppendASCII("test"); |
EXPECT_TRUE(manager->CrackFileSystemPath(path, NULL, &type, NULL)); |
EXPECT_EQ(fileapi::kFileSystemTypePersistent, type); |
@@ -389,9 +398,9 @@ |
TEST_F(FileSystemPathManagerTest, CheckValidPath) { |
scoped_ptr<FileSystemPathManager> manager(NewPathManager(false, false)); |
- FilePath root_path; |
- EXPECT_TRUE(GetRootPath(manager.get(), GURL("http://foo.com/"), |
- kFileSystemTypePersistent, true, &root_path)); |
+ GURL root_url = GetFileSystemRootURI( |
+ GURL("http://foo.com/"), fileapi::kFileSystemTypePersistent); |
+ FilePath root_path = FilePath().AppendASCII(root_url.spec()); |
// The root path must be valid, but upper directories or directories |
// that are not in our temporary or persistent directory must be |
@@ -409,6 +418,9 @@ |
SCOPED_TRACE(testing::Message() << "CheckValidPath #" << i << " " |
<< kCheckValidPathTestCases[i].path); |
FilePath path(kCheckValidPathTestCases[i].path); |
+#ifdef FILE_PATH_USES_WIN_SEPARATORS |
+ path = path.NormalizeWindowsPathSeparators(); |
+#endif |
if (!path.IsAbsolute()) |
path = root_path.Append(path); |
EXPECT_EQ(kCheckValidPathTestCases[i].expected_valid, |
@@ -417,88 +429,12 @@ |
} |
TEST_F(FileSystemPathManagerTest, IsRestrictedName) { |
+ scoped_ptr<FileSystemPathManager> manager(NewPathManager(false, false)); |
for (size_t i = 0; i < ARRAYSIZE_UNSAFE(kIsRestrictedNameTestCases); ++i) { |
SCOPED_TRACE(testing::Message() << "IsRestrictedName #" << i << " " |
<< kIsRestrictedNameTestCases[i].name); |
FilePath name(kIsRestrictedNameTestCases[i].name); |
EXPECT_EQ(kIsRestrictedNameTestCases[i].expected_dangerous, |
- FileSystemPathManager::IsRestrictedFileName(name)); |
+ manager->IsRestrictedFileName(kFileSystemTypeTemporary, name)); |
} |
} |
- |
-class FileSystemPathManagerOriginEnumeratorTest : public testing::Test { |
- public: |
- void SetUp() { |
- ASSERT_TRUE(data_dir_.CreateUniqueTempDir()); |
- enumerator_.reset(new FileSystemPathManager::OriginEnumerator( |
- data_dir_.path())); |
- } |
- |
- FileSystemPathManager::OriginEnumerator* enumerator() const { |
- return enumerator_.get(); |
- } |
- |
- protected: |
- void CreateOriginTypeDirectory(const std::string& origin_identifier, |
- fileapi::FileSystemType type) { |
- std::string type_string = |
- FileSystemPathManager::GetFileSystemTypeString(type); |
- ASSERT_TRUE(!type_string.empty()); |
- FilePath target = data_dir_.path().AppendASCII(origin_identifier) |
- .AppendASCII(type_string); |
- file_util::CreateDirectory(target); |
- ASSERT_TRUE(file_util::DirectoryExists(target)); |
- } |
- |
- ScopedTempDir data_dir_; |
- scoped_ptr<FileSystemPathManager::OriginEnumerator> enumerator_; |
-}; |
- |
-TEST_F(FileSystemPathManagerOriginEnumeratorTest, Empty) { |
- ASSERT_TRUE(enumerator()->Next().empty()); |
-} |
- |
-TEST_F(FileSystemPathManagerOriginEnumeratorTest, EnumerateOrigins) { |
- const char* temporary_origins[] = { |
- "http_www.bar.com_0", |
- "http_www.foo.com_0", |
- "http_www.foo.com_80", |
- "http_www.example.com_8080", |
- "http_www.google.com_80", |
- }; |
- const char* persistent_origins[] = { |
- "http_www.bar.com_0", |
- "http_www.foo.com_8080", |
- "http_www.foo.com_80", |
- }; |
- size_t temporary_size = ARRAYSIZE_UNSAFE(temporary_origins); |
- size_t persistent_size = ARRAYSIZE_UNSAFE(persistent_origins); |
- std::set<std::string> temporary_set, persistent_set; |
- for (size_t i = 0; i < temporary_size; ++i) { |
- CreateOriginTypeDirectory(temporary_origins[i], |
- fileapi::kFileSystemTypeTemporary); |
- temporary_set.insert(temporary_origins[i]); |
- } |
- for (size_t i = 0; i < persistent_size; ++i) { |
- CreateOriginTypeDirectory(persistent_origins[i], kFileSystemTypePersistent); |
- persistent_set.insert(persistent_origins[i]); |
- } |
- |
- size_t temporary_actual_size = 0; |
- size_t persistent_actual_size = 0; |
- std::string current; |
- while (!(current = enumerator()->Next()).empty()) { |
- SCOPED_TRACE(testing::Message() << "EnumerateOrigin " << current); |
- if (enumerator()->HasTemporary()) { |
- ASSERT_TRUE(temporary_set.find(current) != temporary_set.end()); |
- ++temporary_actual_size; |
- } |
- if (enumerator()->HasPersistent()) { |
- ASSERT_TRUE(persistent_set.find(current) != persistent_set.end()); |
- ++persistent_actual_size; |
- } |
- } |
- |
- ASSERT_EQ(temporary_size, temporary_actual_size); |
- ASSERT_EQ(persistent_size, persistent_actual_size); |
-} |