OLD | NEW |
---|---|
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 "base/command_line.h" | 5 #include "base/command_line.h" |
6 #include "base/memory/scoped_vector.h" | |
6 #include "chrome/browser/extensions/extension_apitest.h" | 7 #include "chrome/browser/extensions/extension_apitest.h" |
8 #include "chrome/browser/extensions/extension_test_message_listener.h" | |
7 #include "chrome/browser/ui/browser.h" | 9 #include "chrome/browser/ui/browser.h" |
8 #include "chrome/browser/ui/browser_list.h" | 10 #include "chrome/browser/ui/browser_list.h" |
9 #include "chrome/common/chrome_switches.h" | 11 #include "chrome/common/chrome_switches.h" |
12 #include "chrome/common/extensions/extension.h" | |
10 #include "chrome/test/base/ui_test_utils.h" | 13 #include "chrome/test/base/ui_test_utils.h" |
11 #include "net/base/mock_host_resolver.h" | 14 #include "net/base/mock_host_resolver.h" |
12 | 15 |
13 // Disabled, http://crbug.com/64899. | 16 // Disabled, http://crbug.com/64899. |
14 IN_PROC_BROWSER_TEST_F(ExtensionApiTest, DISABLED_WindowOpen) { | 17 IN_PROC_BROWSER_TEST_F(ExtensionApiTest, DISABLED_WindowOpen) { |
15 CommandLine::ForCurrentProcess()->AppendSwitch( | 18 CommandLine::ForCurrentProcess()->AppendSwitch( |
16 switches::kEnableExperimentalExtensionApis); | 19 switches::kEnableExperimentalExtensionApis); |
17 | 20 |
18 ResultCatcher catcher; | 21 ResultCatcher catcher; |
19 ASSERT_TRUE(LoadExtensionIncognito(test_data_dir_ | 22 ASSERT_TRUE(LoadExtensionIncognito(test_data_dir_ |
20 .AppendASCII("window_open").AppendASCII("spanning"))); | 23 .AppendASCII("window_open").AppendASCII("spanning"))); |
21 EXPECT_TRUE(catcher.GetNextResult()) << catcher.message(); | 24 EXPECT_TRUE(catcher.GetNextResult()) << catcher.message(); |
22 } | 25 } |
23 | 26 |
24 void WaitForTabsAndPopups(Browser* browser, int num_tabs, int num_popups) { | 27 void WaitForTabsAndPopups(Browser* browser, |
28 int num_tabs, | |
29 int num_popups, | |
30 int num_panels) { | |
25 // We start with one tab and one browser already open. | 31 // We start with one tab and one browser already open. |
26 ++num_tabs; | 32 ++num_tabs; |
27 size_t num_browsers = static_cast<size_t>(num_popups) + 1; | 33 size_t num_browsers = static_cast<size_t>(num_popups + num_panels) + 1; |
28 | 34 |
29 const base::TimeDelta kWaitTime = base::TimeDelta::FromSeconds(15); | 35 const base::TimeDelta kWaitTime = base::TimeDelta::FromSeconds(15); |
30 base::TimeTicks end_time = base::TimeTicks::Now() + kWaitTime; | 36 base::TimeTicks end_time = base::TimeTicks::Now() + kWaitTime; |
31 while (base::TimeTicks::Now() < end_time) { | 37 while (base::TimeTicks::Now() < end_time) { |
32 if (BrowserList::GetBrowserCount(browser->profile()) >= num_browsers && | 38 if (BrowserList::GetBrowserCount(browser->profile()) == num_browsers && |
dcheng
2011/10/28 19:48:17
Why did this change from >= to ==? It seems safer
prasadt
2011/10/28 20:19:35
I think the situation is the same before too, as y
| |
33 browser->tab_count() >= num_tabs) | 39 browser->tab_count() == num_tabs) |
34 break; | 40 break; |
35 | 41 |
36 MessageLoopForUI::current()->RunAllPending(); | 42 MessageLoopForUI::current()->RunAllPending(); |
37 } | 43 } |
38 | 44 |
39 EXPECT_EQ(num_browsers, BrowserList::GetBrowserCount(browser->profile())); | 45 EXPECT_EQ(num_browsers, BrowserList::GetBrowserCount(browser->profile())); |
40 EXPECT_EQ(num_tabs, browser->tab_count()); | 46 EXPECT_EQ(num_tabs, browser->tab_count()); |
41 | 47 |
48 int num_popups_seen = 0; | |
49 int num_panels_seen = 0; | |
42 for (BrowserList::const_iterator iter = BrowserList::begin(); | 50 for (BrowserList::const_iterator iter = BrowserList::begin(); |
43 iter != BrowserList::end(); ++iter) { | 51 iter != BrowserList::end(); ++iter) { |
44 if (*iter == browser) | 52 if (*iter == browser) |
45 continue; | 53 continue; |
46 | 54 |
47 // Check for TYPE_POPUP or TYPE_PANEL. | 55 // Check for TYPE_POPUP or TYPE_PANEL. |
48 EXPECT_TRUE((*iter)->is_type_popup() || (*iter)->is_type_panel()); | 56 EXPECT_TRUE((*iter)->is_type_popup() || (*iter)->is_type_panel()); |
57 if ((*iter)->is_type_popup()) | |
58 ++num_popups_seen; | |
59 else | |
60 ++num_panels_seen; | |
49 } | 61 } |
62 ASSERT_EQ(num_popups, num_popups_seen); | |
dcheng
2011/10/28 19:48:17
I would use EXPECT_EQ so the rest of the tests can
prasadt
2011/10/28 20:19:35
Done.
This won't actually affect other tests as t
| |
63 ASSERT_EQ(num_panels, num_panels_seen); | |
50 } | 64 } |
51 | 65 |
52 IN_PROC_BROWSER_TEST_F(ExtensionApiTest, BrowserIsApp) { | 66 IN_PROC_BROWSER_TEST_F(ExtensionApiTest, BrowserIsApp) { |
53 host_resolver()->AddRule("a.com", "127.0.0.1"); | 67 host_resolver()->AddRule("a.com", "127.0.0.1"); |
54 ASSERT_TRUE(StartTestServer()); | 68 ASSERT_TRUE(StartTestServer()); |
55 ASSERT_TRUE(LoadExtension( | 69 ASSERT_TRUE(LoadExtension( |
56 test_data_dir_.AppendASCII("window_open").AppendASCII("browser_is_app"))); | 70 test_data_dir_.AppendASCII("window_open").AppendASCII("browser_is_app"))); |
57 | 71 |
58 WaitForTabsAndPopups(browser(), 0, 2); | 72 WaitForTabsAndPopups(browser(), 0, 2, 0); |
59 | 73 |
60 for (BrowserList::const_iterator iter = BrowserList::begin(); | 74 for (BrowserList::const_iterator iter = BrowserList::begin(); |
61 iter != BrowserList::end(); ++iter) { | 75 iter != BrowserList::end(); ++iter) { |
62 if (*iter == browser()) | 76 if (*iter == browser()) |
63 ASSERT_FALSE((*iter)->is_app()); | 77 ASSERT_FALSE((*iter)->is_app()); |
64 else | 78 else |
65 ASSERT_TRUE((*iter)->is_app()); | 79 ASSERT_TRUE((*iter)->is_app()); |
66 } | 80 } |
67 } | 81 } |
68 | 82 |
69 IN_PROC_BROWSER_TEST_F(ExtensionApiTest, WindowOpenPopupDefault) { | 83 IN_PROC_BROWSER_TEST_F(ExtensionApiTest, WindowOpenPopupDefault) { |
70 ASSERT_TRUE(StartTestServer()); | 84 ASSERT_TRUE(StartTestServer()); |
71 ASSERT_TRUE(LoadExtension( | 85 ASSERT_TRUE(LoadExtension( |
72 test_data_dir_.AppendASCII("window_open").AppendASCII("popup"))); | 86 test_data_dir_.AppendASCII("window_open").AppendASCII("popup"))); |
73 | 87 |
74 const int num_tabs = 1; | 88 const int num_tabs = 1; |
75 const int num_popups = 0; | 89 const int num_popups = 0; |
76 WaitForTabsAndPopups(browser(), num_tabs, num_popups); | 90 WaitForTabsAndPopups(browser(), num_tabs, num_popups, 0); |
77 } | 91 } |
78 | 92 |
79 IN_PROC_BROWSER_TEST_F(ExtensionApiTest, WindowOpenPopupLarge) { | 93 IN_PROC_BROWSER_TEST_F(ExtensionApiTest, WindowOpenPopupLarge) { |
80 ASSERT_TRUE(StartTestServer()); | 94 ASSERT_TRUE(StartTestServer()); |
81 ASSERT_TRUE(LoadExtension( | 95 ASSERT_TRUE(LoadExtension( |
82 test_data_dir_.AppendASCII("window_open").AppendASCII("popup_large"))); | 96 test_data_dir_.AppendASCII("window_open").AppendASCII("popup_large"))); |
83 | 97 |
84 #if defined(OS_CHROMEOS) | 98 #if defined(OS_CHROMEOS) |
85 // On ChromeOS this should open a new tab. | 99 // On ChromeOS this should open a new tab. |
86 const int num_tabs = 1; | 100 const int num_tabs = 1; |
87 const int num_popups = 0; | 101 const int num_popups = 0; |
88 #else | 102 #else |
89 // On other systems this should open a new popup window. | 103 // On other systems this should open a new popup window. |
90 const int num_tabs = 0; | 104 const int num_tabs = 0; |
91 const int num_popups = 1; | 105 const int num_popups = 1; |
92 #endif | 106 #endif |
93 WaitForTabsAndPopups(browser(), num_tabs, num_popups); | 107 WaitForTabsAndPopups(browser(), num_tabs, num_popups, 0); |
94 } | 108 } |
95 | 109 |
96 IN_PROC_BROWSER_TEST_F(ExtensionApiTest, WindowOpenPopupSmall) { | 110 IN_PROC_BROWSER_TEST_F(ExtensionApiTest, WindowOpenPopupSmall) { |
97 ASSERT_TRUE(StartTestServer()); | 111 ASSERT_TRUE(StartTestServer()); |
98 ASSERT_TRUE(LoadExtension( | 112 ASSERT_TRUE(LoadExtension( |
99 test_data_dir_.AppendASCII("window_open").AppendASCII("popup_small"))); | 113 test_data_dir_.AppendASCII("window_open").AppendASCII("popup_small"))); |
100 | 114 |
101 // On ChromeOS this should open a new panel (acts like a new popup window). | 115 // On ChromeOS this should open a new panel (acts like a new popup window). |
102 // On other systems this should open a new popup window. | 116 // On other systems this should open a new popup window. |
103 const int num_tabs = 0; | 117 const int num_tabs = 0; |
104 const int num_popups = 1; | 118 const int num_popups = 1; |
105 WaitForTabsAndPopups(browser(), num_tabs, num_popups); | 119 WaitForTabsAndPopups(browser(), num_tabs, num_popups, 0); |
106 } | 120 } |
107 | 121 |
108 IN_PROC_BROWSER_TEST_F(ExtensionApiTest, PopupBlockingExtension) { | 122 IN_PROC_BROWSER_TEST_F(ExtensionApiTest, PopupBlockingExtension) { |
109 host_resolver()->AddRule("*", "127.0.0.1"); | 123 host_resolver()->AddRule("*", "127.0.0.1"); |
110 ASSERT_TRUE(StartTestServer()); | 124 ASSERT_TRUE(StartTestServer()); |
111 | 125 |
112 ASSERT_TRUE(LoadExtension( | 126 ASSERT_TRUE(LoadExtension( |
113 test_data_dir_.AppendASCII("window_open").AppendASCII("popup_blocking") | 127 test_data_dir_.AppendASCII("window_open").AppendASCII("popup_blocking") |
114 .AppendASCII("extension"))); | 128 .AppendASCII("extension"))); |
115 | 129 |
116 WaitForTabsAndPopups(browser(), 5, 3); | 130 WaitForTabsAndPopups(browser(), 5, 3, 0); |
117 } | 131 } |
118 | 132 |
119 IN_PROC_BROWSER_TEST_F(ExtensionApiTest, PopupBlockingHostedApp) { | 133 IN_PROC_BROWSER_TEST_F(ExtensionApiTest, PopupBlockingHostedApp) { |
120 host_resolver()->AddRule("*", "127.0.0.1"); | 134 host_resolver()->AddRule("*", "127.0.0.1"); |
121 ASSERT_TRUE(test_server()->Start()); | 135 ASSERT_TRUE(test_server()->Start()); |
122 | 136 |
123 ASSERT_TRUE(LoadExtension( | 137 ASSERT_TRUE(LoadExtension( |
124 test_data_dir_.AppendASCII("window_open").AppendASCII("popup_blocking") | 138 test_data_dir_.AppendASCII("window_open").AppendASCII("popup_blocking") |
125 .AppendASCII("hosted_app"))); | 139 .AppendASCII("hosted_app"))); |
126 | 140 |
(...skipping 12 matching lines...) Expand all Loading... | |
139 .ReplaceComponents(replace_host); | 153 .ReplaceComponents(replace_host); |
140 GURL open_popup = | 154 GURL open_popup = |
141 test_server()->GetURL(popup_app_contents_path + "open_popup.html") | 155 test_server()->GetURL(popup_app_contents_path + "open_popup.html") |
142 .ReplaceComponents(replace_host); | 156 .ReplaceComponents(replace_host); |
143 | 157 |
144 browser()->OpenURL(open_tab, GURL(), NEW_FOREGROUND_TAB, | 158 browser()->OpenURL(open_tab, GURL(), NEW_FOREGROUND_TAB, |
145 content::PAGE_TRANSITION_TYPED); | 159 content::PAGE_TRANSITION_TYPED); |
146 browser()->OpenURL(open_popup, GURL(), NEW_FOREGROUND_TAB, | 160 browser()->OpenURL(open_popup, GURL(), NEW_FOREGROUND_TAB, |
147 content::PAGE_TRANSITION_TYPED); | 161 content::PAGE_TRANSITION_TYPED); |
148 | 162 |
149 WaitForTabsAndPopups(browser(), 3, 1); | 163 WaitForTabsAndPopups(browser(), 3, 1, 0); |
150 } | 164 } |
151 | 165 |
152 IN_PROC_BROWSER_TEST_F(ExtensionApiTest, WindowArgumentsOverflow) { | 166 IN_PROC_BROWSER_TEST_F(ExtensionApiTest, WindowArgumentsOverflow) { |
153 ASSERT_TRUE(RunExtensionTest("window_open/argument_overflow")) << message_; | 167 ASSERT_TRUE(RunExtensionTest("window_open/argument_overflow")) << message_; |
154 } | 168 } |
155 | 169 |
156 class WindowOpenPanelDisabledTest : public ExtensionApiTest { | 170 class WindowOpenPanelDisabledTest : public ExtensionApiTest { |
157 virtual void SetUpCommandLine(CommandLine* command_line) { | 171 virtual void SetUpCommandLine(CommandLine* command_line) { |
158 ExtensionApiTest::SetUpCommandLine(command_line); | 172 ExtensionApiTest::SetUpCommandLine(command_line); |
159 command_line->AppendSwitch(switches::kDisablePanels); | 173 command_line->AppendSwitch(switches::kDisablePanels); |
160 } | 174 } |
161 }; | 175 }; |
162 | 176 |
163 IN_PROC_BROWSER_TEST_F(WindowOpenPanelDisabledTest, WindowOpenPanelNotEnabled) { | 177 IN_PROC_BROWSER_TEST_F(WindowOpenPanelDisabledTest, WindowOpenPanelNotEnabled) { |
164 ASSERT_TRUE(RunExtensionTest("window_open/panel_not_enabled")) << message_; | 178 ASSERT_TRUE(RunExtensionTest("window_open/panel_not_enabled")) << message_; |
165 } | 179 } |
166 | 180 |
167 IN_PROC_BROWSER_TEST_F(ExtensionApiTest, WindowOpenPanel) { | 181 IN_PROC_BROWSER_TEST_F(ExtensionApiTest, WindowOpenPanel) { |
168 ASSERT_TRUE(RunExtensionTest("window_open/panel")) << message_; | 182 ASSERT_TRUE(RunExtensionTest("window_open/panel")) << message_; |
169 } | 183 } |
170 | 184 |
171 #if defined(OS_MACOSX) || defined(OS_WIN) | 185 #if defined(OS_MACOSX) || defined(OS_WIN) |
172 // Focus test fails if there is no window manager on Linux. | 186 // Focus test fails if there is no window manager on Linux. |
173 IN_PROC_BROWSER_TEST_F(ExtensionApiTest, WindowOpenFocus) { | 187 IN_PROC_BROWSER_TEST_F(ExtensionApiTest, WindowOpenFocus) { |
174 ASSERT_TRUE(RunExtensionTest("window_open/focus")) << message_; | 188 ASSERT_TRUE(RunExtensionTest("window_open/focus")) << message_; |
175 } | 189 } |
176 #endif | 190 #endif |
177 | 191 |
192 IN_PROC_BROWSER_TEST_F(ExtensionApiTest, | |
193 CloseNonExtensionPanelsOnUninstall) { | |
194 host_resolver()->AddRule("a.com", "127.0.0.1"); | |
195 ASSERT_TRUE(StartTestServer()); | |
196 | |
197 // Setup listeners to wait on strings we expect the extension pages to send. | |
198 std::vector<std::string> test_strings; | |
199 test_strings.push_back("content_tab"); | |
200 test_strings.push_back("content_panel"); | |
201 test_strings.push_back("content_popup"); | |
202 | |
203 ScopedVector<ExtensionTestMessageListener> listeners; | |
204 for (size_t i = 0; i < test_strings.size(); ++i) { | |
205 listeners.push_back( | |
206 new ExtensionTestMessageListener(test_strings[i], false)); | |
207 } | |
208 | |
209 const Extension* extension = LoadExtension( | |
210 test_data_dir_.AppendASCII("window_open").AppendASCII( | |
211 "close_panels_on_uninstall")); | |
212 ASSERT_TRUE(extension); | |
213 | |
214 // Two tabs. One in extension domain and one in non-extension domain. | |
215 // Two popups - one in extension domain and one in non-extension domain. | |
216 // Two panels - one in extension domain and one in non-extension domain. | |
217 WaitForTabsAndPopups(browser(), 2, 2, 2); | |
218 | |
219 // Wait on test messages to make sure the pages loaded. | |
220 for (size_t i = 0; i < listeners.size(); ++i) | |
221 ASSERT_TRUE(listeners[i]->WaitUntilSatisfied()); | |
222 | |
223 // Uninstall the extension. | |
dcheng
2011/10/28 19:48:17
Comment not needed.
prasadt
2011/10/28 20:19:35
Done.
| |
224 UninstallExtension(extension->id()); | |
225 | |
226 // Wait for one tab and one popup in non-extension domain to stay open. | |
227 // Expect everything else, including panels, to close. | |
228 WaitForTabsAndPopups(browser(), 1, 1, 0); | |
229 } | |
230 | |
178 IN_PROC_BROWSER_TEST_F(ExtensionApiTest, WindowOpener) { | 231 IN_PROC_BROWSER_TEST_F(ExtensionApiTest, WindowOpener) { |
179 ASSERT_TRUE(RunExtensionTest("window_open/opener")) << message_; | 232 ASSERT_TRUE(RunExtensionTest("window_open/opener")) << message_; |
180 } | 233 } |
OLD | NEW |