| 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 "ui/views/controls/webview/webview.h" | 5 #include "ui/views/controls/webview/webview.h" |
| 6 | 6 |
| 7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
| 8 #include "base/memory/scoped_ptr.h" | 8 #include "base/memory/scoped_ptr.h" |
| 9 #include "content/public/browser/web_contents.h" | 9 #include "content/public/browser/web_contents.h" |
| 10 #include "content/public/test/mock_render_process_host.h" |
| 10 #include "content/public/test/test_browser_context.h" | 11 #include "content/public/test/test_browser_context.h" |
| 11 #include "content/public/test/test_browser_thread.h" | 12 #include "content/public/test/test_browser_thread.h" |
| 12 #include "content/public/test/test_renderer_host.h" | 13 #include "content/public/test/test_renderer_host.h" |
| 13 #include "content/public/test/web_contents_tester.h" | 14 #include "content/public/test/web_contents_tester.h" |
| 14 #include "ui/base/ime/text_input_focus_manager.h" | 15 #include "ui/base/ime/text_input_focus_manager.h" |
| 15 #include "ui/base/ui_base_switches.h" | 16 #include "ui/base/ui_base_switches.h" |
| 16 #include "ui/gl/gl_surface.h" | 17 #include "ui/gl/gl_surface.h" |
| 17 #include "ui/views/test/test_views_delegate.h" | 18 #include "ui/views/test/test_views_delegate.h" |
| 18 #include "ui/views/test/webview_test_helper.h" | 19 #include "ui/views/test/webview_test_helper.h" |
| 19 #include "ui/views/test/widget_test.h" | 20 #include "ui/views/test/widget_test.h" |
| (...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 82 EXPECT_TRUE(widget->IsActive()); | 83 EXPECT_TRUE(widget->IsActive()); |
| 83 | 84 |
| 84 ui::TextInputFocusManager* text_input_focus_manager = | 85 ui::TextInputFocusManager* text_input_focus_manager = |
| 85 ui::TextInputFocusManager::GetInstance(); | 86 ui::TextInputFocusManager::GetInstance(); |
| 86 EXPECT_EQ(nullptr, webview->GetTextInputClient()); | 87 EXPECT_EQ(nullptr, webview->GetTextInputClient()); |
| 87 EXPECT_EQ(text_input_focus_manager->GetFocusedTextInputClient(), | 88 EXPECT_EQ(text_input_focus_manager->GetFocusedTextInputClient(), |
| 88 webview->GetTextInputClient()); | 89 webview->GetTextInputClient()); |
| 89 | 90 |
| 90 // Case 1: Creates a new WebContents. | 91 // Case 1: Creates a new WebContents. |
| 91 content::WebContents* web_contents1 = webview->GetWebContents(); | 92 content::WebContents* web_contents1 = webview->GetWebContents(); |
| 93 web_contents1->GetRenderViewHost()->GetProcess()->Init(); |
| 92 content::RenderViewHostTester::For(web_contents1->GetRenderViewHost()) | 94 content::RenderViewHostTester::For(web_contents1->GetRenderViewHost()) |
| 93 ->CreateRenderView(base::string16(), MSG_ROUTING_NONE, MSG_ROUTING_NONE, | 95 ->CreateRenderView(base::string16(), MSG_ROUTING_NONE, MSG_ROUTING_NONE, |
| 94 -1, false); | 96 -1, false); |
| 95 webview->RequestFocus(); | 97 webview->RequestFocus(); |
| 96 ui::TextInputClient* client1 = webview->GetTextInputClient(); | 98 ui::TextInputClient* client1 = webview->GetTextInputClient(); |
| 97 EXPECT_NE(nullptr, client1); | 99 EXPECT_NE(nullptr, client1); |
| 98 EXPECT_EQ(text_input_focus_manager->GetFocusedTextInputClient(), client1); | 100 EXPECT_EQ(text_input_focus_manager->GetFocusedTextInputClient(), client1); |
| 99 | 101 |
| 100 // Case 2: Replaces a WebContents by SetWebContents(). | 102 // Case 2: Replaces a WebContents by SetWebContents(). |
| 101 scoped_ptr<content::WebContents> web_contents2( | 103 scoped_ptr<content::WebContents> web_contents2( |
| 102 content::WebContentsTester::CreateTestWebContents(browser_context(), | 104 content::WebContentsTester::CreateTestWebContents(browser_context(), |
| 103 nullptr)); | 105 nullptr)); |
| 106 web_contents2->GetRenderViewHost()->GetProcess()->Init(); |
| 104 content::RenderViewHostTester::For(web_contents2->GetRenderViewHost()) | 107 content::RenderViewHostTester::For(web_contents2->GetRenderViewHost()) |
| 105 ->CreateRenderView(base::string16(), MSG_ROUTING_NONE, MSG_ROUTING_NONE, | 108 ->CreateRenderView(base::string16(), MSG_ROUTING_NONE, MSG_ROUTING_NONE, |
| 106 -1, false); | 109 -1, false); |
| 107 webview->SetWebContents(web_contents2.get()); | 110 webview->SetWebContents(web_contents2.get()); |
| 108 ui::TextInputClient* client2 = webview->GetTextInputClient(); | 111 ui::TextInputClient* client2 = webview->GetTextInputClient(); |
| 109 EXPECT_NE(nullptr, client2); | 112 EXPECT_NE(nullptr, client2); |
| 110 EXPECT_EQ(text_input_focus_manager->GetFocusedTextInputClient(), client2); | 113 EXPECT_EQ(text_input_focus_manager->GetFocusedTextInputClient(), client2); |
| 111 EXPECT_NE(client1, client2); | 114 EXPECT_NE(client1, client2); |
| 112 | 115 |
| 113 widget->Close(); | 116 widget->Close(); |
| 114 RunPendingMessages(); | 117 RunPendingMessages(); |
| 115 } | 118 } |
| 116 | 119 |
| 117 } // namespace | 120 } // namespace |
| OLD | NEW |