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

Side by Side Diff: chrome/browser/ui/bookmarks/bookmark_bubble_sign_in_delegate_unittest.cc

Issue 807503004: While trying to enable webview sign-in by default, I found a bunch of issues (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Move comment, remove RunAllPending Created 5 years, 11 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 unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "chrome/browser/ui/bookmarks/bookmark_bubble_sign_in_delegate.h"
6
7 #include "base/basictypes.h"
8 #include "base/command_line.h"
9 #include "base/memory/scoped_ptr.h"
10 #include "chrome/browser/extensions/test_extension_service.h"
11 #include "chrome/browser/extensions/test_extension_system.h"
12 #include "chrome/browser/ui/bookmarks/bookmark_bubble_delegate.h"
13 #include "chrome/browser/ui/browser.h"
14 #include "chrome/browser/ui/browser_list.h"
15 #include "chrome/browser/ui/tabs/tab_strip_model.h"
16 #include "chrome/common/chrome_switches.h"
17 #include "chrome/test/base/browser_with_test_window_test.h"
18 #include "chrome/test/base/testing_profile.h"
19 #include "ui/events/event_constants.h"
20 #include "ui/gfx/range/range.h"
21
22 class BookmarkBubbleSignInDelegateTest : public BrowserWithTestWindowTest {
23 public:
24 BookmarkBubbleSignInDelegateTest() {}
25
26 void SetUp() override;
27
28 protected:
29 class Window : public TestBrowserWindow {
30 public:
31 Window() : show_count_(0) {}
32
33 int show_count() { return show_count_; }
34
35 private:
36 // TestBrowserWindow:
37 void Show() override { ++show_count_; }
38
39 // Number of times that the Show() method has been called.
40 int show_count_;
41
42 DISALLOW_COPY_AND_ASSIGN(Window);
43 };
44
45 BrowserWindow* CreateBrowserWindow() override { return new Window(); }
46
47 private:
48 DISALLOW_COPY_AND_ASSIGN(BookmarkBubbleSignInDelegateTest);
49 };
50
51 void BookmarkBubbleSignInDelegateTest::SetUp() {
52 BrowserWithTestWindowTest::SetUp();
53 base::CommandLine* command_line = base::CommandLine::ForCurrentProcess();
54 // Force web-based signin, otherwise tests will crash because inline signin
55 // involves IO thread operation.
56 // TODO(guohui): fix the test for inline signin.
57 command_line->AppendSwitch(switches::kEnableWebBasedSignin);
58 // Adds TestExtensionSystem, since signin uses the gaia auth extension.
59 static_cast<extensions::TestExtensionSystem*>(
60 extensions::ExtensionSystem::Get(profile()))->CreateExtensionService(
61 command_line, base::FilePath(), false);
62 }
63
64 TEST_F(BookmarkBubbleSignInDelegateTest, OnSignInLinkClicked) {
65 int starting_tab_count = browser()->tab_strip_model()->count();
66
67 scoped_ptr<BookmarkBubbleDelegate> delegate;
68 delegate.reset(new BookmarkBubbleSignInDelegate(browser()));
69
70 delegate->OnSignInLinkClicked();
71
72 // A new tab should have been opened and the browser should be visible.
73 int tab_count = browser()->tab_strip_model()->count();
74 EXPECT_EQ(starting_tab_count + 1, tab_count);
75 EXPECT_LE(1,
76 static_cast<BookmarkBubbleSignInDelegateTest::Window*>(
77 browser()->window())->show_count());
78 }
79
80 TEST_F(BookmarkBubbleSignInDelegateTest, OnSignInLinkClickedIncognito) {
81 scoped_ptr<BrowserWindow> incognito_window;
82 incognito_window.reset(CreateBrowserWindow());
83 Browser::CreateParams params(browser()->profile()->GetOffTheRecordProfile(),
84 browser()->host_desktop_type());
85 params.window = incognito_window.get();
86 scoped_ptr<Browser> incognito_browser;
87 incognito_browser.reset(new Browser(params));
88
89 int starting_tab_count_normal = browser()->tab_strip_model()->count();
90 int starting_tab_count_incognito =
91 incognito_browser.get()->tab_strip_model()->count();
92
93 scoped_ptr<BookmarkBubbleDelegate> delegate;
94 delegate.reset(new BookmarkBubbleSignInDelegate(incognito_browser.get()));
95
96 delegate->OnSignInLinkClicked();
97
98 // A new tab should have been opened in the normal browser, which should be
99 // visible.
100 int tab_count_normal = browser()->tab_strip_model()->count();
101 EXPECT_EQ(starting_tab_count_normal + 1, tab_count_normal);
102 EXPECT_LE(1,
103 static_cast<BookmarkBubbleSignInDelegateTest::Window*>(
104 browser()->window())->show_count());
105
106 // No effect is expected on the incognito browser.
107 int tab_count_incognito = incognito_browser->tab_strip_model()->count();
108 EXPECT_EQ(starting_tab_count_incognito, tab_count_incognito);
109 EXPECT_EQ(0,
110 static_cast<BookmarkBubbleSignInDelegateTest::Window*>(
111 incognito_window.get())->show_count());
112 }
113
114 // Verifies that the sign in page can be loaded in a different browser
115 // if the provided browser is invalidated.
116 TEST_F(BookmarkBubbleSignInDelegateTest, BrowserRemoved) {
117 // Create an extra browser.
118 scoped_ptr<BrowserWindow> extra_window;
119 extra_window.reset(CreateBrowserWindow());
120
121 Browser::CreateParams params(browser()->profile(),
122 browser()->host_desktop_type());
123 params.window = extra_window.get();
124 scoped_ptr<Browser> extra_browser;
125 extra_browser.reset(new Browser(params));
126
127 int starting_tab_count = extra_browser->tab_strip_model()->count();
128
129 scoped_ptr<BookmarkBubbleDelegate> delegate;
130 delegate.reset(new BookmarkBubbleSignInDelegate(browser()));
131
132 BrowserList::SetLastActive(extra_browser.get());
133
134 browser()->tab_strip_model()->CloseAllTabs();
135 set_browser(NULL);
136
137 delegate->OnSignInLinkClicked();
138
139 // A new tab should have been opened in the extra browser, which should be
140 // visible.
141 int tab_count = extra_browser->tab_strip_model()->count();
142 EXPECT_EQ(starting_tab_count + 1, tab_count);
143 EXPECT_LE(1,
144 static_cast<BookmarkBubbleSignInDelegateTest::Window*>(
145 extra_window.get())->show_count());
146
147 // Required to avoid a crash when the browser is deleted.
148 extra_browser->tab_strip_model()->CloseAllTabs();
149 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698