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