Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1019)

Unified Diff: webkit/fileapi/file_system_path_manager_unittest.cc

Issue 6864040: Fixed file/directory url resolution for external mount point provider. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: '' Created 9 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
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());
+ }
}
}

Powered by Google App Engine
This is Rietveld 408576698