OLD | NEW |
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 |
OLD | NEW |