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

Unified Diff: chrome/browser/sync_file_system/drive/metadata_db_migration_util_unittest.cc

Issue 15951007: SyncFS: Factor out DriveMetadataDB migration functions (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: fix win test 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/sync_file_system/drive/metadata_db_migration_util_unittest.cc
diff --git a/chrome/browser/sync_file_system/drive/metadata_db_migration_util_unittest.cc b/chrome/browser/sync_file_system/drive/metadata_db_migration_util_unittest.cc
index e37361cd6e81d3c515df1e7cf1b41143e774d79e..3c7daf43a321a7229e5a2968e4a03ca82c306b38 100644
--- a/chrome/browser/sync_file_system/drive/metadata_db_migration_util_unittest.cc
+++ b/chrome/browser/sync_file_system/drive/metadata_db_migration_util_unittest.cc
@@ -20,6 +20,31 @@
namespace sync_file_system {
namespace drive {
+namespace {
+const char kV0ServiceName[] = "drive";
+}
+
+TEST(DriveMetadataDBMigrationUtilTest, ParseV0FormatFileSystemURL) {
+ const GURL kOrigin("chrome-extension://example");
+ const base::FilePath kFile(FPL("foo bar"));
+
+ ASSERT_TRUE(RegisterSyncableFileSystem(kV0ServiceName));
+
+ fileapi::FileSystemURL url =
+ CreateSyncableFileSystemURL(kOrigin, kV0ServiceName, kFile);
+
+ std::string serialized_url;
+ SerializeSyncableFileSystemURL(url, &serialized_url);
+
+ GURL origin;
+ base::FilePath path;
+ EXPECT_TRUE(ParseV0FormatFileSystemURL(GURL(serialized_url), &origin, &path));
+ EXPECT_EQ(kOrigin, origin);
+ EXPECT_EQ(kFile, path);
+
+ EXPECT_TRUE(RevokeSyncableFileSystem(kV0ServiceName));
+}
+
TEST(DriveMetadataDBMigrationUtilTest, AddWapiIdPrefix) {
DriveMetadata_ResourceType type_file =
DriveMetadata_ResourceType_RESOURCE_TYPE_FILE;
@@ -46,26 +71,136 @@ TEST(DriveMetadataDBMigrationUtilTest, RemoveWapiIdPrefix) {
EXPECT_EQ("foo:xxx", RemoveWapiIdPrefix("foo:xxx"));
}
+TEST(DriveMetadataDBMigrationUtilTest, MigrationFromV0) {
+ const char kDatabaseVersionKey[] = "VERSION";
+ const char kChangeStampKey[] = "CHANGE_STAMP";
+ const char kSyncRootDirectoryKey[] = "SYNC_ROOT_DIR";
+ const char kDriveMetadataKeyPrefix[] = "METADATA: ";
+ const char kDriveBatchSyncOriginKeyPrefix[] = "BSYNC_ORIGIN: ";
+ const char kDriveIncrementalSyncOriginKeyPrefix[] = "ISYNC_ORIGIN: ";
+
+ const GURL kOrigin1("chrome-extension://example1");
+ const GURL kOrigin2("chrome-extension://example2");
+ const std::string kSyncRootResourceId("folder:sync_root_resource_id");
+ const std::string kResourceId1("folder:hoge");
+ const std::string kResourceId2("folder:fuga");
+ const std::string kFileResourceId("file:piyo");
+ const base::FilePath kFile(FPL("foo bar"));
+ const std::string kFileMD5("file_md5");
+
+ ASSERT_TRUE(RegisterSyncableFileSystem(kV0ServiceName));
+
+ base::ScopedTempDir base_dir;
+ ASSERT_TRUE(base_dir.CreateUniqueTempDir());
+
+ leveldb::Options options;
+ options.create_if_missing = true;
+ leveldb::DB* db_ptr = NULL;
+ std::string db_dir = fileapi::FilePathToString(
+ base_dir.path().Append(DriveMetadataStore::kDatabaseName));
+ leveldb::Status status = leveldb::DB::Open(options, db_dir, &db_ptr);
+
+ scoped_ptr<leveldb::DB> db(db_ptr);
+ ASSERT_TRUE(status.ok());
+
+ // Setup the database with the schema version 0.
+ leveldb::WriteBatch batch;
+ batch.Put(kChangeStampKey, "1");
+ batch.Put(kSyncRootDirectoryKey, kSyncRootResourceId);
+
+ fileapi::FileSystemURL url =
+ CreateSyncableFileSystemURL(kOrigin1, kV0ServiceName, kFile);
+
+ // Setup drive metadata.
+ DriveMetadata drive_metadata;
+ drive_metadata.set_resource_id(kFileResourceId);
+ drive_metadata.set_md5_checksum(kFileMD5);
+ drive_metadata.set_conflicted(false);
+ drive_metadata.set_to_be_fetched(false);
+
+ std::string serialized_url;
+ SerializeSyncableFileSystemURL(url, &serialized_url);
+ std::string metadata_string;
+ drive_metadata.SerializeToString(&metadata_string);
+ batch.Put(kDriveMetadataKeyPrefix + serialized_url, metadata_string);
+
+ // Setup batch sync origin and incremental sync origin.
+ batch.Put(kDriveBatchSyncOriginKeyPrefix + kOrigin1.spec(), kResourceId1);
+ batch.Put(kDriveIncrementalSyncOriginKeyPrefix + kOrigin2.spec(),
+ kResourceId2);
+
+ status = db->Write(leveldb::WriteOptions(), &batch);
+ EXPECT_EQ(SYNC_STATUS_OK, LevelDBStatusToSyncStatusCode(status));
+ EXPECT_TRUE(RevokeSyncableFileSystem(kV0ServiceName));
+
+ // Migrate the database.
+ drive::MigrateDatabaseFromV0ToV1(db.get());
+
+ scoped_ptr<leveldb::Iterator> itr(db->NewIterator(leveldb::ReadOptions()));
+
+ // Verify DB schema version.
+ int64 database_version = 0;
+ itr->Seek(kDatabaseVersionKey);
+ EXPECT_TRUE(itr->Valid());
+ EXPECT_TRUE(base::StringToInt64(itr->value().ToString(), &database_version));
+ EXPECT_EQ(1, database_version);
+
+ // Verify the largest changestamp.
+ int64 changestamp = 0;
+ itr->Seek(kChangeStampKey);
+ EXPECT_TRUE(itr->Valid());
+ EXPECT_TRUE(base::StringToInt64(itr->value().ToString(), &changestamp));
+ EXPECT_EQ(1, changestamp);
+
+ // Verify the sync root directory.
+ itr->Seek(kSyncRootDirectoryKey);
+ EXPECT_TRUE(itr->Valid());
+ EXPECT_EQ(kSyncRootResourceId, itr->value().ToString());
+
+ // Verify the metadata.
+ itr->Seek(kDriveMetadataKeyPrefix);
+ EXPECT_TRUE(itr->Valid());
+ DriveMetadata metadata;
+ EXPECT_TRUE(metadata.ParseFromString(itr->value().ToString()));
+ EXPECT_EQ(kFileResourceId, metadata.resource_id());
+ EXPECT_EQ(kFileMD5, metadata.md5_checksum());
+ EXPECT_FALSE(metadata.conflicted());
+ EXPECT_FALSE(metadata.to_be_fetched());
+
+ // Verify the batch sync origin.
+ itr->Seek(kDriveBatchSyncOriginKeyPrefix);
+ EXPECT_TRUE(itr->Valid());
+ EXPECT_EQ(kResourceId1, itr->value().ToString());
+
+ // Verify the incremental sync origin.
+ itr->Seek(kDriveIncrementalSyncOriginKeyPrefix);
+ EXPECT_TRUE(itr->Valid());
+ EXPECT_EQ(kResourceId2, itr->value().ToString());
+}
+
TEST(DriveMetadataDBMigrationUtilTest, MigrationFromV1) {
const char kDatabaseVersionKey[] = "VERSION";
const char kChangeStampKey[] = "CHANGE_STAMP";
const char kSyncRootDirectoryKey[] = "SYNC_ROOT_DIR";
const char kDriveMetadataKeyPrefix[] = "METADATA: ";
const char kMetadataKeySeparator = ' ';
+ const char kDriveBatchSyncOriginKeyPrefix[] = "BSYNC_ORIGIN: ";
const char kDriveIncrementalSyncOriginKeyPrefix[] = "ISYNC_ORIGIN: ";
const char kDriveDisabledOriginKeyPrefix[] = "DISABLED_ORIGIN: ";
const GURL kOrigin1("chrome-extension://example1");
const GURL kOrigin2("chrome-extension://example2");
+ const GURL kOrigin3("chrome-extension://example3");
const std::string kSyncRootResourceId("folder:sync_root_resource_id");
const std::string kResourceId1("folder:hoge");
const std::string kResourceId2("folder:fuga");
+ const std::string kResourceId3("folder:hogera");
const std::string kFileResourceId("file:piyo");
const base::FilePath kFile(FPL("foo bar"));
const std::string kFileMD5("file_md5");
- const char kV1ServiceName[] = "drive";
+ const char kV1ServiceName[] = "syncfs";
ASSERT_TRUE(RegisterSyncableFileSystem(kV1ServiceName));
base::ScopedTempDir base_dir;
@@ -81,7 +216,7 @@ TEST(DriveMetadataDBMigrationUtilTest, MigrationFromV1) {
scoped_ptr<leveldb::DB> db(db_ptr);
ASSERT_TRUE(status.ok());
- // Setup the database with the scheme version 1.
+ // Setup the database with the schema version 1.
leveldb::WriteBatch batch;
batch.Put(kDatabaseVersionKey, "1");
batch.Put(kChangeStampKey, "1");
@@ -102,11 +237,11 @@ TEST(DriveMetadataDBMigrationUtilTest, MigrationFromV1) {
kMetadataKeySeparator + url.path().AsUTF8Unsafe();
batch.Put(metadata_key, metadata_string);
- // Setup incremental sync origin and disabled origin.
- batch.Put(kDriveIncrementalSyncOriginKeyPrefix + kOrigin1.spec(),
- kResourceId1);
- batch.Put(kDriveDisabledOriginKeyPrefix + kOrigin2.spec(),
+ // Setup origins.
+ batch.Put(kDriveBatchSyncOriginKeyPrefix + kOrigin1.spec(), kResourceId1);
+ batch.Put(kDriveIncrementalSyncOriginKeyPrefix + kOrigin2.spec(),
kResourceId2);
+ batch.Put(kDriveDisabledOriginKeyPrefix + kOrigin3.spec(), kResourceId3);
status = db->Write(leveldb::WriteOptions(), &batch);
EXPECT_EQ(SYNC_STATUS_OK, LevelDBStatusToSyncStatusCode(status));
@@ -117,13 +252,20 @@ TEST(DriveMetadataDBMigrationUtilTest, MigrationFromV1) {
scoped_ptr<leveldb::Iterator> itr(db->NewIterator(leveldb::ReadOptions()));
- // Verify DB scheme version.
+ // Verify DB schema version.
int64 database_version = 0;
itr->Seek(kDatabaseVersionKey);
EXPECT_TRUE(itr->Valid());
EXPECT_TRUE(base::StringToInt64(itr->value().ToString(), &database_version));
EXPECT_EQ(2, database_version);
+ // Verify the largest changestamp.
+ int64 changestamp = 0;
+ itr->Seek(kChangeStampKey);
+ EXPECT_TRUE(itr->Valid());
+ EXPECT_TRUE(base::StringToInt64(itr->value().ToString(), &changestamp));
+ EXPECT_EQ(1, changestamp);
+
// Verify the sync root directory.
itr->Seek(kSyncRootDirectoryKey);
EXPECT_TRUE(itr->Valid());
@@ -139,15 +281,20 @@ TEST(DriveMetadataDBMigrationUtilTest, MigrationFromV1) {
EXPECT_FALSE(metadata.conflicted());
EXPECT_FALSE(metadata.to_be_fetched());
+ // Verify the batch sync origin.
+ itr->Seek(kDriveBatchSyncOriginKeyPrefix);
+ EXPECT_FALSE(StartsWithASCII(kDriveBatchSyncOriginKeyPrefix,
+ itr->key().ToString(), true));
+
// Verify the incremental sync origin.
itr->Seek(kDriveIncrementalSyncOriginKeyPrefix);
EXPECT_TRUE(itr->Valid());
- EXPECT_EQ(RemoveWapiIdPrefix(kResourceId1), itr->value().ToString());
+ EXPECT_EQ(RemoveWapiIdPrefix(kResourceId2), itr->value().ToString());
// Verify the disabled origin.
itr->Seek(kDriveDisabledOriginKeyPrefix);
EXPECT_TRUE(itr->Valid());
- EXPECT_EQ(RemoveWapiIdPrefix(kResourceId2), itr->value().ToString());
+ EXPECT_EQ(RemoveWapiIdPrefix(kResourceId3), itr->value().ToString());
}
} // namespace drive

Powered by Google App Engine
This is Rietveld 408576698