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

Side by Side Diff: trunk/src/chrome/browser/printing/print_preview_dialog_controller_unittest.cc

Issue 21372006: Revert 212329 "Reland "Close web contents modal dialogs on conte..." (Closed) Base URL: svn://svn.chromium.org/chrome/
Patch Set: Created 7 years, 4 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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/printing/print_preview_dialog_controller.h" 5 #include "chrome/browser/printing/print_preview_dialog_controller.h"
6 #include "chrome/browser/printing/print_preview_test.h" 6 #include "chrome/browser/printing/print_preview_test.h"
7 #include "chrome/browser/printing/print_view_manager.h" 7 #include "chrome/browser/printing/print_view_manager.h"
8 #include "chrome/browser/ui/browser_commands.h" 8 #include "chrome/browser/ui/browser_commands.h"
9 #include "chrome/browser/ui/browser_finder.h" 9 #include "chrome/browser/ui/browser_finder.h"
10 #include "chrome/browser/ui/tabs/tab_strip_model.h" 10 #include "chrome/browser/ui/tabs/tab_strip_model.h"
11 #include "chrome/browser/ui/webui/print_preview/print_preview_ui.h" 11 #include "chrome/browser/ui/webui/print_preview/print_preview_ui.h"
12 #include "content/public/browser/navigation_details.h" 12 #include "content/public/browser/navigation_details.h"
13 #include "content/public/browser/notification_service.h" 13 #include "content/public/browser/notification_service.h"
14 #include "content/public/browser/notification_types.h" 14 #include "content/public/browser/notification_types.h"
15 #include "content/public/common/url_constants.h" 15 #include "content/public/common/url_constants.h"
16 16
17 using content::WebContents; 17 using content::WebContents;
18 18
19 // Test crashes on Aura due to initiator's native view having no parent. 19 // Test crashes on Aura due to initiator tab's native view having no parent.
20 // http://crbug.com/104284 20 // http://crbug.com/104284
21 #if defined(USE_AURA) 21 #if defined(USE_AURA)
22 #define MAYBE_GetOrCreatePreviewDialog DISABLED_GetOrCreatePreviewDialog 22 #define MAYBE_GetOrCreatePreviewDialog DISABLED_GetOrCreatePreviewDialog
23 #define MAYBE_MultiplePreviewDialogs DISABLED_MultiplePreviewDialogs 23 #define MAYBE_MultiplePreviewDialogs DISABLED_MultiplePreviewDialogs
24 #define MAYBE_ClearInitiatorDetails DISABLED_ClearInitiatorDetails 24 #define MAYBE_ClearInitiatorTabDetails DISABLED_ClearInitiatorTabDetails
25 #else 25 #else
26 #define MAYBE_GetOrCreatePreviewDialog GetOrCreatePreviewDialog 26 #define MAYBE_GetOrCreatePreviewDialog GetOrCreatePreviewDialog
27 #define MAYBE_MultiplePreviewDialogs MultiplePreviewDialogs 27 #define MAYBE_MultiplePreviewDialogs MultiplePreviewDialogs
28 #define MAYBE_ClearInitiatorDetails ClearInitiatorDetails 28 #define MAYBE_ClearInitiatorTabDetails ClearInitiatorTabDetails
29 #endif 29 #endif
30 30
31 namespace printing { 31 namespace printing {
32 32
33 typedef PrintPreviewTest PrintPreviewDialogControllerUnitTest; 33 typedef PrintPreviewTest PrintPreviewDialogControllerUnitTest;
34 34
35 // Create/Get a preview dialog for initiator. 35 // Create/Get a preview dialog for initiator tab.
36 TEST_F(PrintPreviewDialogControllerUnitTest, MAYBE_GetOrCreatePreviewDialog) { 36 TEST_F(PrintPreviewDialogControllerUnitTest, MAYBE_GetOrCreatePreviewDialog) {
37 // Lets start with one window with one tab. 37 // Lets start with one window with one tab.
38 EXPECT_EQ(1u, chrome::GetTotalBrowserCount()); 38 EXPECT_EQ(1u, chrome::GetTotalBrowserCount());
39 EXPECT_EQ(0, browser()->tab_strip_model()->count()); 39 EXPECT_EQ(0, browser()->tab_strip_model()->count());
40 chrome::NewTab(browser()); 40 chrome::NewTab(browser());
41 EXPECT_EQ(1, browser()->tab_strip_model()->count()); 41 EXPECT_EQ(1, browser()->tab_strip_model()->count());
42 42
43 // Create a reference to initiator contents. 43 // Create a reference to initiator tab contents.
44 WebContents* initiator = browser()->tab_strip_model()->GetActiveWebContents(); 44 WebContents* initiator_tab =
45 browser()->tab_strip_model()->GetActiveWebContents();
45 46
46 PrintPreviewDialogController* dialog_controller = 47 PrintPreviewDialogController* dialog_controller =
47 PrintPreviewDialogController::GetInstance(); 48 PrintPreviewDialogController::GetInstance();
48 ASSERT_TRUE(dialog_controller); 49 ASSERT_TRUE(dialog_controller);
49 50
50 // Get the preview dialog for initiator. 51 // Get the preview dialog for initiator tab.
51 PrintViewManager::FromWebContents(initiator)->PrintPreviewNow(false); 52 PrintViewManager::FromWebContents(initiator_tab)->PrintPreviewNow(false);
52 WebContents* preview_dialog = 53 WebContents* preview_dialog =
53 dialog_controller->GetOrCreatePreviewDialog(initiator); 54 dialog_controller->GetOrCreatePreviewDialog(initiator_tab);
54 55
55 // New print preview dialog is a constrained window, so the number of tabs is 56 // New print preview dialog is a constrained window, so the number of tabs is
56 // still 1. 57 // still 1.
57 EXPECT_EQ(1, browser()->tab_strip_model()->count()); 58 EXPECT_EQ(1, browser()->tab_strip_model()->count());
58 EXPECT_NE(initiator, preview_dialog); 59 EXPECT_NE(initiator_tab, preview_dialog);
59 60
60 // Get the print preview dialog for the same initiator. 61 // Get the print preview dialog for the same initiator tab.
61 WebContents* new_preview_dialog = 62 WebContents* new_preview_dialog =
62 dialog_controller->GetOrCreatePreviewDialog(initiator); 63 dialog_controller->GetOrCreatePreviewDialog(initiator_tab);
63 64
64 // Preview dialog already exists. Tab count remains the same. 65 // Preview dialog already exists. Tab count remains the same.
65 EXPECT_EQ(1, browser()->tab_strip_model()->count()); 66 EXPECT_EQ(1, browser()->tab_strip_model()->count());
66 67
67 // 1:1 relationship between initiator and preview dialog. 68 // 1:1 relationship between initiator tab and preview dialog.
68 EXPECT_EQ(new_preview_dialog, preview_dialog); 69 EXPECT_EQ(new_preview_dialog, preview_dialog);
69 } 70 }
70 71
71 // Tests multiple print preview dialogs exist in the same browser for different 72 // Tests multiple print preview dialogs exist in the same browser for
72 // initiators. If a preview dialog already exists for an initiator, that 73 // different initiator tabs. If a preview dialog already exists for an
73 // initiator gets focused. 74 // initiator tab, that initiator tab gets focused.
74 TEST_F(PrintPreviewDialogControllerUnitTest, MAYBE_MultiplePreviewDialogs) { 75 TEST_F(PrintPreviewDialogControllerUnitTest, MAYBE_MultiplePreviewDialogs) {
75 // Lets start with one window and two tabs. 76 // Lets start with one window and two tabs.
76 EXPECT_EQ(1u, chrome::GetTotalBrowserCount()); 77 EXPECT_EQ(1u, chrome::GetTotalBrowserCount());
77 TabStripModel* tab_strip_model = browser()->tab_strip_model(); 78 TabStripModel* tab_strip_model = browser()->tab_strip_model();
78 ASSERT_TRUE(tab_strip_model); 79 ASSERT_TRUE(tab_strip_model);
79 80
80 EXPECT_EQ(0, tab_strip_model->count()); 81 EXPECT_EQ(0, tab_strip_model->count());
81 82
82 // Create some new initiators. 83 // Create some new initiator tabs.
83 chrome::NewTab(browser()); 84 chrome::NewTab(browser());
84 WebContents* web_contents_1 = tab_strip_model->GetActiveWebContents(); 85 WebContents* web_contents_1 = tab_strip_model->GetActiveWebContents();
85 ASSERT_TRUE(web_contents_1); 86 ASSERT_TRUE(web_contents_1);
86 87
87 chrome::NewTab(browser()); 88 chrome::NewTab(browser());
88 WebContents* web_contents_2 = tab_strip_model->GetActiveWebContents(); 89 WebContents* web_contents_2 = tab_strip_model->GetActiveWebContents();
89 ASSERT_TRUE(web_contents_2); 90 ASSERT_TRUE(web_contents_2);
90 EXPECT_EQ(2, tab_strip_model->count()); 91 EXPECT_EQ(2, tab_strip_model->count());
91 92
92 PrintPreviewDialogController* dialog_controller = 93 PrintPreviewDialogController* dialog_controller =
93 PrintPreviewDialogController::GetInstance(); 94 PrintPreviewDialogController::GetInstance();
94 ASSERT_TRUE(dialog_controller); 95 ASSERT_TRUE(dialog_controller);
95 96
96 // Create preview dialog for |web_contents_1| 97 // Create preview dialog for |web_contents_1|
97 PrintViewManager::FromWebContents(web_contents_1)->PrintPreviewNow(false); 98 PrintViewManager::FromWebContents(web_contents_1)->PrintPreviewNow(false);
98 WebContents* preview_dialog_1 = 99 WebContents* preview_dialog_1 =
99 dialog_controller->GetOrCreatePreviewDialog(web_contents_1); 100 dialog_controller->GetOrCreatePreviewDialog(web_contents_1);
100 101
101 EXPECT_NE(web_contents_1, preview_dialog_1); 102 EXPECT_NE(web_contents_1, preview_dialog_1);
102 EXPECT_EQ(2, tab_strip_model->count()); 103 EXPECT_EQ(2, tab_strip_model->count());
103 104
104 // Create preview dialog for |web_contents_2| 105 // Create preview dialog for |web_contents_2|
105 PrintViewManager::FromWebContents(web_contents_2)->PrintPreviewNow(false); 106 PrintViewManager::FromWebContents(web_contents_2)->PrintPreviewNow(false);
106 WebContents* preview_dialog_2 = 107 WebContents* preview_dialog_2 =
107 dialog_controller->GetOrCreatePreviewDialog(web_contents_2); 108 dialog_controller->GetOrCreatePreviewDialog(web_contents_2);
108 109
109 EXPECT_NE(web_contents_2, preview_dialog_2); 110 EXPECT_NE(web_contents_2, preview_dialog_2);
110 EXPECT_NE(preview_dialog_1, preview_dialog_2); 111 EXPECT_NE(preview_dialog_1, preview_dialog_2);
111 // 2 initiators and 2 preview dialogs exist in the same browser. The preview 112 // 2 initiator tabs and 2 preview dialogs exist in the same browser.
112 // dialogs are constrained in their respective initiators. 113 // The preview dialogs are constrained in their respective initiator tabs.
113 EXPECT_EQ(2, tab_strip_model->count()); 114 EXPECT_EQ(2, tab_strip_model->count());
114 115
115 int tab_1_index = tab_strip_model->GetIndexOfWebContents(web_contents_1); 116 int tab_1_index = tab_strip_model->GetIndexOfWebContents(web_contents_1);
116 int tab_2_index = tab_strip_model->GetIndexOfWebContents(web_contents_2); 117 int tab_2_index = tab_strip_model->GetIndexOfWebContents(web_contents_2);
117 int preview_dialog_1_index = 118 int preview_dialog_1_index =
118 tab_strip_model->GetIndexOfWebContents(preview_dialog_1); 119 tab_strip_model->GetIndexOfWebContents(preview_dialog_1);
119 int preview_dialog_2_index = 120 int preview_dialog_2_index =
120 tab_strip_model->GetIndexOfWebContents(preview_dialog_2); 121 tab_strip_model->GetIndexOfWebContents(preview_dialog_2);
121 122
122 // Constrained dialogs are not in the TabStripModel. 123 // Constrained dialogs are not in the TabStripModel.
123 EXPECT_EQ(-1, preview_dialog_1_index); 124 EXPECT_EQ(-1, preview_dialog_1_index);
124 EXPECT_EQ(-1, preview_dialog_2_index); 125 EXPECT_EQ(-1, preview_dialog_2_index);
125 126
126 // Since |preview_dialog_2_index| was the most recently created dialog, its 127 // Since |preview_dialog_2_index| was the most recently created dialog, its
127 // initiator should have focus. 128 // initiator tab should have focus.
128 EXPECT_EQ(tab_2_index, tab_strip_model->active_index()); 129 EXPECT_EQ(tab_2_index, tab_strip_model->active_index());
129 130
130 // When we get the preview dialog for |web_contents_1|, 131 // When we get the preview dialog for |web_contents_1|,
131 // |preview_dialog_1| is activated and focused. 132 // |preview_dialog_1| is activated and focused.
132 dialog_controller->GetOrCreatePreviewDialog(web_contents_1); 133 dialog_controller->GetOrCreatePreviewDialog(web_contents_1);
133 EXPECT_EQ(tab_1_index, tab_strip_model->active_index()); 134 EXPECT_EQ(tab_1_index, tab_strip_model->active_index());
134 } 135 }
135 136
136 // Check clearing the initiator details associated with a print preview dialog 137 // Check clearing the initiator tab details associated with a print preview
137 // allows the initiator to create another print preview dialog. 138 // dialog allows the initiator tab to create another print preview dialog.
138 TEST_F(PrintPreviewDialogControllerUnitTest, MAYBE_ClearInitiatorDetails) { 139 TEST_F(PrintPreviewDialogControllerUnitTest, MAYBE_ClearInitiatorTabDetails) {
139 // Lets start with one window with one tab. 140 // Lets start with one window with one tab.
140 EXPECT_EQ(1u, chrome::GetTotalBrowserCount()); 141 EXPECT_EQ(1u, chrome::GetTotalBrowserCount());
141 EXPECT_EQ(0, browser()->tab_strip_model()->count()); 142 EXPECT_EQ(0, browser()->tab_strip_model()->count());
142 chrome::NewTab(browser()); 143 chrome::NewTab(browser());
143 EXPECT_EQ(1, browser()->tab_strip_model()->count()); 144 EXPECT_EQ(1, browser()->tab_strip_model()->count());
144 145
145 // Create a reference to initiator contents. 146 // Create a reference to initiator tab contents.
146 WebContents* initiator = browser()->tab_strip_model()->GetActiveWebContents(); 147 WebContents* initiator_tab =
148 browser()->tab_strip_model()->GetActiveWebContents();
147 149
148 PrintPreviewDialogController* dialog_controller = 150 PrintPreviewDialogController* dialog_controller =
149 PrintPreviewDialogController::GetInstance(); 151 PrintPreviewDialogController::GetInstance();
150 ASSERT_TRUE(dialog_controller); 152 ASSERT_TRUE(dialog_controller);
151 153
152 // Get the preview dialog for the initiator. 154 // Get the preview dialog for the initiator tab.
153 PrintViewManager::FromWebContents(initiator)->PrintPreviewNow(false); 155 PrintViewManager::FromWebContents(initiator_tab)->PrintPreviewNow(false);
154 WebContents* preview_dialog = 156 WebContents* preview_dialog =
155 dialog_controller->GetOrCreatePreviewDialog(initiator); 157 dialog_controller->GetOrCreatePreviewDialog(initiator_tab);
156 158
157 // New print preview dialog is a constrained window, so the number of tabs is 159 // New print preview dialog is a constrained window, so the number of tabs is
158 // still 1. 160 // still 1.
159 EXPECT_EQ(1, browser()->tab_strip_model()->count()); 161 EXPECT_EQ(1, browser()->tab_strip_model()->count());
160 EXPECT_NE(initiator, preview_dialog); 162 EXPECT_NE(initiator_tab, preview_dialog);
161 163
162 // Clear the initiator details associated with the preview dialog. 164 // Clear the initiator tab details associated with the preview dialog.
163 dialog_controller->EraseInitiatorInfo(preview_dialog); 165 dialog_controller->EraseInitiatorTabInfo(preview_dialog);
164 166
165 // Get a new print preview dialog for the initiator. 167 // Get a new print preview dialog for the initiator tab.
166 WebContents* new_preview_dialog = 168 WebContents* new_preview_dialog =
167 dialog_controller->GetOrCreatePreviewDialog(initiator); 169 dialog_controller->GetOrCreatePreviewDialog(initiator_tab);
168 170
169 // New print preview dialog is a constrained window, so the number of tabs is 171 // New print preview dialog is a constrained window, so the number of tabs is
170 // still 1. 172 // still 1.
171 EXPECT_EQ(1, browser()->tab_strip_model()->count()); 173 EXPECT_EQ(1, browser()->tab_strip_model()->count());
172 // Verify a new print preview dialog has been created. 174 // Verify a new print preview dialog has been created.
173 EXPECT_NE(new_preview_dialog, preview_dialog); 175 EXPECT_NE(new_preview_dialog, preview_dialog);
174 } 176 }
175 177
176 } // namespace printing 178 } // namespace printing
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698