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

Unified Diff: chrome/browser/ui/views/new_avatar_menu_button_browsertest.cc

Issue 24647003: Redesign of the avatar menu button. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: better fix for app/popup browser crash Created 7 years, 2 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
« no previous file with comments | « chrome/browser/ui/views/new_avatar_button.cc ('k') | chrome/browser/ui/views/profile_chooser_view.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/ui/views/new_avatar_menu_button_browsertest.cc
diff --git a/chrome/browser/ui/views/avatar_menu_button_browsertest.cc b/chrome/browser/ui/views/new_avatar_menu_button_browsertest.cc
similarity index 52%
copy from chrome/browser/ui/views/avatar_menu_button_browsertest.cc
copy to chrome/browser/ui/views/new_avatar_menu_button_browsertest.cc
index a3c01250caacef69479aa69063f6c0b6ba4e3fa1..83251755f1815d7346882c5990959f84d032b96a 100644
--- a/chrome/browser/ui/views/avatar_menu_button_browsertest.cc
+++ b/chrome/browser/ui/views/new_avatar_menu_button_browsertest.cc
@@ -2,20 +2,17 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
-#include "chrome/browser/ui/views/avatar_menu_button.h"
-
#include "base/command_line.h"
#include "base/path_service.h"
#include "base/strings/utf_string_conversions.h"
#include "chrome/browser/chrome_notification_types.h"
-#include "chrome/browser/profiles/avatar_menu.h"
#include "chrome/browser/profiles/profile_manager.h"
#include "chrome/browser/profiles/profiles_state.h"
#include "chrome/browser/ui/browser_list.h"
-#include "chrome/browser/ui/views/avatar_menu_bubble_view.h"
+#include "chrome/browser/ui/views/avatar_menu_button.h"
#include "chrome/browser/ui/views/frame/browser_view.h"
+#include "chrome/browser/ui/views/new_avatar_button.h"
#include "chrome/browser/ui/views/profile_chooser_view.h"
-#include "chrome/browser/ui/views/user_manager_view.h"
#include "chrome/common/chrome_paths.h"
#include "chrome/common/chrome_switches.h"
#include "chrome/test/base/in_process_browser_test.h"
@@ -23,53 +20,39 @@
#include "chrome/test/base/testing_browser_process.h"
#include "content/public/test/test_utils.h"
#include "grit/generated_resources.h"
-#include "ui/base/l10n/l10n_util.h"
-#include "ui/views/controls/button/label_button.h"
-class AvatarMenuButtonTest : public InProcessBrowserTest,
- public testing::WithParamInterface<bool> {
+class NewAvatarMenuButtonTest : public InProcessBrowserTest {
public:
- AvatarMenuButtonTest();
- virtual ~AvatarMenuButtonTest();
+ NewAvatarMenuButtonTest();
+ virtual ~NewAvatarMenuButtonTest();
protected:
virtual void SetUp() OVERRIDE;
-
- bool UsingNewProfileChooser();
+ virtual void SetUpCommandLine(CommandLine* command_line) OVERRIDE;
void CreateTestingProfile();
- AvatarMenuButton* GetAvatarMenuButton();
void StartAvatarMenu();
private:
- DISALLOW_COPY_AND_ASSIGN(AvatarMenuButtonTest);
+ DISALLOW_COPY_AND_ASSIGN(NewAvatarMenuButtonTest);
};
-AvatarMenuButtonTest::AvatarMenuButtonTest() {
+NewAvatarMenuButtonTest::NewAvatarMenuButtonTest() {
}
-AvatarMenuButtonTest::~AvatarMenuButtonTest() {
+NewAvatarMenuButtonTest::~NewAvatarMenuButtonTest() {
}
-void AvatarMenuButtonTest::SetUp() {
- if (GetParam()) {
- if (!UsingNewProfileChooser()) {
- CommandLine::ForCurrentProcess()->AppendSwitch(
- switches::kNewProfileManagement);
- }
- DCHECK(UsingNewProfileChooser());
- } else {
- DCHECK(!UsingNewProfileChooser());
- }
-
+void NewAvatarMenuButtonTest::SetUp() {
InProcessBrowserTest::SetUp();
+ DCHECK(CommandLine::ForCurrentProcess()->HasSwitch(
+ switches::kNewProfileManagement));
}
-bool AvatarMenuButtonTest::UsingNewProfileChooser() {
- return CommandLine::ForCurrentProcess()->HasSwitch(
- switches::kNewProfileManagement);
+void NewAvatarMenuButtonTest::SetUpCommandLine(CommandLine* command_line) {
+ command_line->AppendSwitch(switches::kNewProfileManagement);
}
-void AvatarMenuButtonTest::CreateTestingProfile() {
+void NewAvatarMenuButtonTest::CreateTestingProfile() {
ProfileManager* profile_manager = g_browser_process->profile_manager();
EXPECT_EQ(1u, profile_manager->GetNumberOfProfiles());
@@ -88,60 +71,29 @@ void AvatarMenuButtonTest::CreateTestingProfile() {
EXPECT_EQ(2u, profile_manager->GetNumberOfProfiles());
}
-AvatarMenuButton* AvatarMenuButtonTest::GetAvatarMenuButton() {
+void NewAvatarMenuButtonTest::StartAvatarMenu() {
BrowserView* browser_view = reinterpret_cast<BrowserView*>(
browser()->window());
- return browser_view->frame()->GetAvatarMenuButton();
-}
-void AvatarMenuButtonTest::StartAvatarMenu() {
- AvatarMenuButton* button = GetAvatarMenuButton();
+ // Ensure that the avatar icon button is not also showing.
+ NewAvatarButton* button = browser_view->frame()->GetNewAvatarMenuButton();
ASSERT_TRUE(button);
+ ASSERT_FALSE(browser_view->frame()->GetAvatarMenuButton());
- AvatarMenuBubbleView::set_close_on_deactivate(false);
ProfileChooserView::set_close_on_deactivate(false);
- static_cast<views::MenuButtonListener*>(button)->OnMenuButtonClicked(
- NULL, gfx::Point());
- base::MessageLoop::current()->RunUntilIdle();
- EXPECT_NE(AvatarMenuBubbleView::IsShowing(),
- ProfileChooserView::IsShowing());
-}
-
-IN_PROC_BROWSER_TEST_P(AvatarMenuButtonTest, HideOnSecondClick) {
-#if defined(OS_WIN) && defined(USE_ASH)
- // Disable this test in Metro+Ash for now (http://crbug.com/262796).
- if (CommandLine::ForCurrentProcess()->HasSwitch(switches::kAshBrowserTests))
- return;
-#endif
-
- if (!profiles::IsMultipleProfilesEnabled() ||
- UsingNewProfileChooser()) {
- return;
- }
-
- CreateTestingProfile();
- StartAvatarMenu();
-
- // Verify that clicking again doesn't reshow it.
- AvatarMenuButton* button = GetAvatarMenuButton();
- static_cast<views::MenuButtonListener*>(button)->OnMenuButtonClicked(
- NULL, gfx::Point());
- // Hide the bubble manually. In the browser this would normally happen during
- // the event processing.
- AvatarMenuBubbleView::Hide();
+ ui::MouseEvent mouse_ev(ui::ET_MOUSE_RELEASED, gfx::Point(), gfx::Point(), 0);
+ button->NotifyClick(mouse_ev);
base::MessageLoop::current()->RunUntilIdle();
- EXPECT_FALSE(AvatarMenuBubbleView::IsShowing());
- EXPECT_FALSE(ProfileChooserView::IsShowing());
+ EXPECT_TRUE(ProfileChooserView::IsShowing());
}
-IN_PROC_BROWSER_TEST_P(AvatarMenuButtonTest, NewSignOut) {
- if (!profiles::IsMultipleProfilesEnabled() ||
- !UsingNewProfileChooser()) {
+IN_PROC_BROWSER_TEST_F(NewAvatarMenuButtonTest, SignOut) {
+ // If multiprofile mode is not enabled, you can't switch between profiles.
+ if (!profiles::IsMultipleProfilesEnabled())
return;
- }
CreateTestingProfile();
- StartAvatarMenu();
+ ASSERT_NO_FATAL_FAILURE(StartAvatarMenu());
BrowserList* browser_list =
BrowserList::GetInstance(chrome::GetActiveDesktop());
@@ -169,6 +121,3 @@ IN_PROC_BROWSER_TEST_P(AvatarMenuButtonTest, NewSignOut) {
window_close_observer.Wait(); // Rely on test timeout for failure indication.
EXPECT_TRUE(browser_list->empty());
}
-
-INSTANTIATE_TEST_CASE_P(Old, AvatarMenuButtonTest, testing::Values(false));
-INSTANTIATE_TEST_CASE_P(New, AvatarMenuButtonTest, testing::Values(true));
« no previous file with comments | « chrome/browser/ui/views/new_avatar_button.cc ('k') | chrome/browser/ui/views/profile_chooser_view.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698