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_list.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 tab'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_ClearInitiatorTabDetails DISABLED_ClearInitiatorTabDetails | 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_ClearInitiatorTabDetails ClearInitiatorTabDetails | 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 tab. | 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, BrowserList::size()); | 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 tab contents. | 43 // Create a reference to initiator tab contents. |
44 WebContents* initiator_tab = | 44 WebContents* initiator_tab = |
45 browser()->tab_strip_model()->GetActiveWebContents(); | 45 browser()->tab_strip_model()->GetActiveWebContents(); |
46 | 46 |
47 PrintPreviewDialogController* dialog_controller = | 47 PrintPreviewDialogController* dialog_controller = |
48 PrintPreviewDialogController::GetInstance(); | 48 PrintPreviewDialogController::GetInstance(); |
(...skipping 18 matching lines...) Expand all Loading... |
67 | 67 |
68 // 1:1 relationship between initiator tab and preview dialog. | 68 // 1:1 relationship between initiator tab and preview dialog. |
69 EXPECT_EQ(new_preview_dialog, preview_dialog); | 69 EXPECT_EQ(new_preview_dialog, preview_dialog); |
70 } | 70 } |
71 | 71 |
72 // Tests multiple print preview dialogs exist in the same browser for | 72 // Tests multiple print preview dialogs exist in the same browser for |
73 // different initiator tabs. If a preview dialog already exists for an | 73 // different initiator tabs. If a preview dialog already exists for an |
74 // initiator tab, that initiator tab gets focused. | 74 // initiator tab, that initiator tab gets focused. |
75 TEST_F(PrintPreviewDialogControllerUnitTest, MAYBE_MultiplePreviewDialogs) { | 75 TEST_F(PrintPreviewDialogControllerUnitTest, MAYBE_MultiplePreviewDialogs) { |
76 // Lets start with one window and two tabs. | 76 // Lets start with one window and two tabs. |
77 EXPECT_EQ(1u, BrowserList::size()); | 77 EXPECT_EQ(1u, chrome::GetTotalBrowserCount()); |
78 TabStripModel* tab_strip_model = browser()->tab_strip_model(); | 78 TabStripModel* tab_strip_model = browser()->tab_strip_model(); |
79 ASSERT_TRUE(tab_strip_model); | 79 ASSERT_TRUE(tab_strip_model); |
80 | 80 |
81 EXPECT_EQ(0, tab_strip_model->count()); | 81 EXPECT_EQ(0, tab_strip_model->count()); |
82 | 82 |
83 // Create some new initiator tabs. | 83 // Create some new initiator tabs. |
84 chrome::NewTab(browser()); | 84 chrome::NewTab(browser()); |
85 WebContents* web_contents_1 = tab_strip_model->GetActiveWebContents(); | 85 WebContents* web_contents_1 = tab_strip_model->GetActiveWebContents(); |
86 ASSERT_TRUE(web_contents_1); | 86 ASSERT_TRUE(web_contents_1); |
87 | 87 |
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
131 // When we get the preview dialog for |web_contents_1|, | 131 // When we get the preview dialog for |web_contents_1|, |
132 // |preview_dialog_1| is activated and focused. | 132 // |preview_dialog_1| is activated and focused. |
133 dialog_controller->GetOrCreatePreviewDialog(web_contents_1); | 133 dialog_controller->GetOrCreatePreviewDialog(web_contents_1); |
134 EXPECT_EQ(tab_1_index, tab_strip_model->active_index()); | 134 EXPECT_EQ(tab_1_index, tab_strip_model->active_index()); |
135 } | 135 } |
136 | 136 |
137 // Check clearing the initiator tab details associated with a print preview | 137 // Check clearing the initiator tab details associated with a print preview |
138 // dialog allows the initiator tab to create another print preview dialog. | 138 // dialog allows the initiator tab to create another print preview dialog. |
139 TEST_F(PrintPreviewDialogControllerUnitTest, MAYBE_ClearInitiatorTabDetails) { | 139 TEST_F(PrintPreviewDialogControllerUnitTest, MAYBE_ClearInitiatorTabDetails) { |
140 // Lets start with one window with one tab. | 140 // Lets start with one window with one tab. |
141 EXPECT_EQ(1u, BrowserList::size()); | 141 EXPECT_EQ(1u, chrome::GetTotalBrowserCount()); |
142 EXPECT_EQ(0, browser()->tab_strip_model()->count()); | 142 EXPECT_EQ(0, browser()->tab_strip_model()->count()); |
143 chrome::NewTab(browser()); | 143 chrome::NewTab(browser()); |
144 EXPECT_EQ(1, browser()->tab_strip_model()->count()); | 144 EXPECT_EQ(1, browser()->tab_strip_model()->count()); |
145 | 145 |
146 // Create a reference to initiator tab contents. | 146 // Create a reference to initiator tab contents. |
147 WebContents* initiator_tab = | 147 WebContents* initiator_tab = |
148 browser()->tab_strip_model()->GetActiveWebContents(); | 148 browser()->tab_strip_model()->GetActiveWebContents(); |
149 | 149 |
150 PrintPreviewDialogController* dialog_controller = | 150 PrintPreviewDialogController* dialog_controller = |
151 PrintPreviewDialogController::GetInstance(); | 151 PrintPreviewDialogController::GetInstance(); |
(...skipping 17 matching lines...) Expand all Loading... |
169 dialog_controller->GetOrCreatePreviewDialog(initiator_tab); | 169 dialog_controller->GetOrCreatePreviewDialog(initiator_tab); |
170 | 170 |
171 // 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 |
172 // still 1. | 172 // still 1. |
173 EXPECT_EQ(1, browser()->tab_strip_model()->count()); | 173 EXPECT_EQ(1, browser()->tab_strip_model()->count()); |
174 // Verify a new print preview dialog has been created. | 174 // Verify a new print preview dialog has been created. |
175 EXPECT_NE(new_preview_dialog, preview_dialog); | 175 EXPECT_NE(new_preview_dialog, preview_dialog); |
176 } | 176 } |
177 | 177 |
178 } // namespace printing | 178 } // namespace printing |
OLD | NEW |