| 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
|
|
|