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

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

Issue 23726016: Show non-incognito browser in front of incognito browser when signing in from bookmark bubble. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fix comment Created 7 years, 3 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
« no previous file with comments | « chrome/browser/ui/bookmarks/bookmark_bubble_sign_in_delegate.cc ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 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 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/ui/bookmarks/bookmark_bubble_sign_in_delegate.h" 5 #include "chrome/browser/ui/bookmarks/bookmark_bubble_sign_in_delegate.h"
6 6
7 #include "base/memory/scoped_ptr.h" 7 #include "base/memory/scoped_ptr.h"
8 #include "chrome/browser/ui/bookmarks/bookmark_bubble_delegate.h" 8 #include "chrome/browser/ui/bookmarks/bookmark_bubble_delegate.h"
9 #include "chrome/browser/ui/browser.h" 9 #include "chrome/browser/ui/browser.h"
10 #include "chrome/browser/ui/browser_list.h" 10 #include "chrome/browser/ui/browser_list.h"
11 #include "chrome/browser/ui/tabs/tab_strip_model.h" 11 #include "chrome/browser/ui/tabs/tab_strip_model.h"
12 #include "chrome/test/base/browser_with_test_window_test.h" 12 #include "chrome/test/base/browser_with_test_window_test.h"
13 #include "chrome/test/base/testing_profile.h"
13 #include "ui/base/events/event_constants.h" 14 #include "ui/base/events/event_constants.h"
14 #include "ui/base/range/range.h" 15 #include "ui/base/range/range.h"
15 16
16 typedef BrowserWithTestWindowTest BookmarkBubbleSignInDelegateTest; 17 class BookmarkBubbleSignInDelegateTest : public BrowserWithTestWindowTest {
18 public:
19 BookmarkBubbleSignInDelegateTest() {}
20
21 protected:
22 class Window : public TestBrowserWindow {
23 public:
24 Window() : show_count_(0) {}
25
26 // ui::BaseWindow:
27 virtual void Show() OVERRIDE {
tfarina 2013/08/31 01:32:05 can this be in private section? also // TestBrow
fdoray 2013/09/03 01:38:57 Done.
28 ++show_count_;
29 }
30
31 // Number of times that the Show() method has been called.
32 int show_count_;
tfarina 2013/08/31 01:32:05 please, make this private, add a public getter for
fdoray 2013/09/03 01:38:57 Done.
33 };
34
35 virtual BrowserWindow* CreateBrowserWindow() OVERRIDE {
36 return new Window();
37 }
38 };
17 39
18 TEST_F(BookmarkBubbleSignInDelegateTest, OnSignInLinkClicked) { 40 TEST_F(BookmarkBubbleSignInDelegateTest, OnSignInLinkClicked) {
19 int starting_tab_count = browser()->tab_strip_model()->count(); 41 int starting_tab_count = browser()->tab_strip_model()->count();
20 42
21 scoped_ptr<BookmarkBubbleDelegate> delegate; 43 scoped_ptr<BookmarkBubbleDelegate> delegate;
22 delegate.reset(new BookmarkBubbleSignInDelegate(browser())); 44 delegate.reset(new BookmarkBubbleSignInDelegate(browser()));
23 45
24 delegate->OnSignInLinkClicked(); 46 delegate->OnSignInLinkClicked();
25 47
26 // A new tab should have been opened. 48 // A new tab should have been opened and the browser should be visible.
27 int tab_count = browser()->tab_strip_model()->count(); 49 int tab_count = browser()->tab_strip_model()->count();
28 EXPECT_EQ(starting_tab_count + 1, tab_count); 50 EXPECT_EQ(starting_tab_count + 1, tab_count);
51 EXPECT_EQ(1,
52 static_cast<BookmarkBubbleSignInDelegateTest::Window*>(
53 browser()->window())->show_count_);
54 }
55
56 TEST_F(BookmarkBubbleSignInDelegateTest, OnSignInLinkClickedIncognito) {
57 // Create an incognito browser.
58 TestingProfile::Builder incognito_profile_builder;
59 incognito_profile_builder.SetIncognito();
60 scoped_ptr<TestingProfile> incognito_profile =
61 incognito_profile_builder.Build();
62 incognito_profile->SetOriginalProfile(profile());
63 profile()->SetOffTheRecordProfile(incognito_profile.Pass());
64
65 scoped_ptr<BrowserWindow> incognito_window;
66 incognito_window.reset(CreateBrowserWindow());
67 Browser::CreateParams params(browser()->profile()->GetOffTheRecordProfile(),
68 browser()->host_desktop_type());
69 params.window = incognito_window.get();
70 scoped_ptr<Browser> incognito_browser;
71 incognito_browser.reset(new Browser(params));
72
73 int starting_tab_count_normal = browser()->tab_strip_model()->count();
74 int starting_tab_count_incognito =
75 incognito_browser.get()->tab_strip_model()->count();
76
77 scoped_ptr<BookmarkBubbleDelegate> delegate;
78 delegate.reset(new BookmarkBubbleSignInDelegate(incognito_browser.get()));
79
80 delegate->OnSignInLinkClicked();
81
82 // A new tab should have been opened in the normal browser, which should be
83 // visible.
84 int tab_count_normal = browser()->tab_strip_model()->count();
85 EXPECT_EQ(starting_tab_count_normal + 1, tab_count_normal);
86 EXPECT_EQ(1,
87 static_cast<BookmarkBubbleSignInDelegateTest::Window*>(
88 browser()->window())->show_count_);
89
90 // No effect is expected on the incognito browser.
91 int tab_count_incognito = incognito_browser->tab_strip_model()->count();
92 EXPECT_EQ(starting_tab_count_incognito, tab_count_incognito);
93 EXPECT_EQ(0,
94 static_cast<BookmarkBubbleSignInDelegateTest::Window*>(
95 incognito_window.get())->show_count_);
29 } 96 }
30 97
31 // Verifies that the sign in page can be loaded in a different browser 98 // Verifies that the sign in page can be loaded in a different browser
32 // if the provided browser is invalidated. 99 // if the provided browser is invalidated.
33 TEST_F(BookmarkBubbleSignInDelegateTest, BrowserRemoved) { 100 TEST_F(BookmarkBubbleSignInDelegateTest, BrowserRemoved) {
34 // Create an extra browser. 101 // Create an extra browser.
35 scoped_ptr<BrowserWindow> extra_window; 102 scoped_ptr<BrowserWindow> extra_window;
36 extra_window.reset(CreateBrowserWindow()); 103 extra_window.reset(CreateBrowserWindow());
37 104
38 Browser::CreateParams params(browser()->profile(), 105 Browser::CreateParams params(browser()->profile(),
39 browser()->host_desktop_type()); 106 browser()->host_desktop_type());
40 params.window = extra_window.get(); 107 params.window = extra_window.get();
41 scoped_ptr<Browser> extra_browser; 108 scoped_ptr<Browser> extra_browser;
42 extra_browser.reset(new Browser(params)); 109 extra_browser.reset(new Browser(params));
43 110
44 int starting_tab_count = extra_browser->tab_strip_model()->count(); 111 int starting_tab_count = extra_browser->tab_strip_model()->count();
45 112
46 scoped_ptr<BookmarkBubbleDelegate> delegate; 113 scoped_ptr<BookmarkBubbleDelegate> delegate;
47 delegate.reset(new BookmarkBubbleSignInDelegate(browser())); 114 delegate.reset(new BookmarkBubbleSignInDelegate(browser()));
48 115
49 BrowserList::SetLastActive(extra_browser.get()); 116 BrowserList::SetLastActive(extra_browser.get());
50 117
51 browser()->tab_strip_model()->CloseAllTabs(); 118 browser()->tab_strip_model()->CloseAllTabs();
52 set_browser(NULL); 119 set_browser(NULL);
53 120
54 delegate->OnSignInLinkClicked(); 121 delegate->OnSignInLinkClicked();
55 122
56 // A new tab should have been opened in the extra browser. 123 // A new tab should have been opened in the extra browser, which should be
124 // visible.
57 int tab_count = extra_browser->tab_strip_model()->count(); 125 int tab_count = extra_browser->tab_strip_model()->count();
58 EXPECT_EQ(starting_tab_count + 1, tab_count); 126 EXPECT_EQ(starting_tab_count + 1, tab_count);
127 EXPECT_EQ(1,
128 static_cast<BookmarkBubbleSignInDelegateTest::Window*>(
129 extra_window.get())->show_count_);
59 130
60 // Required to avoid a crash when the browser is deleted. 131 // Required to avoid a crash when the browser is deleted.
61 extra_browser->tab_strip_model()->CloseAllTabs(); 132 extra_browser->tab_strip_model()->CloseAllTabs();
62 } 133 }
OLDNEW
« no previous file with comments | « chrome/browser/ui/bookmarks/bookmark_bubble_sign_in_delegate.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698