| Index: chrome/browser/profiles/profile_info_cache_unittest.cc
|
| diff --git a/chrome/browser/profiles/profile_info_cache_unittest.cc b/chrome/browser/profiles/profile_info_cache_unittest.cc
|
| index be03de0e212b18eada802e2eb763b1749a28c62f..b6227e0a75dbe298747bb7a2577e40ba9f5f4ccd 100644
|
| --- a/chrome/browser/profiles/profile_info_cache_unittest.cc
|
| +++ b/chrome/browser/profiles/profile_info_cache_unittest.cc
|
| @@ -8,25 +8,78 @@
|
| #include "base/utf_string_conversions.h"
|
| #include "chrome/browser/browser_process.h"
|
| #include "chrome/browser/profiles/profile_manager.h"
|
| +#include "chrome/common/chrome_notification_types.h"
|
| #include "chrome/test/base/testing_browser_process.h"
|
| #include "chrome/test/base/testing_pref_service.h"
|
| #include "chrome/test/base/testing_profile_manager.h"
|
| +#include "chrome/test/base/ui_test_utils.h"
|
| +#include "content/public/browser/notification_observer.h"
|
| +#include "content/public/browser/notification_registrar.h"
|
| +#include "content/test/test_browser_thread.h"
|
| #include "testing/gtest/include/gtest/gtest.h"
|
| #include "third_party/skia/include/core/SkBitmap.h"
|
| #include "ui/base/resource/resource_bundle.h"
|
| #include "ui/gfx/image/image.h"
|
|
|
| +using content::BrowserThread;
|
| +
|
| namespace {
|
|
|
| +bool IsEqual(const gfx::Image& image1,
|
| + const gfx::Image& image2) {
|
| + const SkBitmap& bmp1 = *image1.ToSkBitmap();
|
| + const SkBitmap& bmp2 = *image2.ToSkBitmap();
|
| +
|
| + if (bmp1.width() != bmp2.width() ||
|
| + bmp1.height() != bmp2.height() ||
|
| + bmp1.config() != SkBitmap::kARGB_8888_Config ||
|
| + bmp2.config() != SkBitmap::kARGB_8888_Config) {
|
| + return false;
|
| + }
|
| +
|
| + SkAutoLockPixels lock1(bmp1);
|
| + SkAutoLockPixels lock2(bmp2);
|
| + if (!bmp1.getPixels() || !bmp2.getPixels())
|
| + return false;
|
| +
|
| + for (int y = 0; y < bmp1.height(); ++y) {
|
| + for (int x = 0; x < bmp1.width(); ++x) {
|
| + if (*bmp1.getAddr32(x,y) != *bmp2.getAddr32(x,y))
|
| + return false;
|
| + }
|
| + }
|
| +
|
| + return true;
|
| +}
|
| +
|
| +gfx::Image CreateTestImage() {
|
| + SkBitmap bitmap;
|
| + bitmap.setConfig(SkBitmap::kARGB_8888_Config, 100, 50);
|
| + bitmap.allocPixels();
|
| + bitmap.eraseRGB(0xff, 0, 0);
|
| + return gfx::Image(new SkBitmap(bitmap));
|
| +}
|
| +
|
| class ProfileInfoCacheUnittests : public testing::Test {
|
| protected:
|
| ProfileInfoCacheUnittests()
|
| : testing_profile_manager_(
|
| - static_cast<TestingBrowserProcess*>(g_browser_process)) {
|
| + static_cast<TestingBrowserProcess*>(g_browser_process)),
|
| + ui_thread_(BrowserThread::UI, &ui_loop_),
|
| + file_thread_(BrowserThread::FILE) {
|
| }
|
|
|
| virtual void SetUp() OVERRIDE {
|
| ASSERT_TRUE(testing_profile_manager_.SetUp());
|
| + file_thread_.Start();
|
| + }
|
| +
|
| + virtual void TearDown() OVERRIDE {
|
| + // Process all tasks on the FILE thread.
|
| + file_thread_.Stop();
|
| + // The FILE thread might post tasks back to the UI thread so drain the UI
|
| + // thread too.
|
| + ui_loop_.RunAllPending();
|
| }
|
|
|
| ProfileInfoCache* GetCache() {
|
| @@ -45,8 +98,15 @@ class ProfileInfoCacheUnittests : public testing::Test {
|
| #endif
|
| }
|
|
|
| + void ResetCache() {
|
| + testing_profile_manager_.DeleteProfileInfoCache();
|
| + }
|
| +
|
| private:
|
| + MessageLoopForUI ui_loop_;
|
| TestingProfileManager testing_profile_manager_;
|
| + content::TestBrowserThread ui_thread_;
|
| + content::TestBrowserThread file_thread_;
|
| };
|
|
|
| TEST_F(ProfileInfoCacheUnittests, AddProfiles) {
|
| @@ -60,7 +120,10 @@ TEST_F(ProfileInfoCacheUnittests, AddProfiles) {
|
| const SkBitmap& icon = ResourceBundle::GetSharedInstance().GetImageNamed(
|
| ProfileInfoCache::GetDefaultAvatarIconResourceIDAtIndex(i));
|
|
|
| - GetCache()->AddProfileToCache(profile_path, profile_name, string16(), 0);
|
| + GetCache()->AddProfileToCache(profile_path, profile_name, string16(), i);
|
| + GetCache()->SetBackgroundStatusOfProfileAtIndex(i, true);
|
| + string16 gaia_name = ASCIIToUTF16(StringPrintf("gaia_%ud", i));
|
| + GetCache()->SetGAIANameOfProfileAtIndex(i, gaia_name);
|
|
|
| EXPECT_EQ(i + 1, GetCache()->GetNumberOfProfiles());
|
| EXPECT_EQ(profile_name, GetCache()->GetNameOfProfileAtIndex(i));
|
| @@ -69,6 +132,23 @@ TEST_F(ProfileInfoCacheUnittests, AddProfiles) {
|
| EXPECT_EQ(icon.width(), actual_icon.width());
|
| EXPECT_EQ(icon.height(), actual_icon.height());
|
| }
|
| +
|
| + // Reset the cache and test the it reloads correctly.
|
| + ResetCache();
|
| +
|
| + EXPECT_EQ(4u, GetCache()->GetNumberOfProfiles());
|
| + for (uint32 i = 0; i < 4; ++i) {
|
| + std::string base_name = StringPrintf("path_%ud", i);
|
| + FilePath profile_path =
|
| + GetUserDataDir().Append(StringToFilePath(base_name));
|
| + EXPECT_EQ(i, GetCache()->GetIndexOfProfileWithPath(profile_path));
|
| + string16 profile_name = ASCIIToUTF16(StringPrintf("name_%ud", i));
|
| + EXPECT_EQ(profile_name, GetCache()->GetNameOfProfileAtIndex(i));
|
| + EXPECT_EQ(i, GetCache()->GetAvatarIconIndexOfProfileAtIndex(i));
|
| + EXPECT_EQ(true, GetCache()->GetBackgroundStatusOfProfileAtIndex(i));
|
| + string16 gaia_name = ASCIIToUTF16(StringPrintf("gaia_%ud", i));
|
| + EXPECT_EQ(gaia_name, GetCache()->GetGAIANameOfProfileAtIndex(i));
|
| + }
|
| }
|
|
|
| TEST_F(ProfileInfoCacheUnittests, DeleteProfile) {
|
| @@ -114,6 +194,47 @@ TEST_F(ProfileInfoCacheUnittests, MutateProfile) {
|
| GetCache()->GetAvatarIconOfProfileAtIndex(1);
|
| }
|
|
|
| +TEST_F(ProfileInfoCacheUnittests, Sort) {
|
| + string16 name_a = ASCIIToUTF16("apple");
|
| + GetCache()->AddProfileToCache(GetUserDataDir().Append(
|
| + StringToFilePath("path_a")), name_a, string16(), 0);
|
| +
|
| + string16 name_c = ASCIIToUTF16("cat");
|
| + GetCache()->AddProfileToCache(GetUserDataDir().Append(
|
| + StringToFilePath("path_c")), name_c, string16(), 0);
|
| +
|
| + // Sanity check the initial order.
|
| + EXPECT_EQ(name_a, GetCache()->GetNameOfProfileAtIndex(0));
|
| + EXPECT_EQ(name_c, GetCache()->GetNameOfProfileAtIndex(1));
|
| +
|
| + // Add a new profile (start with a capital to test case insensitive sorting.
|
| + string16 name_b = ASCIIToUTF16("Banana");
|
| + GetCache()->AddProfileToCache(GetUserDataDir().Append(
|
| + StringToFilePath("path_b")), name_b, string16(), 0);
|
| +
|
| + // Verify the new order.
|
| + EXPECT_EQ(name_a, GetCache()->GetNameOfProfileAtIndex(0));
|
| + EXPECT_EQ(name_b, GetCache()->GetNameOfProfileAtIndex(1));
|
| + EXPECT_EQ(name_c, GetCache()->GetNameOfProfileAtIndex(2));
|
| +
|
| + // Change the name of an existing profile.
|
| + name_a = UTF8ToUTF16("dog");
|
| + GetCache()->SetNameOfProfileAtIndex(0, name_a);
|
| +
|
| + // Verify the new order.
|
| + EXPECT_EQ(name_b, GetCache()->GetNameOfProfileAtIndex(0));
|
| + EXPECT_EQ(name_c, GetCache()->GetNameOfProfileAtIndex(1));
|
| + EXPECT_EQ(name_a, GetCache()->GetNameOfProfileAtIndex(2));
|
| +
|
| + // Delete a profile.
|
| + GetCache()->DeleteProfileFromCache(GetUserDataDir().Append(
|
| + StringToFilePath("path_c")));
|
| +
|
| + // Verify the new order.
|
| + EXPECT_EQ(name_b, GetCache()->GetNameOfProfileAtIndex(0));
|
| + EXPECT_EQ(name_a, GetCache()->GetNameOfProfileAtIndex(1));
|
| +}
|
| +
|
| TEST_F(ProfileInfoCacheUnittests, BackgroundModeStatus) {
|
| GetCache()->AddProfileToCache(
|
| GetUserDataDir().Append(StringToFilePath("path_1")),
|
| @@ -141,4 +262,143 @@ TEST_F(ProfileInfoCacheUnittests, BackgroundModeStatus) {
|
| EXPECT_FALSE(GetCache()->GetBackgroundStatusOfProfileAtIndex(1));
|
| }
|
|
|
| +TEST_F(ProfileInfoCacheUnittests, HasMigrated) {
|
| + GetCache()->AddProfileToCache(
|
| + GetUserDataDir().Append(StringToFilePath("path_1")),
|
| + ASCIIToUTF16("name_1"), string16(), 0);
|
| + GetCache()->AddProfileToCache(
|
| + GetUserDataDir().Append(StringToFilePath("path_2")),
|
| + ASCIIToUTF16("name_2"), string16(), 0);
|
| +
|
| + // Sanity check.
|
| + EXPECT_FALSE(GetCache()->GetHasMigratedToGAIAInfoOfProfileAtIndex(0));
|
| + EXPECT_FALSE(GetCache()->GetHasMigratedToGAIAInfoOfProfileAtIndex(1));
|
| +
|
| + // Set migrated state for 2nd profile.
|
| + GetCache()->SetHasMigratedToGAIAInfoOfProfileAtIndex(1, true);
|
| + EXPECT_FALSE(GetCache()->GetHasMigratedToGAIAInfoOfProfileAtIndex(0));
|
| + EXPECT_TRUE(GetCache()->GetHasMigratedToGAIAInfoOfProfileAtIndex(1));
|
| +
|
| + // Set migrated state for 1st profile.
|
| + GetCache()->SetHasMigratedToGAIAInfoOfProfileAtIndex(0, true);
|
| + EXPECT_TRUE(GetCache()->GetHasMigratedToGAIAInfoOfProfileAtIndex(0));
|
| + EXPECT_TRUE(GetCache()->GetHasMigratedToGAIAInfoOfProfileAtIndex(1));
|
| +
|
| + // Unset migrated state for 2nd profile.
|
| + GetCache()->SetHasMigratedToGAIAInfoOfProfileAtIndex(1, false);
|
| + EXPECT_TRUE(GetCache()->GetHasMigratedToGAIAInfoOfProfileAtIndex(0));
|
| + EXPECT_FALSE(GetCache()->GetHasMigratedToGAIAInfoOfProfileAtIndex(1));
|
| +}
|
| +
|
| +TEST_F(ProfileInfoCacheUnittests, GAIAName) {
|
| + GetCache()->AddProfileToCache(
|
| + GetUserDataDir().Append(StringToFilePath("path_1")),
|
| + ASCIIToUTF16("name_1"), string16(), 0);
|
| + string16 profile_name(ASCIIToUTF16("profile name 2"));
|
| + GetCache()->AddProfileToCache(
|
| + GetUserDataDir().Append(StringToFilePath("path_2")),
|
| + profile_name, string16(), 0);
|
| +
|
| + // Sanity check.
|
| + EXPECT_TRUE(GetCache()->GetGAIANameOfProfileAtIndex(0).empty());
|
| + EXPECT_TRUE(GetCache()->GetGAIANameOfProfileAtIndex(1).empty());
|
| + EXPECT_FALSE(GetCache()->IsUsingGAIANameOfProfileAtIndex(0));
|
| + EXPECT_FALSE(GetCache()->IsUsingGAIANameOfProfileAtIndex(1));
|
| +
|
| + // Set GAIA name.
|
| + string16 gaia_name(ASCIIToUTF16("Pat Smith"));
|
| + GetCache()->SetGAIANameOfProfileAtIndex(1, gaia_name);
|
| + EXPECT_TRUE(GetCache()->GetGAIANameOfProfileAtIndex(0).empty());
|
| + EXPECT_EQ(gaia_name, GetCache()->GetGAIANameOfProfileAtIndex(1));
|
| + EXPECT_EQ(profile_name, GetCache()->GetNameOfProfileAtIndex(1));
|
| +
|
| + // Use GAIA name as profile name.
|
| + GetCache()->SetIsUsingGAIANameOfProfileAtIndex(1, true);
|
| +
|
| + EXPECT_EQ(gaia_name, GetCache()->GetNameOfProfileAtIndex(1));
|
| + EXPECT_EQ(gaia_name, GetCache()->GetGAIANameOfProfileAtIndex(1));
|
| +
|
| + // Don't use GAIA name as profile name.
|
| + GetCache()->SetIsUsingGAIANameOfProfileAtIndex(1, false);
|
| + EXPECT_EQ(profile_name, GetCache()->GetNameOfProfileAtIndex(1));
|
| + EXPECT_EQ(gaia_name, GetCache()->GetGAIANameOfProfileAtIndex(1));
|
| +}
|
| +
|
| +TEST_F(ProfileInfoCacheUnittests, GAIAPicture) {
|
| + GetCache()->AddProfileToCache(
|
| + GetUserDataDir().Append(StringToFilePath("path_1")),
|
| + ASCIIToUTF16("name_1"), string16(), 0);
|
| + GetCache()->AddProfileToCache(
|
| + GetUserDataDir().Append(StringToFilePath("path_2")),
|
| + ASCIIToUTF16("name_2"), string16(), 0);
|
| +
|
| + // Sanity check.
|
| + EXPECT_TRUE(
|
| + GetCache()->GetGAIAPictureOfProfileAtIndex(0).ToSkBitmap()->isNull());
|
| + EXPECT_TRUE(
|
| + GetCache()->GetGAIAPictureOfProfileAtIndex(1).ToSkBitmap()->isNull());
|
| + EXPECT_FALSE(GetCache()->IsUsingGAIAPictureOfProfileAtIndex(0));
|
| + EXPECT_FALSE(GetCache()->IsUsingGAIAPictureOfProfileAtIndex(1));
|
| +
|
| + // The profile icon should be the default one.
|
| + int id = ProfileInfoCache::GetDefaultAvatarIconResourceIDAtIndex(0);
|
| + const gfx::Image& profile_image(
|
| + ResourceBundle::GetSharedInstance().GetImageNamed(id));
|
| + EXPECT_TRUE(IsEqual(
|
| + profile_image, GetCache()->GetAvatarIconOfProfileAtIndex(1)));
|
| +
|
| + // Set GAIA picture.
|
| + gfx::Image gaia_image(CreateTestImage());
|
| + GetCache()->SetGAIAPictureOfProfileAtIndex(1, gaia_image);
|
| + EXPECT_TRUE(
|
| + GetCache()->GetGAIAPictureOfProfileAtIndex(0).ToSkBitmap()->isNull());
|
| + EXPECT_TRUE(IsEqual(
|
| + gaia_image, GetCache()->GetGAIAPictureOfProfileAtIndex(1)));
|
| + EXPECT_TRUE(IsEqual(
|
| + profile_image, GetCache()->GetAvatarIconOfProfileAtIndex(1)));
|
| +
|
| + // Use GAIA picture as profile picture.
|
| + GetCache()->SetIsUsingGAIAPictureOfProfileAtIndex(1, true);
|
| + EXPECT_TRUE(IsEqual(
|
| + gaia_image, GetCache()->GetGAIAPictureOfProfileAtIndex(1)));
|
| + EXPECT_TRUE(IsEqual(
|
| + gaia_image, GetCache()->GetAvatarIconOfProfileAtIndex(1)));
|
| +
|
| + // Don't use GAIA picture as profile picture.
|
| + GetCache()->SetIsUsingGAIAPictureOfProfileAtIndex(1, false);
|
| + EXPECT_TRUE(IsEqual(
|
| + gaia_image, GetCache()->GetGAIAPictureOfProfileAtIndex(1)));
|
| + EXPECT_TRUE(IsEqual(
|
| + profile_image, GetCache()->GetAvatarIconOfProfileAtIndex(1)));
|
| +}
|
| +
|
| +TEST_F(ProfileInfoCacheUnittests, PersistGAIAPicture) {
|
| + GetCache()->AddProfileToCache(
|
| + GetUserDataDir().Append(StringToFilePath("path_1")),
|
| + ASCIIToUTF16("name_1"), string16(), 0);
|
| + gfx::Image gaia_image(CreateTestImage());
|
| +
|
| + ui_test_utils::WindowedNotificationObserver save_observer(
|
| + chrome::NOTIFICATION_PROFILE_CACHE_PICTURE_SAVED,
|
| + content::NotificationService::AllSources());
|
| + GetCache()->SetGAIAPictureOfProfileAtIndex(0, gaia_image);
|
| + EXPECT_TRUE(IsEqual(
|
| + gaia_image, GetCache()->GetGAIAPictureOfProfileAtIndex(0)));
|
| +
|
| + // Wait for the file to be written to disk then reset the cache.
|
| + save_observer.Wait();
|
| + ResetCache();
|
| +
|
| + // Try to get the GAIA picture. This should return NULL until the read from
|
| + // disk is done.
|
| + ui_test_utils::WindowedNotificationObserver read_observer(
|
| + chrome::NOTIFICATION_PROFILE_CACHED_INFO_CHANGED,
|
| + content::NotificationService::AllSources());
|
| + EXPECT_TRUE(
|
| + GetCache()->GetGAIAPictureOfProfileAtIndex(0).ToSkBitmap()->isNull());
|
| + read_observer.Wait();
|
| + EXPECT_TRUE(IsEqual(
|
| + gaia_image, GetCache()->GetGAIAPictureOfProfileAtIndex(0)));
|
| +}
|
| +
|
| } // namespace
|
|
|