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

Unified Diff: chrome/browser/chromeos/drive/file_system/create_directory_operation_unittest.cc

Issue 15817003: drive: Use OperationTestBase from CreateDirectoryOperationTest (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: rebase Created 7 years, 7 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: chrome/browser/chromeos/drive/file_system/create_directory_operation_unittest.cc
diff --git a/chrome/browser/chromeos/drive/file_system/create_directory_operation_unittest.cc b/chrome/browser/chromeos/drive/file_system/create_directory_operation_unittest.cc
index b6da222fd336f2bbed8d42820dc2588d6c82792c..2ee63e561fa0e075fc876896c4cbdce3a317bfd0 100644
--- a/chrome/browser/chromeos/drive/file_system/create_directory_operation_unittest.cc
+++ b/chrome/browser/chromeos/drive/file_system/create_directory_operation_unittest.cc
@@ -4,171 +4,110 @@
#include "chrome/browser/chromeos/drive/file_system/create_directory_operation.h"
-#include "base/files/scoped_temp_dir.h"
-#include "base/message_loop.h"
-#include "chrome/browser/chromeos/drive/file_system_util.h"
-#include "chrome/browser/chromeos/drive/resource_metadata.h"
-#include "chrome/browser/chromeos/drive/test_util.h"
+#include "chrome/browser/chromeos/drive/file_system/operation_test_base.h"
#include "chrome/browser/google_apis/test_util.h"
-#include "content/public/browser/browser_thread.h"
-#include "content/public/test/test_browser_thread.h"
#include "testing/gtest/include/gtest/gtest.h"
namespace drive {
namespace file_system {
-namespace {
-// Creates a resource entry instance. The resource id is "resource_id:{title}",
-// where {title} is the given |title|.
-ResourceEntry CreateResourceEntry(const std::string& title,
- const std::string& parent_resource_id,
- bool is_directory) {
- ResourceEntry entry;
- const std::string resource_id = "resource_id:" + title;
- entry.set_title(title);
- entry.set_resource_id(resource_id);
- entry.set_parent_resource_id(parent_resource_id);
+class CreateDirectoryOperationTest : public OperationTestBase {
+ protected:
+ // Returns FILE_ERROR_OK if a directory is found at |path|.
+ FileError FindDirectory(const base::FilePath& path) {
+ ResourceEntry entry;
+ FileError error = GetLocalResourceEntry(path, &entry);
+ if (error == FILE_ERROR_OK && !entry.file_info().is_directory())
+ error = FILE_ERROR_NOT_A_DIRECTORY;
+ return error;
+ }
+};
+
+TEST_F(CreateDirectoryOperationTest, CreateDirectory) {
+ CreateDirectoryOperation operation(blocking_task_runner(),
+ observer(),
+ scheduler(),
+ metadata());
+
+ const base::FilePath kExistingFile(
+ FILE_PATH_LITERAL("drive/root/File 1.txt"));
+ const base::FilePath kExistingDirectory(
+ FILE_PATH_LITERAL("drive/root/Directory 1"));
+ const base::FilePath kNewDirectory1(
+ FILE_PATH_LITERAL("drive/root/New Directory"));
+ const base::FilePath kNewDirectory2 =
+ kNewDirectory1.AppendASCII("New Directory 2/a/b/c");
+
+ // Create a new directory, not recursively.
+ EXPECT_EQ(FILE_ERROR_NOT_FOUND, FindDirectory(kNewDirectory1));
- PlatformFileInfoProto* file_info = entry.mutable_file_info();
- file_info->set_is_directory(is_directory);
-
- return entry;
-}
-
-} // namespace
-
-TEST(CreateDirectoryOperationTest, GetExistingDeepestDirectory) {
- MessageLoopForUI message_loop;
- content::TestBrowserThread ui_thread(
- content::BrowserThread::UI, &message_loop);
-
- // Set up a Metadata instance.
- base::ScopedTempDir temp_dir;
- ASSERT_TRUE(temp_dir.CreateUniqueTempDir());
- scoped_ptr<internal::ResourceMetadata, test_util::DestroyHelperForTests>
- metadata(new internal::ResourceMetadata(
- temp_dir.path(), message_loop.message_loop_proxy()));
FileError error = FILE_ERROR_FAILED;
- metadata->Initialize(
+ operation.CreateDirectory(
+ kNewDirectory1,
+ true, // is_exclusive
+ false, // is_recursive
google_apis::test_util::CreateCopyResultCallback(&error));
google_apis::test_util::RunBlockingPoolTask();
- ASSERT_EQ(FILE_ERROR_OK, error);
-
- // Create a testee directory tree.
- // drive/root/dir1/
- // drive/root/dir1/dir2/
- // drive/root/dir1/dir2/file3
- // drive/root/dir1/file4
- // drive/root/dir5/
- const char kTestRootResourceId[] = "test_root";
- ASSERT_EQ(FILE_ERROR_OK, metadata->AddEntry(
- util::CreateMyDriveRootEntry(kTestRootResourceId)));
- ASSERT_EQ(FILE_ERROR_OK, metadata->AddEntry(
- CreateResourceEntry("dir1", kTestRootResourceId, true)));
- ASSERT_EQ(FILE_ERROR_OK, metadata->AddEntry(
- CreateResourceEntry("dir2", "resource_id:dir1", true)));
- ASSERT_EQ(FILE_ERROR_OK, metadata->AddEntry(
- CreateResourceEntry("file3", "resource_id:dir2", false)));
- ASSERT_EQ(FILE_ERROR_OK, metadata->AddEntry(
- CreateResourceEntry("file4", "resource_id:dir1", false)));
- ASSERT_EQ(FILE_ERROR_OK, metadata->AddEntry(
- CreateResourceEntry("dir5", kTestRootResourceId, true)));
-
- ResourceEntry entry;
- // Searching grand root and mydrive root.
- EXPECT_EQ(
- FILE_PATH_LITERAL("drive"),
- CreateDirectoryOperation::GetExistingDeepestDirectory(
- metadata.get(), base::FilePath(FILE_PATH_LITERAL("drive")),
- &entry).value());
- EXPECT_EQ(util::kDriveGrandRootSpecialResourceId, entry.resource_id());
- EXPECT_EQ(
- FILE_PATH_LITERAL("drive/root"),
- CreateDirectoryOperation::GetExistingDeepestDirectory(
- metadata.get(), base::FilePath(FILE_PATH_LITERAL("drive/root")),
- &entry).value());
- EXPECT_EQ(kTestRootResourceId, entry.resource_id());
-
- // Searching existing directories.
- EXPECT_EQ(
- FILE_PATH_LITERAL("drive/root/dir1"),
- CreateDirectoryOperation::GetExistingDeepestDirectory(
- metadata.get(), base::FilePath(FILE_PATH_LITERAL("drive/root/dir1")),
- &entry).value());
- EXPECT_EQ("resource_id:dir1", entry.resource_id());
- EXPECT_EQ(
- FILE_PATH_LITERAL("drive/root/dir1/dir2"),
- CreateDirectoryOperation::GetExistingDeepestDirectory(
- metadata.get(),
- base::FilePath(FILE_PATH_LITERAL("drive/root/dir1/dir2")),
- &entry).value());
- EXPECT_EQ("resource_id:dir2", entry.resource_id());
+ EXPECT_EQ(FILE_ERROR_OK, error);
+ EXPECT_EQ(FILE_ERROR_OK, FindDirectory(kNewDirectory1));
+ EXPECT_EQ(1U, observer()->get_changed_paths().size());
+ EXPECT_EQ(1U,
+ observer()->get_changed_paths().count(kNewDirectory1.DirName()));
+
+ // Create a new directory recursively.
+ EXPECT_EQ(FILE_ERROR_NOT_FOUND, FindDirectory(kNewDirectory2));
+ operation.CreateDirectory(
+ kNewDirectory2,
+ true, // is_exclusive
+ false, // is_recursive
+ google_apis::test_util::CreateCopyResultCallback(&error));
+ google_apis::test_util::RunBlockingPoolTask();
+ EXPECT_EQ(FILE_ERROR_NOT_FOUND, error);
+ EXPECT_EQ(FILE_ERROR_NOT_FOUND, FindDirectory(kNewDirectory2));
- // Searching missing directories.
- EXPECT_EQ(
- FILE_PATH_LITERAL("drive/root/dir1/dir2"),
- CreateDirectoryOperation::GetExistingDeepestDirectory(
- metadata.get(),
- base::FilePath(FILE_PATH_LITERAL("drive/root/dir1/dir2/dir3")),
- &entry).value());
- EXPECT_EQ("resource_id:dir2", entry.resource_id());
- EXPECT_EQ(
- FILE_PATH_LITERAL("drive/root/dir1/dir2"),
- CreateDirectoryOperation::GetExistingDeepestDirectory(
- metadata.get(),
- base::FilePath(FILE_PATH_LITERAL("drive/root/dir1/dir2/dir3/dir4")),
- &entry).value());
- EXPECT_EQ("resource_id:dir2", entry.resource_id());
- EXPECT_EQ(
- FILE_PATH_LITERAL("drive/root/dir1"),
- CreateDirectoryOperation::GetExistingDeepestDirectory(
- metadata.get(),
- base::FilePath(FILE_PATH_LITERAL("drive/root/dir1/dir2-1/dir3")),
- &entry).value());
- EXPECT_EQ("resource_id:dir1", entry.resource_id());
- EXPECT_EQ(
- FILE_PATH_LITERAL("drive/root/dir5"),
- CreateDirectoryOperation::GetExistingDeepestDirectory(
- metadata.get(),
- base::FilePath(FILE_PATH_LITERAL("drive/root/dir5/dir6/dir7/dir8")),
- &entry).value());
- EXPECT_EQ("resource_id:dir5", entry.resource_id());
+ operation.CreateDirectory(
+ kNewDirectory2,
+ true, // is_exclusive
+ true, // is_recursive
+ google_apis::test_util::CreateCopyResultCallback(&error));
+ google_apis::test_util::RunBlockingPoolTask();
+ EXPECT_EQ(FILE_ERROR_OK, error);
+ EXPECT_EQ(FILE_ERROR_OK, FindDirectory(kNewDirectory2));
+
+ // Try to create an existing directory.
+ operation.CreateDirectory(
+ kExistingDirectory,
+ true, // is_exclusive
+ false, // is_recursive
+ google_apis::test_util::CreateCopyResultCallback(&error));
+ google_apis::test_util::RunBlockingPoolTask();
+ EXPECT_EQ(FILE_ERROR_EXISTS, error);
- // If the path points to a file (not a directory), failed to find.
- EXPECT_EQ(
- FILE_PATH_LITERAL(""),
- CreateDirectoryOperation::GetExistingDeepestDirectory(
- metadata.get(),
- base::FilePath(FILE_PATH_LITERAL("drive/root/dir1/dir2/file3")),
- &entry).value());
- EXPECT_EQ(
- FILE_PATH_LITERAL(""),
- CreateDirectoryOperation::GetExistingDeepestDirectory(
- metadata.get(),
- base::FilePath(FILE_PATH_LITERAL("drive/root/dir1/file4")),
- &entry).value());
+ operation.CreateDirectory(
+ kExistingDirectory,
+ false, // is_exclusive
+ false, // is_recursive
+ google_apis::test_util::CreateCopyResultCallback(&error));
+ google_apis::test_util::RunBlockingPoolTask();
+ EXPECT_EQ(FILE_ERROR_OK, error);
- // Searching missing directory under a "file" should be also failed.
- EXPECT_EQ(
- FILE_PATH_LITERAL(""),
- CreateDirectoryOperation::GetExistingDeepestDirectory(
- metadata.get(),
- base::FilePath(FILE_PATH_LITERAL("drive/root/dir1/file4/dir5")),
- &entry).value());
+ // Try to create a directory with a path for an existing file.
+ operation.CreateDirectory(
+ kExistingFile,
+ false, // is_exclusive
+ true, // is_recursive
+ google_apis::test_util::CreateCopyResultCallback(&error));
+ google_apis::test_util::RunBlockingPoolTask();
+ EXPECT_EQ(FILE_ERROR_NOT_FOUND, error);
- // Searching path not starting "drive" should be also failed.
- EXPECT_EQ(
- FILE_PATH_LITERAL(""),
- CreateDirectoryOperation::GetExistingDeepestDirectory(
- metadata.get(),
- base::FilePath(FILE_PATH_LITERAL("123456")),
- &entry).value());
- EXPECT_EQ(
- FILE_PATH_LITERAL(""),
- CreateDirectoryOperation::GetExistingDeepestDirectory(
- metadata.get(),
- base::FilePath(FILE_PATH_LITERAL("foo/bar")),
- &entry).value());
+ // Try to create a directory under a file.
+ operation.CreateDirectory(
+ kExistingFile.AppendASCII("New Directory"),
+ false, // is_exclusive
+ true, // is_recursive
+ google_apis::test_util::CreateCopyResultCallback(&error));
+ google_apis::test_util::RunBlockingPoolTask();
+ EXPECT_EQ(FILE_ERROR_NOT_FOUND, error);
}
} // namespace file_system

Powered by Google App Engine
This is Rietveld 408576698