OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/strings/stringprintf.h" | 5 #include "base/strings/stringprintf.h" |
6 #include "base/strings/utf_string_conversions.h" | 6 #include "base/strings/utf_string_conversions.h" |
7 #include "chrome/app/chrome_command_ids.h" | 7 #include "chrome/app/chrome_command_ids.h" |
8 #include "chrome/browser/apps/app_browsertest_util.h" | 8 #include "chrome/browser/apps/app_browsertest_util.h" |
9 #include "chrome/browser/chrome_content_browser_client.h" | 9 #include "chrome/browser/chrome_content_browser_client.h" |
10 #include "chrome/browser/profiles/profile.h" | 10 #include "chrome/browser/profiles/profile.h" |
11 #include "chrome/browser/renderer_context_menu/render_view_context_menu_browsert
est_util.h" | 11 #include "chrome/browser/renderer_context_menu/render_view_context_menu_browsert
est_util.h" |
12 #include "chrome/browser/renderer_context_menu/render_view_context_menu_test_uti
l.h" | 12 #include "chrome/browser/renderer_context_menu/render_view_context_menu_test_uti
l.h" |
13 #include "chrome/test/base/interactive_test_utils.h" | 13 #include "chrome/test/base/interactive_test_utils.h" |
14 #include "chrome/test/base/test_launcher_utils.h" | 14 #include "chrome/test/base/test_launcher_utils.h" |
15 #include "chrome/test/base/ui_test_utils.h" | 15 #include "chrome/test/base/ui_test_utils.h" |
16 #include "content/public/browser/notification_service.h" | 16 #include "content/public/browser/notification_service.h" |
17 #include "content/public/browser/render_process_host.h" | 17 #include "content/public/browser/render_process_host.h" |
18 #include "content/public/browser/render_view_host.h" | 18 #include "content/public/browser/render_view_host.h" |
19 #include "content/public/browser/render_widget_host_iterator.h" | 19 #include "content/public/browser/render_widget_host_iterator.h" |
20 #include "content/public/browser/render_widget_host_view.h" | 20 #include "content/public/browser/render_widget_host_view.h" |
21 #include "content/public/browser/web_contents.h" | 21 #include "content/public/browser/web_contents.h" |
22 #include "content/public/common/content_switches.h" | 22 #include "content/public/common/content_switches.h" |
23 #include "content/public/test/browser_test_utils.h" | 23 #include "content/public/test/browser_test_utils.h" |
24 #include "extensions/browser/app_window/app_window.h" | 24 #include "extensions/browser/app_window/app_window.h" |
25 #include "extensions/browser/app_window/app_window_registry.h" | 25 #include "extensions/browser/app_window/app_window_registry.h" |
| 26 #include "extensions/browser/guest_view/extensions_guest_view_manager_delegate.h
" |
26 #include "extensions/browser/guest_view/guest_view_base.h" | 27 #include "extensions/browser/guest_view/guest_view_base.h" |
27 #include "extensions/browser/guest_view/guest_view_manager.h" | 28 #include "extensions/browser/guest_view/guest_view_manager.h" |
28 #include "extensions/browser/guest_view/guest_view_manager_factory.h" | 29 #include "extensions/browser/guest_view/guest_view_manager_factory.h" |
| 30 #include "extensions/browser/guest_view/test_guest_view_manager.h" |
29 #include "extensions/test/extension_test_message_listener.h" | 31 #include "extensions/test/extension_test_message_listener.h" |
30 #include "net/test/embedded_test_server/embedded_test_server.h" | 32 #include "net/test/embedded_test_server/embedded_test_server.h" |
31 #include "ui/base/ime/composition_text.h" | 33 #include "ui/base/ime/composition_text.h" |
32 #include "ui/base/ime/text_input_client.h" | 34 #include "ui/base/ime/text_input_client.h" |
33 #include "ui/base/test/ui_controls.h" | 35 #include "ui/base/test/ui_controls.h" |
34 #include "ui/events/keycodes/keyboard_codes.h" | 36 #include "ui/events/keycodes/keyboard_codes.h" |
35 | 37 |
36 using extensions::AppWindow; | 38 using extensions::AppWindow; |
37 | 39 using extensions::ExtensionsGuestViewManagerDelegate; |
38 class TestGuestViewManager : public extensions::GuestViewManager { | 40 using extensions::GuestViewManager; |
39 public: | 41 using extensions::TestGuestViewManager; |
40 explicit TestGuestViewManager(content::BrowserContext* context) | |
41 : GuestViewManager(context), | |
42 guest_add_count_(0), | |
43 guest_remove_count_(0), | |
44 web_contents_(NULL) {} | |
45 | |
46 content::WebContents* WaitForGuestAdded() { | |
47 if (web_contents_) | |
48 return web_contents_; | |
49 | |
50 add_message_loop_runner_ = new content::MessageLoopRunner; | |
51 add_message_loop_runner_->Run(); | |
52 return web_contents_; | |
53 } | |
54 | |
55 // Waits so that at least |expected_remove_count| guests' creation | |
56 // has been seen by this manager. | |
57 void WaitForGuestRemoved(size_t expected_remove_count) { | |
58 if (guest_remove_count_ >= expected_remove_count) | |
59 return; | |
60 | |
61 remove_message_loop_runner_ = new content::MessageLoopRunner; | |
62 remove_message_loop_runner_->Run(); | |
63 } | |
64 | |
65 size_t guest_add_count() { return guest_add_count_; } | |
66 | |
67 private: | |
68 // GuestViewManager override: | |
69 void AddGuest(int guest_instance_id, | |
70 content::WebContents* guest_web_contents) override { | |
71 GuestViewManager::AddGuest(guest_instance_id, guest_web_contents); | |
72 web_contents_ = guest_web_contents; | |
73 ++guest_add_count_; | |
74 | |
75 if (add_message_loop_runner_.get()) | |
76 add_message_loop_runner_->Quit(); | |
77 } | |
78 | |
79 void RemoveGuest(int guest_instance_id) override { | |
80 GuestViewManager::RemoveGuest(guest_instance_id); | |
81 ++guest_remove_count_; | |
82 | |
83 if (remove_message_loop_runner_.get()) | |
84 remove_message_loop_runner_->Quit(); | |
85 } | |
86 | |
87 size_t guest_add_count_; | |
88 size_t guest_remove_count_; | |
89 content::WebContents* web_contents_; | |
90 scoped_refptr<content::MessageLoopRunner> add_message_loop_runner_; | |
91 scoped_refptr<content::MessageLoopRunner> remove_message_loop_runner_; | |
92 }; | |
93 | |
94 // Test factory for creating test instances of GuestViewManager. | |
95 class TestGuestViewManagerFactory : public extensions::GuestViewManagerFactory { | |
96 public: | |
97 TestGuestViewManagerFactory() : | |
98 test_guest_view_manager_(NULL) {} | |
99 | |
100 ~TestGuestViewManagerFactory() override {} | |
101 | |
102 extensions::GuestViewManager* CreateGuestViewManager( | |
103 content::BrowserContext* context) override { | |
104 return GetManager(context); | |
105 } | |
106 | |
107 TestGuestViewManager* GetManager(content::BrowserContext* context) { | |
108 if (!test_guest_view_manager_) { | |
109 test_guest_view_manager_ = new TestGuestViewManager(context); | |
110 } | |
111 return test_guest_view_manager_; | |
112 } | |
113 | |
114 private: | |
115 TestGuestViewManager* test_guest_view_manager_; | |
116 | |
117 DISALLOW_COPY_AND_ASSIGN(TestGuestViewManagerFactory); | |
118 }; | |
119 | 42 |
120 class WebViewInteractiveTest | 43 class WebViewInteractiveTest |
121 : public extensions::PlatformAppBrowserTest { | 44 : public extensions::PlatformAppBrowserTest { |
122 public: | 45 public: |
123 WebViewInteractiveTest() | 46 WebViewInteractiveTest() |
124 : guest_web_contents_(NULL), | 47 : guest_web_contents_(NULL), |
125 embedder_web_contents_(NULL), | 48 embedder_web_contents_(NULL), |
126 corner_(gfx::Point()), | 49 corner_(gfx::Point()), |
127 mouse_click_result_(false), | 50 mouse_click_result_(false), |
128 first_click_(true) { | 51 first_click_(true) { |
129 extensions::GuestViewManager::set_factory_for_testing(&factory_); | 52 extensions::GuestViewManager::set_factory_for_testing(&factory_); |
130 } | 53 } |
131 | 54 |
132 TestGuestViewManager* GetGuestViewManager() { | 55 TestGuestViewManager* GetGuestViewManager() { |
133 return factory_.GetManager(browser()->profile()); | 56 TestGuestViewManager* manager = static_cast<TestGuestViewManager*>( |
| 57 TestGuestViewManager::FromBrowserContext(browser()->profile())); |
| 58 // TestGuestViewManager::WaitForSingleGuestCreated may and will get called |
| 59 // before a guest is created. |
| 60 if (!manager) { |
| 61 manager = static_cast<TestGuestViewManager*>( |
| 62 GuestViewManager::CreateWithDelegate( |
| 63 browser()->profile(), |
| 64 scoped_ptr<guestview::GuestViewManagerDelegate>( |
| 65 new ExtensionsGuestViewManagerDelegate( |
| 66 browser()->profile())))); |
| 67 } |
| 68 return manager; |
134 } | 69 } |
135 | 70 |
136 void MoveMouseInsideWindowWithListener(gfx::Point point, | 71 void MoveMouseInsideWindowWithListener(gfx::Point point, |
137 const std::string& message) { | 72 const std::string& message) { |
138 ExtensionTestMessageListener move_listener(message, false); | 73 ExtensionTestMessageListener move_listener(message, false); |
139 ASSERT_TRUE(ui_test_utils::SendMouseMoveSync( | 74 ASSERT_TRUE(ui_test_utils::SendMouseMoveSync( |
140 gfx::Point(corner_.x() + point.x(), corner_.y() + point.y()))); | 75 gfx::Point(corner_.x() + point.x(), corner_.y() + point.y()))); |
141 ASSERT_TRUE(move_listener.WaitUntilSatisfied()); | 76 ASSERT_TRUE(move_listener.WaitUntilSatisfied()); |
142 } | 77 } |
143 | 78 |
(...skipping 133 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
277 const std::string& app_location, | 212 const std::string& app_location, |
278 TestServer test_server) { | 213 TestServer test_server) { |
279 content::WebContents* embedder_web_contents = NULL; | 214 content::WebContents* embedder_web_contents = NULL; |
280 scoped_ptr<ExtensionTestMessageListener> done_listener( | 215 scoped_ptr<ExtensionTestMessageListener> done_listener( |
281 RunAppHelper( | 216 RunAppHelper( |
282 test_name, app_location, test_server, &embedder_web_contents)); | 217 test_name, app_location, test_server, &embedder_web_contents)); |
283 | 218 |
284 ASSERT_TRUE(done_listener); | 219 ASSERT_TRUE(done_listener); |
285 ASSERT_TRUE(done_listener->WaitUntilSatisfied()); | 220 ASSERT_TRUE(done_listener->WaitUntilSatisfied()); |
286 | 221 |
287 guest_web_contents_ = GetGuestViewManager()->WaitForGuestAdded(); | 222 guest_web_contents_ = GetGuestViewManager()->WaitForSingleGuestCreated(); |
288 } | 223 } |
289 | 224 |
290 void RunTest(const std::string& app_name) { | |
291 } | |
292 void SetupTest(const std::string& app_name, | 225 void SetupTest(const std::string& app_name, |
293 const std::string& guest_url_spec) { | 226 const std::string& guest_url_spec) { |
294 ASSERT_TRUE(StartEmbeddedTestServer()); | 227 ASSERT_TRUE(StartEmbeddedTestServer()); |
295 GURL::Replacements replace_host; | 228 GURL::Replacements replace_host; |
296 replace_host.SetHostStr("localhost"); | 229 replace_host.SetHostStr("localhost"); |
297 | 230 |
298 GURL guest_url = embedded_test_server()->GetURL(guest_url_spec); | 231 GURL guest_url = embedded_test_server()->GetURL(guest_url_spec); |
299 guest_url = guest_url.ReplaceComponents(replace_host); | 232 guest_url = guest_url.ReplaceComponents(replace_host); |
300 | 233 |
301 ui_test_utils::UrlLoadObserver guest_observer( | 234 ui_test_utils::UrlLoadObserver guest_observer( |
(...skipping 238 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
540 "FULLSCREEN_STEP_PASSED", false); | 473 "FULLSCREEN_STEP_PASSED", false); |
541 passed_listener.set_failure_message("TEST_FAILED"); | 474 passed_listener.set_failure_message("TEST_FAILED"); |
542 content::SimulateMouseClickAt(guest_web_contents(), | 475 content::SimulateMouseClickAt(guest_web_contents(), |
543 0, | 476 0, |
544 blink::WebMouseEvent::ButtonLeft, | 477 blink::WebMouseEvent::ButtonLeft, |
545 gfx::Point(20, 20)); | 478 gfx::Point(20, 20)); |
546 ASSERT_TRUE(passed_listener.WaitUntilSatisfied()); | 479 ASSERT_TRUE(passed_listener.WaitUntilSatisfied()); |
547 } | 480 } |
548 | 481 |
549 protected: | 482 protected: |
550 TestGuestViewManagerFactory factory_; | 483 extensions::TestGuestViewManagerFactory factory_; |
551 content::WebContents* guest_web_contents_; | 484 content::WebContents* guest_web_contents_; |
552 content::WebContents* embedder_web_contents_; | 485 content::WebContents* embedder_web_contents_; |
553 gfx::Point corner_; | 486 gfx::Point corner_; |
554 bool mouse_click_result_; | 487 bool mouse_click_result_; |
555 bool first_click_; | 488 bool first_click_; |
556 // Only used in drag/drop test. | 489 // Only used in drag/drop test. |
557 base::Closure quit_closure_; | 490 base::Closure quit_closure_; |
558 std::string last_drop_data_; | 491 std::string last_drop_data_; |
559 }; | 492 }; |
560 | 493 |
(...skipping 332 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
893 // Wait for the embedder to receive a 'newwindow' event. | 826 // Wait for the embedder to receive a 'newwindow' event. |
894 ASSERT_TRUE(done_listener->WaitUntilSatisfied()); | 827 ASSERT_TRUE(done_listener->WaitUntilSatisfied()); |
895 } | 828 } |
896 #endif | 829 #endif |
897 | 830 |
898 IN_PROC_BROWSER_TEST_F(WebViewInteractiveTest, | 831 IN_PROC_BROWSER_TEST_F(WebViewInteractiveTest, |
899 NewWindow_OpenerDestroyedWhileUnattached) { | 832 NewWindow_OpenerDestroyedWhileUnattached) { |
900 TestHelper("testNewWindowOpenerDestroyedWhileUnattached", | 833 TestHelper("testNewWindowOpenerDestroyedWhileUnattached", |
901 "web_view/newwindow", | 834 "web_view/newwindow", |
902 NEEDS_TEST_SERVER); | 835 NEEDS_TEST_SERVER); |
903 ASSERT_EQ(2u, GetGuestViewManager()->guest_add_count()); | 836 ASSERT_EQ(2, GetGuestViewManager()->num_guests_created()); |
904 | 837 |
905 // We have two guests in this test, one is the intial one, the other | 838 // We have two guests in this test, one is the intial one, the other |
906 // is the newwindow one. | 839 // is the newwindow one. |
907 // Before the embedder goes away, both the guests should go away. | 840 // Before the embedder goes away, both the guests should go away. |
908 // This ensures that unattached guests are gone if opener is gone. | 841 // This ensures that unattached guests are gone if opener is gone. |
909 GetGuestViewManager()->WaitForGuestRemoved(2u); | 842 GetGuestViewManager()->WaitForAllGuestsDeleted(); |
910 } | 843 } |
911 | 844 |
912 IN_PROC_BROWSER_TEST_F(WebViewInteractiveTest, ExecuteCode) { | 845 IN_PROC_BROWSER_TEST_F(WebViewInteractiveTest, ExecuteCode) { |
913 ASSERT_TRUE(RunPlatformAppTestWithArg( | 846 ASSERT_TRUE(RunPlatformAppTestWithArg( |
914 "platform_apps/web_view/common", "execute_code")) << message_; | 847 "platform_apps/web_view/common", "execute_code")) << message_; |
915 } | 848 } |
916 | 849 |
917 IN_PROC_BROWSER_TEST_F(WebViewInteractiveTest, PopupPositioningBasic) { | 850 IN_PROC_BROWSER_TEST_F(WebViewInteractiveTest, PopupPositioningBasic) { |
918 TestHelper("testBasic", "web_view/popup_positioning", NO_TEST_SERVER); | 851 TestHelper("testBasic", "web_view/popup_positioning", NO_TEST_SERVER); |
919 ASSERT_TRUE(guest_web_contents()); | 852 ASSERT_TRUE(guest_web_contents()); |
(...skipping 291 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1211 | 1144 |
1212 // Now verify that the selection text propagates properly to RWHV. | 1145 // Now verify that the selection text propagates properly to RWHV. |
1213 content::RenderWidgetHostView* guest_rwhv = | 1146 content::RenderWidgetHostView* guest_rwhv = |
1214 guest_web_contents()->GetRenderWidgetHostView(); | 1147 guest_web_contents()->GetRenderWidgetHostView(); |
1215 ASSERT_TRUE(guest_rwhv); | 1148 ASSERT_TRUE(guest_rwhv); |
1216 std::string selected_text = base::UTF16ToUTF8(guest_rwhv->GetSelectedText()); | 1149 std::string selected_text = base::UTF16ToUTF8(guest_rwhv->GetSelectedText()); |
1217 ASSERT_TRUE(selected_text.size() >= 10u); | 1150 ASSERT_TRUE(selected_text.size() >= 10u); |
1218 ASSERT_EQ("AAAAAAAAAA", selected_text.substr(0, 10)); | 1151 ASSERT_EQ("AAAAAAAAAA", selected_text.substr(0, 10)); |
1219 } | 1152 } |
1220 #endif | 1153 #endif |
OLD | NEW |