OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "extensions/browser/guest_view/web_view/web_view_apitest.h" | 5 #include "extensions/browser/guest_view/web_view/web_view_apitest.h" |
6 | 6 |
7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
8 #include "base/path_service.h" | 8 #include "base/path_service.h" |
9 #include "base/strings/string_util.h" | 9 #include "base/strings/string_util.h" |
10 #include "base/strings/stringprintf.h" | 10 #include "base/strings/stringprintf.h" |
11 #include "content/public/browser/render_process_host.h" | 11 #include "content/public/browser/render_process_host.h" |
12 #include "content/public/common/content_switches.h" | 12 #include "content/public/common/content_switches.h" |
13 #include "content/public/test/browser_test_utils.h" | 13 #include "content/public/test/browser_test_utils.h" |
14 #include "content/public/test/test_renderer_host.h" | 14 #include "content/public/test/test_renderer_host.h" |
15 #include "content/public/test/test_utils.h" | 15 #include "content/public/test/test_utils.h" |
16 #include "extensions/browser/api/test/test_api.h" | 16 #include "extensions/browser/api/test/test_api.h" |
17 #include "extensions/browser/app_window/app_window.h" | 17 #include "extensions/browser/app_window/app_window.h" |
18 #include "extensions/browser/app_window/app_window_registry.h" | 18 #include "extensions/browser/app_window/app_window_registry.h" |
19 #include "extensions/browser/extension_host.h" | 19 #include "extensions/browser/extension_host.h" |
20 #include "extensions/browser/guest_view/extensions_guest_view_manager_delegate.h " | |
20 #include "extensions/browser/guest_view/guest_view_manager.h" | 21 #include "extensions/browser/guest_view/guest_view_manager.h" |
21 #include "extensions/browser/guest_view/guest_view_manager_factory.h" | 22 #include "extensions/browser/guest_view/guest_view_manager_factory.h" |
22 #include "extensions/browser/guest_view/test_guest_view_manager.h" | 23 #include "extensions/browser/guest_view/test_guest_view_manager.h" |
23 #include "extensions/browser/process_manager.h" | 24 #include "extensions/browser/process_manager.h" |
24 #include "extensions/common/extension.h" | 25 #include "extensions/common/extension.h" |
25 #include "extensions/common/extension_paths.h" | 26 #include "extensions/common/extension_paths.h" |
26 #include "extensions/shell/browser/shell_content_browser_client.h" | 27 #include "extensions/shell/browser/shell_content_browser_client.h" |
27 #include "extensions/shell/browser/shell_extension_system.h" | 28 #include "extensions/shell/browser/shell_extension_system.h" |
28 #include "extensions/shell/test/shell_test.h" | 29 #include "extensions/shell/test/shell_test.h" |
29 #include "extensions/test/extension_test_message_listener.h" | 30 #include "extensions/test/extension_test_message_listener.h" |
(...skipping 200 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
230 base::StringPrintf("onAppCommand('%s');", message.c_str()))); | 231 base::StringPrintf("onAppCommand('%s');", message.c_str()))); |
231 } | 232 } |
232 | 233 |
233 content::WebContents* WebViewAPITest::GetEmbedderWebContents() { | 234 content::WebContents* WebViewAPITest::GetEmbedderWebContents() { |
234 if (!embedder_web_contents_) | 235 if (!embedder_web_contents_) |
235 embedder_web_contents_ = GetFirstAppWindowWebContents(); | 236 embedder_web_contents_ = GetFirstAppWindowWebContents(); |
236 return embedder_web_contents_; | 237 return embedder_web_contents_; |
237 } | 238 } |
238 | 239 |
239 TestGuestViewManager* WebViewAPITest::GetGuestViewManager() { | 240 TestGuestViewManager* WebViewAPITest::GetGuestViewManager() { |
240 return static_cast<TestGuestViewManager*>( | 241 content::BrowserContext* context = |
241 TestGuestViewManager::FromBrowserContext( | 242 ShellContentBrowserClient::Get()->GetBrowserContext(); |
242 ShellContentBrowserClient::Get()->GetBrowserContext())); | 243 TestGuestViewManager* manager = static_cast<TestGuestViewManager*>( |
244 TestGuestViewManager::FromBrowserContext(context)); | |
245 // TestGuestViewManager::WaitForSingleGuestCreated may and will get called | |
246 // before a guest is created. | |
247 if (!manager) { | |
248 manager = static_cast<TestGuestViewManager*>( | |
249 GuestViewManager::CreateWithDelegate( | |
250 context, | |
251 scoped_ptr<guestview::GuestViewManagerDelegate>( | |
252 new ExtensionsGuestViewManagerDelegate(context)))); | |
253 } | |
254 return manager; | |
243 } | 255 } |
244 | 256 |
245 void WebViewAPITest::SendMessageToGuestAndWait( | 257 void WebViewAPITest::SendMessageToGuestAndWait( |
246 const std::string& message, | 258 const std::string& message, |
247 const std::string& wait_message) { | 259 const std::string& wait_message) { |
248 scoped_ptr<ExtensionTestMessageListener> listener; | 260 scoped_ptr<ExtensionTestMessageListener> listener; |
249 if (!wait_message.empty()) | 261 if (!wait_message.empty()) |
250 listener.reset(new ExtensionTestMessageListener(wait_message, false)); | 262 listener.reset(new ExtensionTestMessageListener(wait_message, false)); |
251 | 263 |
252 EXPECT_TRUE( | 264 EXPECT_TRUE( |
(...skipping 104 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
357 #if defined(OS_WIN) | 369 #if defined(OS_WIN) |
358 #define MAYBE_CloseOnLoadcommit DISABLED_CloseOnLoadcommit | 370 #define MAYBE_CloseOnLoadcommit DISABLED_CloseOnLoadcommit |
359 #else | 371 #else |
360 #define MAYBE_CloseOnLoadcommit CloseOnLoadcommit | 372 #define MAYBE_CloseOnLoadcommit CloseOnLoadcommit |
361 #endif | 373 #endif |
362 IN_PROC_BROWSER_TEST_F(WebViewAPITest, MAYBE_CloseOnLoadcommit) { | 374 IN_PROC_BROWSER_TEST_F(WebViewAPITest, MAYBE_CloseOnLoadcommit) { |
363 LaunchApp("web_view/close_on_loadcommit"); | 375 LaunchApp("web_view/close_on_loadcommit"); |
364 ExtensionTestMessageListener test_done_listener("done-close-on-loadcommit", | 376 ExtensionTestMessageListener test_done_listener("done-close-on-loadcommit", |
365 false); | 377 false); |
366 ASSERT_TRUE(test_done_listener.WaitUntilSatisfied()); | 378 ASSERT_TRUE(test_done_listener.WaitUntilSatisfied()); |
379 fprintf(stderr, ">>%s\n", __PRETTY_FUNCTION__); | |
Fady Samuel
2015/04/23 03:44:52
Note to self: Delete this.
Fady Samuel
2015/04/24 00:11:31
Done.
| |
367 } | 380 } |
368 | 381 |
369 // This test verifies that reloading the embedder reloads the guest (and doest | 382 // This test verifies that reloading the embedder reloads the guest (and doest |
370 // not crash). | 383 // not crash). |
371 IN_PROC_BROWSER_TEST_F(WebViewAPITest, ReloadEmbedder) { | 384 IN_PROC_BROWSER_TEST_F(WebViewAPITest, ReloadEmbedder) { |
372 // Just load a guest from other test, we do not want to add a separate | 385 // Just load a guest from other test, we do not want to add a separate |
373 // app for this test. | 386 // app for this test. |
374 LaunchApp("web_view/visibility_changed"); | 387 LaunchApp("web_view/visibility_changed"); |
375 | 388 |
376 ExtensionTestMessageListener launched_again_listener("LAUNCHED", false); | 389 ExtensionTestMessageListener launched_again_listener("LAUNCHED", false); |
(...skipping 330 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
707 RunTest("testWebRequestAPIGoogleProperty", "web_view/apitest"); | 720 RunTest("testWebRequestAPIGoogleProperty", "web_view/apitest"); |
708 } | 721 } |
709 | 722 |
710 // This test verifies that webview.contentWindow works inside an iframe | 723 // This test verifies that webview.contentWindow works inside an iframe |
711 IN_PROC_BROWSER_TEST_F(WebViewAPITest, TestWebViewInsideFrame) { | 724 IN_PROC_BROWSER_TEST_F(WebViewAPITest, TestWebViewInsideFrame) { |
712 LaunchApp("web_view/inside_iframe"); | 725 LaunchApp("web_view/inside_iframe"); |
713 } | 726 } |
714 | 727 |
715 | 728 |
716 } // namespace extensions | 729 } // namespace extensions |
OLD | NEW |