Index: webkit/fileapi/file_system_path_manager_unittest.cc |
=================================================================== |
--- webkit/fileapi/file_system_path_manager_unittest.cc (revision 82028) |
+++ webkit/fileapi/file_system_path_manager_unittest.cc (working copy) |
@@ -15,6 +15,8 @@ |
#include "base/memory/scoped_temp_dir.h" |
#include "base/message_loop.h" |
#include "base/message_loop_proxy.h" |
+#include "base/sys_string_conversions.h" |
+#include "base/utf_string_conversions.h" |
#include "googleurl/src/gurl.h" |
#include "testing/gtest/include/gtest/gtest.h" |
#include "webkit/fileapi/file_system_util.h" |
@@ -59,19 +61,26 @@ |
"https_bar.com_0" PS "Temporary" }, |
{ fileapi::kFileSystemTypePersistent, "https://bar.com/", |
"https_bar.com_0" PS "Persistent" }, |
+#if defined(OS_CHROMEOS) |
+ { fileapi::kFileSystemTypeExternal, "chrome-extension://foo/", |
+ "chrome-extension__0" PS "External" }, |
+#endif |
}; |
const struct RootPathFileURITest { |
fileapi::FileSystemType type; |
const char* origin_url; |
const char* expected_path; |
+ const char* virtual_path; |
} kRootPathFileURITestCases[] = { |
{ fileapi::kFileSystemTypeTemporary, "file:///", |
- "file__0" PS "Temporary" }, |
+ "file__0" PS "Temporary", NULL }, |
{ fileapi::kFileSystemTypePersistent, "file:///", |
- "file__0" PS "Persistent" }, |
- // TODO(zelidrag): Add fileapi::kFileSystemTypeLocal test cases here once |
- // we fix ChromeOS build of this test. |
+ "file__0" PS "Persistent", NULL }, |
+#if defined(OS_CHROMEOS) |
+ { fileapi::kFileSystemTypeExternal, "chrome-extension://foo/", |
+ "chrome-extension__0" PS "External", "testing/test_file.txt" }, |
ericu
2011/04/19 20:30:49
We don't need to stick on a file name here and pul
zel
2011/04/19 23:14:00
Done.
|
+#endif |
}; |
const struct CheckValidPathTest { |
@@ -163,6 +172,16 @@ |
{ FILE_PATH_LITERAL("|ab"), true, }, |
}; |
+FilePath UTF8ToFilePath(const std::string& str) { |
+ FilePath::StringType result; |
+#if defined(OS_POSIX) |
+ result = base::SysWideToNativeMB(UTF8ToWide(str)); |
+#elif defined(OS_WIN) |
+ result = UTF8ToUTF16(str); |
+#endif |
+ return FilePath(result); |
+} |
+ |
class TestSpecialStoragePolicy : public quota::SpecialStoragePolicy { |
public: |
virtual bool IsStorageProtected(const GURL& origin) { |
@@ -197,18 +216,24 @@ |
FileSystemPathManager* NewPathManager( |
bool incognito, |
bool allow_file_access) { |
- return new FileSystemPathManager( |
+ FileSystemPathManager* manager = new FileSystemPathManager( |
base::MessageLoopProxy::CreateForCurrentThread(), |
data_dir_.path(), |
scoped_refptr<quota::SpecialStoragePolicy>( |
new TestSpecialStoragePolicy()), |
incognito, |
allow_file_access); |
+#if defined(OS_CHROMEOS) |
+ fileapi::ExternalFileSystemMountPointProvider* ext_provider = |
+ manager->external_provider(); |
+ ext_provider->AddMountPoint(FilePath("/tmp/testing")); |
+#endif |
+ return manager; |
} |
void OnGetRootPath(bool success, |
- const FilePath& root_path, |
- const std::string& name) { |
+ const FilePath& root_path, |
+ const std::string& name) { |
root_path_callback_status_ = success; |
root_path_ = root_path; |
file_system_name_ = name; |
@@ -218,6 +243,8 @@ |
const GURL& origin_url, |
fileapi::FileSystemType type, |
bool create, |
+ bool is_file_system, |
+ const FilePath& virtual_path, |
ericu
2011/04/19 20:30:49
Obsolete params.
zel
2011/04/19 23:14:00
Done.
|
FilePath* root_path) { |
manager->GetFileSystemRootPath(origin_url, type, create, |
callback_factory_.NewCallback( |
@@ -233,6 +260,12 @@ |
return data_dir_.path().Append( |
SandboxMountPointProvider::kFileSystemDirectory); |
} |
+ FilePath external_file_system_path() { |
+ return UTF8ToFilePath(std::string(fileapi::kExternalDir)); |
+ } |
+ FilePath external_file_path_root() { |
+ return UTF8ToFilePath(std::string("/tmp")); |
+ } |
private: |
ScopedTempDir data_dir_; |
@@ -259,12 +292,21 @@ |
EXPECT_TRUE(GetRootPath(manager.get(), |
GURL(kRootPathTestCases[i].origin_url), |
kRootPathTestCases[i].type, |
- true /* create */, &root_path)); |
+ true /* create */, true /* is_file_system */, |
+ FilePath(), |
+ &root_path)); |
- FilePath expected = file_system_path().AppendASCII( |
- kRootPathTestCases[i].expected_path); |
- EXPECT_EQ(expected.value(), root_path.DirName().value()); |
- EXPECT_TRUE(file_util::DirectoryExists(root_path)); |
+ if (kRootPathTestCases[i].type != fileapi::kFileSystemTypeExternal) { |
+ FilePath expected = file_system_path().AppendASCII( |
+ kRootPathTestCases[i].expected_path); |
+ EXPECT_EQ(expected.value(), root_path.DirName().value()); |
+ EXPECT_TRUE(file_util::DirectoryExists(root_path)); |
+ } else { |
+ // External file system root path is virtual one and does not match |
+ // anything from the actual file system. |
+ EXPECT_EQ(external_file_system_path().value(), |
+ root_path.value()); |
+ } |
ASSERT_TRUE(returned_root_path.size() > i); |
returned_root_path[i] = root_path; |
} |
@@ -279,7 +321,8 @@ |
EXPECT_TRUE(GetRootPath(manager.get(), |
GURL(kRootPathTestCases[i].origin_url), |
kRootPathTestCases[i].type, |
- false /* create */, &root_path)); |
+ false /* create */, true /* is_file_system */, |
+ FilePath(), &root_path)); |
ASSERT_TRUE(returned_root_path.size() > i); |
EXPECT_EQ(returned_root_path[i].value(), root_path.value()); |
} |
@@ -295,10 +338,12 @@ |
FilePath root_path1; |
EXPECT_TRUE(GetRootPath(manager1.get(), origin_url, |
- kFileSystemTypeTemporary, true, &root_path1)); |
+ kFileSystemTypeTemporary, true, false, FilePath(), |
+ &root_path1)); |
FilePath root_path2; |
EXPECT_TRUE(GetRootPath(manager2.get(), origin_url, |
- kFileSystemTypeTemporary, false, &root_path2)); |
+ kFileSystemTypeTemporary, false, false, FilePath(), |
+ &root_path2)); |
EXPECT_EQ(root_path1.value(), root_path2.value()); |
} |
@@ -313,7 +358,8 @@ |
EXPECT_FALSE(GetRootPath(manager.get(), |
GURL(kRootPathTestCases[i].origin_url), |
kRootPathTestCases[i].type, |
- false /* create */, NULL)); |
+ false /* create */, false /* is_file_system */, |
+ FilePath(), NULL)); |
} |
} |
@@ -328,7 +374,8 @@ |
EXPECT_FALSE(GetRootPath(manager.get(), |
GURL(kRootPathTestCases[i].origin_url), |
kRootPathTestCases[i].type, |
- true /* create */, NULL)); |
+ true /* create */, false /* is_file_system */, |
+ FilePath(), NULL)); |
} |
} |
@@ -340,7 +387,8 @@ |
EXPECT_FALSE(GetRootPath(manager.get(), |
GURL(kRootPathFileURITestCases[i].origin_url), |
kRootPathFileURITestCases[i].type, |
- true /* create */, NULL)); |
+ true /* create */, false /* is_file_system */, |
+ FilePath(), NULL)); |
} |
} |
@@ -354,11 +402,20 @@ |
EXPECT_TRUE(GetRootPath(manager.get(), |
GURL(kRootPathFileURITestCases[i].origin_url), |
kRootPathFileURITestCases[i].type, |
- true /* create */, &root_path)); |
- FilePath expected = file_system_path().AppendASCII( |
- kRootPathFileURITestCases[i].expected_path); |
- EXPECT_EQ(expected.value(), root_path.DirName().value()); |
- EXPECT_TRUE(file_util::DirectoryExists(root_path)); |
+ true /* create */, false /* is_file_system */, |
+ (kRootPathFileURITestCases[i].virtual_path ? |
+ UTF8ToFilePath(std::string( |
+ kRootPathFileURITestCases[i].virtual_path)) : |
+ FilePath()), |
+ &root_path)); |
+ if (kRootPathFileURITestCases[i].type != fileapi::kFileSystemTypeExternal) { |
+ FilePath expected = file_system_path().AppendASCII( |
+ kRootPathFileURITestCases[i].expected_path); |
+ EXPECT_EQ(expected.value(), root_path.DirName().value()); |
+ EXPECT_TRUE(file_util::DirectoryExists(root_path)); |
+ } else { |
+ EXPECT_EQ(external_file_path_root().value(), root_path.value()); |
+ } |
} |
} |