Chromium Code Reviews| 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 "apps/app_window.h" | 5 #include "apps/app_window.h" |
| 6 #include "apps/app_window_registry.h" | 6 #include "apps/app_window_registry.h" |
| 7 #include "base/strings/stringprintf.h" | 7 #include "base/strings/stringprintf.h" |
| 8 #include "base/strings/utf_string_conversions.h" | 8 #include "base/strings/utf_string_conversions.h" |
| 9 #include "chrome/app/chrome_command_ids.h" | 9 #include "chrome/app/chrome_command_ids.h" |
| 10 #include "chrome/browser/apps/app_browsertest_util.h" | 10 #include "chrome/browser/apps/app_browsertest_util.h" |
| 11 #include "chrome/browser/chrome_content_browser_client.h" | 11 #include "chrome/browser/chrome_content_browser_client.h" |
| 12 #include "chrome/browser/extensions/extension_test_message_listener.h" | 12 #include "chrome/browser/extensions/extension_test_message_listener.h" |
| 13 #include "chrome/browser/guest_view/guest_view_base.h" | 13 #include "chrome/browser/guest_view/guest_view_base.h" |
| 14 #include "chrome/browser/guest_view/guest_view_manager.h" | |
| 15 #include "chrome/browser/guest_view/guest_view_manager_factory.h" | |
| 14 #include "chrome/browser/profiles/profile.h" | 16 #include "chrome/browser/profiles/profile.h" |
| 15 #include "chrome/browser/renderer_context_menu/render_view_context_menu_browsert est_util.h" | 17 #include "chrome/browser/renderer_context_menu/render_view_context_menu_browsert est_util.h" |
| 16 #include "chrome/browser/renderer_context_menu/render_view_context_menu_test_uti l.h" | 18 #include "chrome/browser/renderer_context_menu/render_view_context_menu_test_uti l.h" |
| 17 #include "chrome/test/base/interactive_test_utils.h" | 19 #include "chrome/test/base/interactive_test_utils.h" |
| 18 #include "chrome/test/base/test_launcher_utils.h" | 20 #include "chrome/test/base/test_launcher_utils.h" |
| 19 #include "chrome/test/base/ui_test_utils.h" | 21 #include "chrome/test/base/ui_test_utils.h" |
| 20 #include "content/public/browser/notification_service.h" | 22 #include "content/public/browser/notification_service.h" |
| 21 #include "content/public/browser/render_process_host.h" | 23 #include "content/public/browser/render_process_host.h" |
| 22 #include "content/public/browser/render_view_host.h" | 24 #include "content/public/browser/render_view_host.h" |
| 23 #include "content/public/browser/render_widget_host_view.h" | 25 #include "content/public/browser/render_widget_host_view.h" |
| 24 #include "content/public/browser/web_contents.h" | 26 #include "content/public/browser/web_contents.h" |
| 25 #include "content/public/common/content_switches.h" | 27 #include "content/public/common/content_switches.h" |
| 26 #include "content/public/test/browser_test_utils.h" | 28 #include "content/public/test/browser_test_utils.h" |
| 27 #include "net/test/embedded_test_server/embedded_test_server.h" | 29 #include "net/test/embedded_test_server/embedded_test_server.h" |
| 28 #include "ui/base/ime/composition_text.h" | 30 #include "ui/base/ime/composition_text.h" |
| 29 #include "ui/base/ime/text_input_client.h" | 31 #include "ui/base/ime/text_input_client.h" |
| 30 #include "ui/base/test/ui_controls.h" | 32 #include "ui/base/test/ui_controls.h" |
| 31 #include "ui/events/keycodes/keyboard_codes.h" | 33 #include "ui/events/keycodes/keyboard_codes.h" |
| 32 | 34 |
| 33 using apps::AppWindow; | 35 using apps::AppWindow; |
| 34 | 36 |
| 37 class TestGuestViewManager : public GuestViewManager { | |
| 38 public: | |
| 39 explicit TestGuestViewManager(content::BrowserContext* context) : | |
| 40 GuestViewManager(context), | |
| 41 web_contents_(NULL) {} | |
| 42 | |
| 43 content::WebContents* WaitForGuestCreated() { | |
| 44 if (web_contents_) | |
| 45 return web_contents_; | |
| 46 | |
| 47 message_loop_runner_ = new content::MessageLoopRunner; | |
| 48 message_loop_runner_->Run(); | |
| 49 return web_contents_; | |
| 50 } | |
| 51 | |
| 52 private: | |
| 53 // GuestViewManager override: | |
| 54 virtual void AddGuest(int guest_instance_id, | |
| 55 content::WebContents* guest_web_contents) OVERRIDE{ | |
| 56 GuestViewManager::AddGuest(guest_instance_id, guest_web_contents); | |
| 57 web_contents_ = guest_web_contents; | |
| 58 | |
| 59 if (message_loop_runner_) | |
| 60 message_loop_runner_->Quit(); | |
| 61 } | |
| 62 | |
| 63 content::WebContents* web_contents_; | |
| 64 scoped_refptr<content::MessageLoopRunner> message_loop_runner_; | |
| 65 }; | |
| 66 | |
| 67 // Test factory for creating test instances of GuestViewManager. | |
| 68 class TestGuestViewManagerFactory : public GuestViewManagerFactory { | |
| 69 public: | |
| 70 TestGuestViewManagerFactory() : | |
| 71 test_guest_view_manager_(NULL) {} | |
| 72 | |
| 73 virtual ~TestGuestViewManagerFactory() {} | |
| 74 | |
| 75 virtual GuestViewManager* CreateGuestViewManager( | |
| 76 content::BrowserContext* context) OVERRIDE { | |
| 77 return GetManager(context); | |
| 78 } | |
| 79 | |
| 80 TestGuestViewManager* GetManager(content::BrowserContext* context) { | |
| 81 if (!test_guest_view_manager_) { | |
| 82 test_guest_view_manager_ = new TestGuestViewManager(context); | |
| 83 } | |
| 84 return test_guest_view_manager_; | |
| 85 } | |
| 86 | |
| 87 private: | |
| 88 TestGuestViewManager* test_guest_view_manager_; | |
| 89 | |
| 90 DISALLOW_COPY_AND_ASSIGN(TestGuestViewManagerFactory); | |
| 91 }; | |
|
lazyboy
2014/06/13 17:40:01
nit: add \n
Fady Samuel
2014/06/16 14:35:40
Done.
| |
| 35 class WebViewInteractiveTest | 92 class WebViewInteractiveTest |
| 36 : public extensions::PlatformAppBrowserTest { | 93 : public extensions::PlatformAppBrowserTest { |
| 37 public: | 94 public: |
| 38 WebViewInteractiveTest() | 95 WebViewInteractiveTest() |
| 39 : corner_(gfx::Point()), | 96 : corner_(gfx::Point()), |
| 40 mouse_click_result_(false), | 97 mouse_click_result_(false), |
| 41 first_click_(true) {} | 98 first_click_(true) { |
| 99 GuestViewManager::set_factory_for_testing(&factory_); | |
| 100 } | |
| 101 | |
| 102 TestGuestViewManager* GetGuestViewManager() { | |
| 103 return factory_.GetManager(browser()->profile()); | |
| 104 } | |
| 42 | 105 |
| 43 void MoveMouseInsideWindowWithListener(gfx::Point point, | 106 void MoveMouseInsideWindowWithListener(gfx::Point point, |
| 44 const std::string& message) { | 107 const std::string& message) { |
| 45 ExtensionTestMessageListener move_listener(message, false); | 108 ExtensionTestMessageListener move_listener(message, false); |
| 46 ASSERT_TRUE(ui_test_utils::SendMouseMoveSync( | 109 ASSERT_TRUE(ui_test_utils::SendMouseMoveSync( |
| 47 gfx::Point(corner_.x() + point.x(), corner_.y() + point.y()))); | 110 gfx::Point(corner_.x() + point.x(), corner_.y() + point.y()))); |
| 48 ASSERT_TRUE(move_listener.WaitUntilSatisfied()); | 111 ASSERT_TRUE(move_listener.WaitUntilSatisfied()); |
| 49 } | 112 } |
| 50 | 113 |
| 51 void SendMouseClickWithListener(ui_controls::MouseButton button, | 114 void SendMouseClickWithListener(ui_controls::MouseButton button, |
| (...skipping 353 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 405 std::string last_drop_data; | 468 std::string last_drop_data; |
| 406 EXPECT_TRUE(content::ExecuteScriptAndExtractString( | 469 EXPECT_TRUE(content::ExecuteScriptAndExtractString( |
| 407 embedder_web_contents_, | 470 embedder_web_contents_, |
| 408 "window.domAutomationController.send(getLastDropData())", | 471 "window.domAutomationController.send(getLastDropData())", |
| 409 &last_drop_data)); | 472 &last_drop_data)); |
| 410 | 473 |
| 411 last_drop_data_ = last_drop_data; | 474 last_drop_data_ = last_drop_data; |
| 412 } | 475 } |
| 413 | 476 |
| 414 protected: | 477 protected: |
| 478 TestGuestViewManagerFactory factory_; | |
| 415 content::WebContents* guest_web_contents_; | 479 content::WebContents* guest_web_contents_; |
| 416 content::WebContents* embedder_web_contents_; | 480 content::WebContents* embedder_web_contents_; |
| 417 gfx::Point corner_; | 481 gfx::Point corner_; |
| 418 bool mouse_click_result_; | 482 bool mouse_click_result_; |
| 419 bool first_click_; | 483 bool first_click_; |
| 420 // Only used in drag/drop test. | 484 // Only used in drag/drop test. |
| 421 base::Closure quit_closure_; | 485 base::Closure quit_closure_; |
| 422 std::string last_drop_data_; | 486 std::string last_drop_data_; |
| 423 }; | 487 }; |
| 424 | 488 |
| 425 // Used to get notified when a guest is created. | |
| 426 class GuestContentBrowserClient : public chrome::ChromeContentBrowserClient { | |
| 427 public: | |
| 428 GuestContentBrowserClient() : web_contents_(NULL) {} | |
| 429 | |
| 430 content::WebContents* WaitForGuestCreated() { | |
| 431 if (web_contents_) | |
| 432 return web_contents_; | |
| 433 | |
| 434 message_loop_runner_ = new content::MessageLoopRunner; | |
| 435 message_loop_runner_->Run(); | |
| 436 return web_contents_; | |
| 437 } | |
| 438 | |
| 439 private: | |
| 440 // ChromeContentBrowserClient implementation: | |
| 441 virtual void GuestWebContentsAttached( | |
| 442 content::WebContents* guest_web_contents, | |
| 443 content::WebContents* embedder_web_contents, | |
| 444 const base::DictionaryValue& extra_params) OVERRIDE { | |
| 445 ChromeContentBrowserClient::GuestWebContentsAttached( | |
| 446 guest_web_contents, embedder_web_contents, extra_params); | |
| 447 web_contents_ = guest_web_contents; | |
| 448 | |
| 449 if (message_loop_runner_) | |
| 450 message_loop_runner_->Quit(); | |
| 451 } | |
| 452 | |
| 453 content::WebContents* web_contents_; | |
| 454 scoped_refptr<content::MessageLoopRunner> message_loop_runner_; | |
| 455 }; | |
| 456 | |
| 457 // ui_test_utils::SendMouseMoveSync doesn't seem to work on OS_MACOSX, and | 489 // ui_test_utils::SendMouseMoveSync doesn't seem to work on OS_MACOSX, and |
| 458 // likely won't work on many other platforms as well, so for now this test | 490 // likely won't work on many other platforms as well, so for now this test |
| 459 // is for Windows and Linux only. As of Sept 17th, 2013 this test is disabled | 491 // is for Windows and Linux only. As of Sept 17th, 2013 this test is disabled |
| 460 // on Windows due to flakines, see http://crbug.com/293445. | 492 // on Windows due to flakines, see http://crbug.com/293445. |
| 461 | 493 |
| 462 // Disabled on Linux Aura because pointer lock does not work on Linux Aura. | 494 // Disabled on Linux Aura because pointer lock does not work on Linux Aura. |
| 463 // crbug.com/341876 | 495 // crbug.com/341876 |
| 464 | 496 |
| 465 #if defined(OS_LINUX) && !defined(USE_AURA) | 497 #if defined(OS_LINUX) && !defined(USE_AURA) |
| 466 | 498 |
| (...skipping 407 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 874 | 906 |
| 875 // This test exercies the following scenario: | 907 // This test exercies the following scenario: |
| 876 // 1. An <input> in guest has focus. | 908 // 1. An <input> in guest has focus. |
| 877 // 2. User takes focus to embedder by clicking e.g. an <input> in embedder. | 909 // 2. User takes focus to embedder by clicking e.g. an <input> in embedder. |
| 878 // 3. User brings back the focus directly to the <input> in #1. | 910 // 3. User brings back the focus directly to the <input> in #1. |
| 879 // | 911 // |
| 880 // Now we need to make sure TextInputTypeChanged fires properly for the guest's | 912 // Now we need to make sure TextInputTypeChanged fires properly for the guest's |
| 881 // view upon step #3. We simply read the input type's state after #3 to | 913 // view upon step #3. We simply read the input type's state after #3 to |
| 882 // make sure it's not TEXT_INPUT_TYPE_NONE. | 914 // make sure it's not TEXT_INPUT_TYPE_NONE. |
| 883 IN_PROC_BROWSER_TEST_F(WebViewInteractiveTest, Focus_FocusRestored) { | 915 IN_PROC_BROWSER_TEST_F(WebViewInteractiveTest, Focus_FocusRestored) { |
| 884 GuestContentBrowserClient new_client; | |
| 885 content::ContentBrowserClient* old_client = | |
| 886 SetBrowserClientForTesting(&new_client); | |
| 887 | |
| 888 content::WebContents* embedder_web_contents = NULL; | 916 content::WebContents* embedder_web_contents = NULL; |
| 889 scoped_ptr<ExtensionTestMessageListener> done_listener( | 917 scoped_ptr<ExtensionTestMessageListener> done_listener( |
| 890 RunAppHelper("testFocusRestored", "web_view/focus", NO_TEST_SERVER, | 918 RunAppHelper("testFocusRestored", "web_view/focus", NO_TEST_SERVER, |
| 891 &embedder_web_contents)); | 919 &embedder_web_contents)); |
| 892 ASSERT_TRUE(done_listener->WaitUntilSatisfied()); | 920 ASSERT_TRUE(done_listener->WaitUntilSatisfied()); |
| 893 content::WebContents* guest_web_contents = new_client.WaitForGuestCreated(); | 921 content::WebContents* guest_web_contents = |
| 894 // Reset the browser client so that we do not notice any unexpected behavior. | 922 GetGuestViewManager()->WaitForGuestCreated(); |
| 895 SetBrowserClientForTesting(old_client); | |
| 896 ASSERT_TRUE(guest_web_contents); | 923 ASSERT_TRUE(guest_web_contents); |
| 897 | 924 |
| 898 // 1) We click on the guest so that we get a focus event. | 925 // 1) We click on the guest so that we get a focus event. |
| 899 ExtensionTestMessageListener next_step_listener("TEST_STEP_PASSED", false); | 926 ExtensionTestMessageListener next_step_listener("TEST_STEP_PASSED", false); |
| 900 next_step_listener.set_failure_message("TEST_STEP_FAILED"); | 927 next_step_listener.set_failure_message("TEST_STEP_FAILED"); |
| 901 { | 928 { |
| 902 content::SimulateMouseClickAt(guest_web_contents, | 929 content::SimulateMouseClickAt(guest_web_contents, |
| 903 0, | 930 0, |
| 904 blink::WebMouseEvent::ButtonLeft, | 931 blink::WebMouseEvent::ButtonLeft, |
| 905 gfx::Point(10, 10)); | 932 gfx::Point(10, 10)); |
| (...skipping 143 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1049 | 1076 |
| 1050 // Now verify that the selection text propagates properly to RWHV. | 1077 // Now verify that the selection text propagates properly to RWHV. |
| 1051 content::RenderWidgetHostView* guest_rwhv = | 1078 content::RenderWidgetHostView* guest_rwhv = |
| 1052 guest_web_contents()->GetRenderWidgetHostView(); | 1079 guest_web_contents()->GetRenderWidgetHostView(); |
| 1053 ASSERT_TRUE(guest_rwhv); | 1080 ASSERT_TRUE(guest_rwhv); |
| 1054 std::string selected_text = base::UTF16ToUTF8(guest_rwhv->GetSelectedText()); | 1081 std::string selected_text = base::UTF16ToUTF8(guest_rwhv->GetSelectedText()); |
| 1055 ASSERT_TRUE(selected_text.size() >= 10u); | 1082 ASSERT_TRUE(selected_text.size() >= 10u); |
| 1056 ASSERT_EQ("AAAAAAAAAA", selected_text.substr(0, 10)); | 1083 ASSERT_EQ("AAAAAAAAAA", selected_text.substr(0, 10)); |
| 1057 } | 1084 } |
| 1058 #endif | 1085 #endif |
| OLD | NEW |