This source file includes following definitions.
- OnAvatarMenuChanged
- change_count
- SetUp
- GetFakeUserManager
- AddProfile
- GetAvatarMenu
- ActiveUserChanged
- manager
- change_count
- TEST_F
- TEST_F
- TEST_F
- TEST_F
- TEST_F
- TEST_F
- TEST_F
- TEST_F
- TEST_F
#include <string>
#include "ash/ash_switches.h"
#include "base/command_line.h"
#include "base/memory/scoped_ptr.h"
#include "base/strings/string16.h"
#include "base/strings/utf_string_conversions.h"
#include "chrome/browser/chromeos/login/fake_user_manager.h"
#include "chrome/browser/chromeos/profiles/profile_helper.h"
#include "chrome/browser/prefs/pref_service_syncable.h"
#include "chrome/browser/profiles/avatar_menu.h"
#include "chrome/browser/profiles/avatar_menu_observer.h"
#include "chrome/browser/profiles/profile_info_cache.h"
#include "chrome/browser/ui/ash/chrome_shell_delegate.h"
#include "chrome/common/chrome_constants.h"
#include "chrome/common/chrome_switches.h"
#include "chrome/test/base/testing_browser_process.h"
#include "chrome/test/base/testing_profile_manager.h"
#include "testing/gtest/include/gtest/gtest.h"
#include "ui/base/l10n/l10n_util.h"
using base::ASCIIToUTF16;
namespace {
static const char kUserIdHashSuffix[] = "-hash";
class MockObserver : public AvatarMenuObserver {
public:
MockObserver() : count_(0) {}
virtual ~MockObserver() {}
virtual void OnAvatarMenuChanged(
AvatarMenu* avatar_menu) OVERRIDE {
++count_;
}
int change_count() const { return count_; }
private:
int count_;
DISALLOW_COPY_AND_ASSIGN(MockObserver);
};
}
namespace chromeos {
class ProfileListChromeOSTest : public testing::Test {
public:
ProfileListChromeOSTest()
: manager_(TestingBrowserProcess::GetGlobal()) {
}
virtual void SetUp() {
ASSERT_TRUE(manager_.SetUp());
manager_.SetLoggedIn(true);
CommandLine* cl = CommandLine::ForCurrentProcess();
cl->AppendSwitch(switches::kMultiProfiles);
user_manager_enabler_.reset(
new ScopedUserManagerEnabler(new FakeUserManager));
}
FakeUserManager* GetFakeUserManager() {
return static_cast<FakeUserManager*>(UserManager::Get());
}
void AddProfile(base::string16 name, bool log_in) {
std::string email_string = base::UTF16ToASCII(name) + "@example.com";
GetFakeUserManager()->AddUser(email_string);
if (log_in) {
GetFakeUserManager()->UserLoggedIn(
email_string,
email_string + kUserIdHashSuffix,
false);
}
manager()->CreateTestingProfile(
chrome::kProfileDirPrefix + email_string + kUserIdHashSuffix,
scoped_ptr<PrefServiceSyncable>(),
ASCIIToUTF16(email_string), 0, std::string(),
TestingProfile::TestingFactories());
}
AvatarMenu* GetAvatarMenu() {
mock_observer_.reset(new MockObserver());
EXPECT_EQ(0, change_count());
avatar_menu_.reset(new AvatarMenu(
manager()->profile_info_cache(),
mock_observer_.get(),
NULL));
avatar_menu_->RebuildMenu();
EXPECT_EQ(0, change_count());
return avatar_menu_.get();
}
void ActiveUserChanged(ProfileHelper* profile_helper,
const std::string& hash) {
profile_helper->ActiveUserHashChanged(hash);
}
TestingProfileManager* manager() { return &manager_; }
int change_count() const { return mock_observer_->change_count(); }
private:
TestingProfileManager manager_;
scoped_ptr<MockObserver> mock_observer_;
scoped_ptr<ScopedUserManagerEnabler> user_manager_enabler_;
scoped_ptr<AvatarMenu> avatar_menu_;
ChromeShellDelegate chrome_shell_delegate_;
DISALLOW_COPY_AND_ASSIGN(ProfileListChromeOSTest);
};
TEST_F(ProfileListChromeOSTest, InitialCreation) {
base::string16 name1(ASCIIToUTF16("p1"));
AddProfile(name1, true);
AvatarMenu* menu = GetAvatarMenu();
ASSERT_EQ(1U, menu->GetNumberOfItems());
const AvatarMenu::Item& item1 = menu->GetItemAt(0);
EXPECT_EQ(0U, item1.menu_index);
EXPECT_EQ(name1, item1.name);
}
TEST_F(ProfileListChromeOSTest, ShowLoggedInUsers) {
base::string16 name1(ASCIIToUTF16("p1"));
base::string16 name2(ASCIIToUTF16("p2"));
base::string16 name3(ASCIIToUTF16("p3"));
base::string16 name4(ASCIIToUTF16("p4"));
AddProfile(name1, true);
AddProfile(name2, false);
AddProfile(name3, true);
AddProfile(name4, false);
AvatarMenu* menu = GetAvatarMenu();
ASSERT_EQ(2U, menu->GetNumberOfItems());
const AvatarMenu::Item& item1 = menu->GetItemAt(0);
EXPECT_EQ(0U, item1.menu_index);
EXPECT_EQ(name1, item1.name);
const AvatarMenu::Item& item3 = menu->GetItemAt(1);
EXPECT_EQ(1U, item3.menu_index);
EXPECT_EQ(name3, item3.name);
}
TEST_F(ProfileListChromeOSTest, DontShowManagedUsers) {
base::string16 name1(ASCIIToUTF16("p1"));
base::string16 managed_name(ASCIIToUTF16("p2@example.com"));
AddProfile(name1, true);
ProfileInfoCache* cache = manager()->profile_info_cache();
manager()->profile_info_cache()->AddProfileToCache(
cache->GetUserDataDir().AppendASCII("p2"), managed_name,
base::string16(), 0, "TEST_ID");
GetFakeUserManager()->AddUser(base::UTF16ToASCII(managed_name));
AvatarMenu* menu = GetAvatarMenu();
ASSERT_EQ(1U, menu->GetNumberOfItems());
const AvatarMenu::Item& item1 = menu->GetItemAt(0);
EXPECT_EQ(0U, item1.menu_index);
EXPECT_EQ(name1, item1.name);
}
TEST_F(ProfileListChromeOSTest, ShowAddProfileLink) {
base::string16 name1(ASCIIToUTF16("p1.com"));
base::string16 name2(ASCIIToUTF16("p2.com"));
AddProfile(name1, true);
AddProfile(name2, false);
AvatarMenu* menu = GetAvatarMenu();
ASSERT_EQ(1U, menu->GetNumberOfItems());
EXPECT_TRUE(menu->ShouldShowAddNewProfileLink());
}
TEST_F(ProfileListChromeOSTest, DontShowAddProfileLink) {
base::string16 name1(ASCIIToUTF16("p1.com"));
base::string16 name2(ASCIIToUTF16("p2.com"));
AddProfile(name1, true);
AddProfile(name2, true);
AvatarMenu* menu = GetAvatarMenu();
ASSERT_EQ(2U, menu->GetNumberOfItems());
EXPECT_FALSE(menu->ShouldShowAddNewProfileLink());
}
TEST_F(ProfileListChromeOSTest, ActiveItem) {
base::string16 name1(ASCIIToUTF16("p1.com"));
base::string16 name2(ASCIIToUTF16("p2.com"));
AddProfile(name1, true);
AddProfile(name2, true);
std::string email_string = base::UTF16ToASCII(name1) + "@example.com";
std::string hash = email_string + kUserIdHashSuffix;
ActiveUserChanged(
g_browser_process->platform_part()->profile_helper(), hash);
AvatarMenu* menu = GetAvatarMenu();
ASSERT_EQ(2U, menu->GetNumberOfItems());
ASSERT_EQ(0U, menu->GetActiveProfileIndex());
}
TEST_F(ProfileListChromeOSTest, ModifyingNameResortsCorrectly) {
base::string16 name1(ASCIIToUTF16("Alpha"));
base::string16 name2(ASCIIToUTF16("Beta"));
base::string16 newname1(ASCIIToUTF16("Gamma"));
AddProfile(name1, true);
AddProfile(name2, true);
AvatarMenu* menu = GetAvatarMenu();
ASSERT_EQ(2U, menu->GetNumberOfItems());
const AvatarMenu::Item& item1 = menu->GetItemAt(0);
EXPECT_EQ(0U, item1.menu_index);
EXPECT_EQ(name1, item1.name);
const AvatarMenu::Item& item2 = menu->GetItemAt(1);
EXPECT_EQ(1U, item2.menu_index);
EXPECT_EQ(name2, item2.name);
GetFakeUserManager()->SaveUserDisplayName(
base::UTF16ToASCII(name1) + "@example.com", newname1);
manager()->profile_info_cache()->SetNameOfProfileAtIndex(0, newname1);
const AvatarMenu::Item& item1next = menu->GetItemAt(0);
EXPECT_GT(change_count(), 1);
EXPECT_EQ(0U, item1next.menu_index);
EXPECT_EQ(name2, item1next.name);
const AvatarMenu::Item& item2next = menu->GetItemAt(1);
EXPECT_EQ(1U, item2next.menu_index);
EXPECT_EQ(newname1, item2next.name);
}
TEST_F(ProfileListChromeOSTest, ChangeOnNotify) {
base::string16 name1(ASCIIToUTF16("p1.com"));
base::string16 name2(ASCIIToUTF16("p2.com"));
AddProfile(name1, true);
AddProfile(name2, true);
AvatarMenu* menu = GetAvatarMenu();
EXPECT_EQ(2U, menu->GetNumberOfItems());
base::string16 name3(ASCIIToUTF16("p3.com"));
AddProfile(name3, true);
EXPECT_GE(change_count(), 4);
ASSERT_EQ(3U, menu->GetNumberOfItems());
const AvatarMenu::Item& item1 = menu->GetItemAt(0);
EXPECT_EQ(0U, item1.menu_index);
EXPECT_EQ(name1, item1.name);
const AvatarMenu::Item& item2 = menu->GetItemAt(1);
EXPECT_EQ(1U, item2.menu_index);
EXPECT_EQ(name2, item2.name);
const AvatarMenu::Item& item3 = menu->GetItemAt(2);
EXPECT_EQ(2U, item3.menu_index);
EXPECT_EQ(name3, item3.name);
}
TEST_F(ProfileListChromeOSTest, DontShowAvatarMenu) {
base::string16 name1(ASCIIToUTF16("p1"));
base::string16 name2(ASCIIToUTF16("p2"));
AddProfile(name1, true);
EXPECT_FALSE(AvatarMenu::ShouldShowAvatarMenu());
AddProfile(name2, false);
EXPECT_FALSE(AvatarMenu::ShouldShowAvatarMenu());
}
}