Index: webkit/fileapi/file_system_file_util_unittest.cc |
diff --git a/webkit/fileapi/file_system_file_util_unittest.cc b/webkit/fileapi/file_system_file_util_unittest.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..056aa2445dadc38a00911bb8742c08bb3c8cf86f |
--- /dev/null |
+++ b/webkit/fileapi/file_system_file_util_unittest.cc |
@@ -0,0 +1,221 @@ |
+// Copyright (c) 2011 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "base/file_path.h" |
+#include "base/memory/ref_counted.h" |
+#include "base/memory/scoped_ptr.h" |
+#include "base/platform_file.h" |
+#include "base/scoped_temp_dir.h" |
+#include "testing/gtest/include/gtest/gtest.h" |
+#include "webkit/fileapi/file_system_context.h" |
+#include "webkit/fileapi/file_system_operation_context.h" |
+#include "webkit/fileapi/file_system_test_helper.h" |
+#include "webkit/fileapi/local_file_system_file_util.h" |
+#include "webkit/fileapi/obfuscated_file_system_file_util.h" |
+ |
+using namespace fileapi; |
+ |
+namespace { |
+ |
+struct CopyMoveTestCaseRecord { |
+ bool is_directory; |
+ const FilePath::CharType path[64]; |
+ int64 data_file_size; |
+}; |
+ |
+const CopyMoveTestCaseRecord kCopyMoveTestCases[] = { |
+ {true, FILE_PATH_LITERAL("dir a"), 0}, |
+ {true, FILE_PATH_LITERAL("dir a/dir a"), 0}, |
+ {true, FILE_PATH_LITERAL("dir a/dir d"), 0}, |
+ {true, FILE_PATH_LITERAL("dir a/dir d/dir e"), 0}, |
+ {true, FILE_PATH_LITERAL("dir a/dir d/dir e/dir f"), 0}, |
+ {true, FILE_PATH_LITERAL("dir a/dir d/dir e/dir g"), 0}, |
+ {true, FILE_PATH_LITERAL("dir a/dir d/dir e/dir h"), 0}, |
+ {true, FILE_PATH_LITERAL("dir b"), 0}, |
+ {true, FILE_PATH_LITERAL("dir b/dir a"), 0}, |
+ {true, FILE_PATH_LITERAL("dir c"), 0}, |
+ {false, FILE_PATH_LITERAL("file 0"), 38}, |
+ {false, FILE_PATH_LITERAL("file 2"), 60}, |
+ {false, FILE_PATH_LITERAL("file 3"), 0}, |
+ {false, FILE_PATH_LITERAL("dir a/file 0"), 39}, |
+ {false, FILE_PATH_LITERAL("dir a/dir d/dir e/dir g/file 0"), 40}, |
+ {false, FILE_PATH_LITERAL("dir a/dir d/dir e/dir g/file 1"), 41}, |
+ {false, FILE_PATH_LITERAL("dir a/dir d/dir e/dir g/file 2"), 42}, |
+ {false, FILE_PATH_LITERAL("dir a/dir d/dir e/dir g/file 3"), 50}, |
+}; |
+ |
+} // namespace (anonymous) |
+ |
+// This is not yet a full unit test for FileSystemFileUtil. TODO(ericu): Adapt |
+// the other subclasses' unit tests, as mentioned in the comments in |
+// ObfuscatedFileSystemFileUtil's unit test. |
+// Currently this is just a test of cross-filesystem copy and move, which |
+// actually exercises subclasses of FileSystemFileUtil as well as the class |
+// itself. We currently only test copies between obfuscated filesystems. |
+// TODO(ericu): Add a test for copying between obfuscated and local filesystems, |
+// and between different local filesystems. |
+class FileSystemFileUtilTest : public testing::Test { |
+ public: |
+ FileSystemFileUtilTest() { |
+ } |
+ |
+ void SetUp() { |
+ } |
+ |
+ FileSystemOperationContext* NewContext(FileSystemTestOriginHelper* helper) { |
+ FileSystemOperationContext* context = helper->NewOperationContext(); |
+ context->set_allowed_bytes_growth(1024 * 1024); |
+ return context; |
+ } |
+ |
+ void TestCrossFileSystemCopyMoveHelper( |
+ const GURL& src_origin, fileapi::FileSystemType src_type, |
+ const GURL& dest_origin, fileapi::FileSystemType dest_type, |
+ bool copy) { |
+ ScopedTempDir src_dir; |
+ ASSERT_TRUE(src_dir.CreateUniqueTempDir()); |
+ scoped_refptr<ObfuscatedFileSystemFileUtil> src_util( |
+ new ObfuscatedFileSystemFileUtil(src_dir.path())); |
+ FileSystemTestOriginHelper src_helper(src_origin, src_type); |
+ src_helper.SetUp(src_dir.path(), |
+ false, // incognito |
+ false, // unlimited quota |
+ NULL, // quota::QuotaManagerProxy |
+ src_util.get()); |
+ ScopedTempDir dest_dir; |
+ ASSERT_TRUE(dest_dir.CreateUniqueTempDir()); |
+ scoped_refptr<ObfuscatedFileSystemFileUtil> dest_util( |
+ new ObfuscatedFileSystemFileUtil(dest_dir.path())); |
+ FileSystemTestOriginHelper dest_helper(dest_origin, dest_type); |
+ dest_helper.SetUp(dest_dir.path(), |
+ false, // incognito |
+ false, // unlimited quota |
+ NULL, // quota::QuotaManagerProxy |
+ dest_util.get()); |
+ |
+ // Set up all the source data. |
+ scoped_ptr<FileSystemOperationContext> context; |
+ FilePath test_root(FILE_PATH_LITERAL("root directory")); |
+ for (size_t i = 0; i < arraysize(kCopyMoveTestCases); ++i) { |
+ SCOPED_TRACE(testing::Message() << "Creating kCopyMoveTestCases " << i); |
+ const CopyMoveTestCaseRecord& test_case = kCopyMoveTestCases[i]; |
+ FilePath path = test_root.Append(test_case.path); |
+ if (test_case.is_directory) { |
+ context.reset(NewContext(&src_helper)); |
+ ASSERT_EQ(base::PLATFORM_FILE_OK, |
+ src_util->CreateDirectory(context.get(), path, true, true)); |
+ } else { |
+ context.reset(NewContext(&src_helper)); |
+ bool created = false; |
+ ASSERT_EQ(base::PLATFORM_FILE_OK, |
+ src_util->EnsureFileExists(context.get(), path, &created)); |
+ ASSERT_TRUE(created); |
+ context.reset(NewContext(&src_helper)); |
+ ASSERT_EQ(base::PLATFORM_FILE_OK, src_util->Truncate( |
+ context.get(), path, test_case.data_file_size)); |
+ } |
+ } |
+ |
+ // Do the actual copy or move. |
+ FileSystemContext* file_system_context = dest_helper.file_system_context(); |
+ scoped_ptr<FileSystemOperationContext> copy_context( |
+ new FileSystemOperationContext(file_system_context, NULL)); |
+ copy_context->set_src_file_system_file_util(src_util); |
+ copy_context->set_dest_file_system_file_util(dest_util); |
+ copy_context->set_src_origin_url(src_helper.origin()); |
+ copy_context->set_dest_origin_url(dest_helper.origin()); |
+ copy_context->set_src_type(src_helper.type()); |
+ copy_context->set_dest_type(dest_helper.type()); |
+ copy_context->set_allowed_bytes_growth(1024 * 1024); |
+ |
+ if (copy) |
+ ASSERT_EQ(base::PLATFORM_FILE_OK, |
+ src_util->Copy(copy_context.get(), test_root, test_root)); |
+ else |
+ ASSERT_EQ(base::PLATFORM_FILE_OK, |
+ src_util->Move(copy_context.get(), test_root, test_root)); |
+ |
+ // Validate that the destination paths are correct. |
+ for (size_t i = 0; i < arraysize(kCopyMoveTestCases); ++i) { |
+ SCOPED_TRACE(testing::Message() << "Validating kCopyMoveTestCases " << i); |
+ const CopyMoveTestCaseRecord& test_case = kCopyMoveTestCases[i]; |
+ FilePath path = test_root.Append(test_case.path); |
+ SCOPED_TRACE(testing::Message() << "Path is " << test_case.path); |
+ |
+ base::PlatformFileInfo dest_file_info; |
+ FilePath data_path; |
+ context.reset(NewContext(&dest_helper)); |
+ EXPECT_EQ(base::PLATFORM_FILE_OK, |
+ dest_util->GetFileInfo( |
+ context.get(), path, &dest_file_info, &data_path)); |
+ if (test_case.is_directory) { |
+ EXPECT_TRUE(dest_file_info.is_directory); |
+ } else { |
+ base::PlatformFileInfo platform_file_info; |
+ ASSERT_TRUE(file_util::GetFileInfo(data_path, &platform_file_info)); |
+ EXPECT_EQ(test_case.data_file_size, platform_file_info.size); |
+ EXPECT_FALSE(platform_file_info.is_directory); |
+ EXPECT_EQ(platform_file_info.size, dest_file_info.size); |
+ EXPECT_FALSE(dest_file_info.is_directory); |
+ } |
+ } |
+ |
+ // Validate that the source paths are still there [for a copy] or gone [for |
+ // a move]. |
+ for (size_t i = 0; i < arraysize(kCopyMoveTestCases); ++i) { |
+ SCOPED_TRACE(testing::Message() << "Validating kCopyMoveTestCases " << |
+ i); |
+ const CopyMoveTestCaseRecord& test_case = kCopyMoveTestCases[i]; |
+ FilePath path = test_root.Append(test_case.path); |
+ SCOPED_TRACE(testing::Message() << "Path is " << test_case.path); |
+ |
+ base::PlatformFileInfo src_file_info; |
+ FilePath data_path; |
+ context.reset(NewContext(&src_helper)); |
+ base::PlatformFileError expected_result; |
+ if (copy) |
+ expected_result = base::PLATFORM_FILE_OK; |
+ else |
+ expected_result = base::PLATFORM_FILE_ERROR_NOT_FOUND; |
+ EXPECT_EQ(expected_result, |
+ src_util->GetFileInfo( |
+ context.get(), path, &src_file_info, &data_path)); |
+ } |
+ } |
+ |
+ private: |
+ DISALLOW_COPY_AND_ASSIGN(FileSystemFileUtilTest); |
+}; |
+ |
+TEST_F(FileSystemFileUtilTest, TestCrossFileSystemCopyDifferentOrigins) { |
+ GURL src_origin("http://www.example.com"); |
+ fileapi::FileSystemType type = kFileSystemTypePersistent; |
+ GURL dest_origin("http://www.not.the.same.domain.com"); |
+ |
+ TestCrossFileSystemCopyMoveHelper(src_origin, type, dest_origin, type, true); |
+} |
+ |
+TEST_F(FileSystemFileUtilTest, TestCrossFileSystemCopySameOrigin) { |
+ GURL origin("http://www.example.com"); |
+ fileapi::FileSystemType src_type = kFileSystemTypePersistent; |
+ fileapi::FileSystemType dest_type = kFileSystemTypeTemporary; |
+ |
+ TestCrossFileSystemCopyMoveHelper(origin, src_type, origin, dest_type, true); |
+} |
+ |
+TEST_F(FileSystemFileUtilTest, TestCrossFileSystemMoveDifferentOrigins) { |
+ GURL src_origin("http://www.example.com"); |
+ fileapi::FileSystemType type = kFileSystemTypePersistent; |
+ GURL dest_origin("http://www.not.the.same.domain.com"); |
+ |
+ TestCrossFileSystemCopyMoveHelper(src_origin, type, dest_origin, type, false); |
+} |
+ |
+TEST_F(FileSystemFileUtilTest, TestCrossFileSystemMoveSameOrigin) { |
+ GURL origin("http://www.example.com"); |
+ fileapi::FileSystemType src_type = kFileSystemTypePersistent; |
+ fileapi::FileSystemType dest_type = kFileSystemTypeTemporary; |
+ |
+ TestCrossFileSystemCopyMoveHelper(origin, src_type, origin, dest_type, false); |
+} |