Chromium Code Reviews| Index: chrome/browser/chromeos/extensions/virtual_keyboard_browsertest.cc |
| diff --git a/chrome/browser/chromeos/extensions/virtual_keyboard_browsertest.cc b/chrome/browser/chromeos/extensions/virtual_keyboard_browsertest.cc |
| index afe7c0ef5c7d4d82b15c9a95a365578405de8703..7a00cf2ef85fce9beadfdf04d6c328e498896cb3 100644 |
| --- a/chrome/browser/chromeos/extensions/virtual_keyboard_browsertest.cc |
| +++ b/chrome/browser/chromeos/extensions/virtual_keyboard_browsertest.cc |
| @@ -3,6 +3,7 @@ |
| * Use of this source code is governed by a BSD-style license that can be |
| * found in the LICENSE file. |
| */ |
| +#include "chrome/browser/chromeos/extensions/virtual_keyboard_browsertest.h" |
| #include <vector> |
| @@ -17,131 +18,137 @@ |
| #include "content/public/browser/site_instance.h" |
| #include "content/public/browser/web_contents.h" |
| #include "content/public/test/browser_test_utils.h" |
| +#include "extensions/common/extension.h" |
| #include "ui/aura/client/aura_constants.h" |
| #include "ui/base/ime/input_method.h" |
| #include "ui/keyboard/keyboard_controller.h" |
| #include "ui/keyboard/keyboard_switches.h" |
| namespace { |
| +const base::FilePath::CharType kWebuiTestDir[] = FILE_PATH_LITERAL("webui"); |
| -const base::FilePath kWebuiTestDir = |
| - base::FilePath(FILE_PATH_LITERAL("webui")); |
| +const base::FilePath::CharType kMockController[] = |
| + FILE_PATH_LITERAL("mock_controller.js"); |
| -const base::FilePath kVirtualKeyboardTestDir = |
| - base::FilePath(FILE_PATH_LITERAL("chromeos/virtual_keyboard")); |
| +const base::FilePath::CharType kMockTimer[] = |
| + FILE_PATH_LITERAL("mock_timer.js"); |
| -const base::FilePath kMockController = |
| - base::FilePath(FILE_PATH_LITERAL("mock_controller.js")); |
| +const char kVirtualKeyboardTestDir[] = "chromeos/virtual_keyboard"; |
| -const base::FilePath kMockTimer = |
| - base::FilePath(FILE_PATH_LITERAL("mock_timer.js")); |
| +const char kBaseKeyboardTestFramework[] = "virtual_keyboard_test_base.js"; |
| -const base::FilePath kBaseKeyboardTestFramework = |
| - base::FilePath(FILE_PATH_LITERAL("virtual_keyboard_test_base.js")); |
| +const char kExtensionId[] = "mppnpdlheglhdfmldimlhpnegondlapf"; |
| -} // namespace |
| - |
| -class VirtualKeyboardBrowserTest : public InProcessBrowserTest { |
| - public: |
| - |
| - // Ensure that the virtual keyboard is enabled. |
| - virtual void SetUpCommandLine(CommandLine* command_line) OVERRIDE { |
| - command_line->AppendSwitch( |
| - keyboard::switches::kEnableVirtualKeyboard); |
| - } |
| +const char kVirtualKeyboardURL[] = "chrome://keyboard"; |
| - // Injects javascript in |file| into the keyboard page and runs test methods. |
| - void RunTest(const base::FilePath& file) { |
| - ui_test_utils::NavigateToURL(browser(), GURL("chrome://keyboard")); |
| +} // namespace |
| - content::WebContents* web_contents = |
| - browser()->tab_strip_model()->GetActiveWebContents(); |
| - ASSERT_TRUE(web_contents); |
| +VirtualKeyboardBrowserTestConfig::VirtualKeyboardBrowserTestConfig() |
| + : base_framework_(kBaseKeyboardTestFramework), |
| + extension_id_(kExtensionId), |
| + test_dir_(kVirtualKeyboardTestDir), |
| + url_(kVirtualKeyboardURL) { |
| +} |
| - // Inject testing scripts. |
| - InjectJavascript(kWebuiTestDir, kMockController); |
| - InjectJavascript(kWebuiTestDir, kMockTimer); |
| - InjectJavascript(kVirtualKeyboardTestDir, kBaseKeyboardTestFramework); |
| - InjectJavascript(kVirtualKeyboardTestDir, file); |
| +VirtualKeyboardBrowserTestConfig::~VirtualKeyboardBrowserTestConfig() {}; |
| - ASSERT_TRUE(content::ExecuteScript(web_contents, utf8_content_)); |
| +void VirtualKeyboardBrowserTest::SetUpCommandLine(CommandLine* command_line) { |
| + command_line->AppendSwitch(keyboard::switches::kEnableVirtualKeyboard); |
| +} |
| - // Inject DOM-automation test harness and run tests. |
| - std::vector<int> resource_ids; |
| - EXPECT_TRUE(ExecuteWebUIResourceTest(web_contents, resource_ids)); |
| - } |
| +void VirtualKeyboardBrowserTest::RunTest( |
| + const base::FilePath& file, |
| + const VirtualKeyboardBrowserTestConfig& config) { |
| + ui_test_utils::NavigateToURL(browser(), GURL(config.url_)); |
| + content::WebContents* web_contents = |
| + browser()->tab_strip_model()->GetActiveWebContents(); |
| + content::WaitForLoadStop(web_contents); |
| + ASSERT_TRUE(web_contents); |
| + |
| + // Inject testing scripts. |
| + InjectJavascript(base::FilePath(kWebuiTestDir), |
| + base::FilePath(kMockController)); |
| + InjectJavascript(base::FilePath(kWebuiTestDir), base::FilePath(kMockTimer)); |
| + InjectJavascript(base::FilePath(FILE_PATH_LITERAL(config.test_dir_)), |
| + base::FilePath(FILE_PATH_LITERAL(config.base_framework_))); |
| + InjectJavascript(base::FilePath(FILE_PATH_LITERAL(config.test_dir_)), file); |
| + |
| + ASSERT_TRUE(content::ExecuteScript(web_contents, utf8_content_)); |
| + |
| + // Inject DOM-automation test harness and run tests. |
| + std::vector<int> resource_ids; |
| + EXPECT_TRUE(ExecuteWebUIResourceTest(web_contents, resource_ids)); |
| +} |
| - void showVirtualKeyboard() { |
| - aura::Window *window = ash::Shell::GetPrimaryRootWindow(); |
| - ui::InputMethod* input_method = window->GetProperty( |
| - aura::client::kRootWindowInputMethodKey); |
| - ASSERT_TRUE(input_method); |
| - input_method->ShowImeIfNeeded(); |
| - } |
| +void VirtualKeyboardBrowserTest::ShowVirtualKeyboard() { |
| + aura::Window* window = ash::Shell::GetPrimaryRootWindow(); |
| + ui::InputMethod* input_method = |
| + window->GetProperty(aura::client::kRootWindowInputMethodKey); |
| + ASSERT_TRUE(input_method); |
| + input_method->ShowImeIfNeeded(); |
| +} |
| - content::RenderViewHost* GetKeyboardRenderViewHost() { |
| - showVirtualKeyboard(); |
| - std::string kVirtualKeyboardURL = |
| - "chrome-extension://mppnpdlheglhdfmldimlhpnegondlapf/"; |
| - scoped_ptr<content::RenderWidgetHostIterator> widgets( |
| - content::RenderWidgetHost::GetRenderWidgetHosts()); |
| - while (content::RenderWidgetHost* widget = widgets->GetNextHost()) { |
| - if (widget->IsRenderView()) { |
| - content::RenderViewHost* view = content::RenderViewHost::From(widget); |
| - std::string url = view->GetSiteInstance()->GetSiteURL().spec(); |
| - if (url == kVirtualKeyboardURL) { |
| - content::WebContents* wc = |
| - content::WebContents::FromRenderViewHost(view); |
| - // Waits for Polymer to load. |
| - content::WaitForLoadStop(wc); |
| - return view; |
| - } |
| +content::RenderViewHost* VirtualKeyboardBrowserTest::GetKeyboardRenderViewHost( |
| + const std::string& id) { |
| + ShowVirtualKeyboard(); |
| + std::string url = extensions::Extension::GetBaseURLFromExtensionId(id).spec(); |
|
Jeffrey Yasskin
2014/05/08 00:04:16
You can remove both .spec()s if you make this a GU
rsadam
2014/05/08 15:06:44
Done.
|
| + scoped_ptr<content::RenderWidgetHostIterator> widgets( |
| + content::RenderWidgetHost::GetRenderWidgetHosts()); |
| + while (content::RenderWidgetHost* widget = widgets->GetNextHost()) { |
| + if (widget->IsRenderView()) { |
| + content::RenderViewHost* view = content::RenderViewHost::From(widget); |
| + if (url == view->GetSiteInstance()->GetSiteURL().spec()) { |
| + content::WebContents* wc = |
| + content::WebContents::FromRenderViewHost(view); |
| + // Waits for Polymer to load. |
| + content::WaitForLoadStop(wc); |
| + return view; |
| } |
| } |
| - return NULL; |
| - } |
| - |
| - private: |
| - |
| - // Injects javascript into the keyboard page. The test |file| is in |
| - // directory |dir| relative to the root testing directory. |
| - void InjectJavascript(const base::FilePath& dir, |
| - const base::FilePath& file) { |
| - base::FilePath path = ui_test_utils::GetTestFilePath(dir, file); |
| - std::string library_content; |
| - ASSERT_TRUE(base::ReadFileToString(path, &library_content)) |
| - << path.value(); |
| - utf8_content_.append(library_content); |
| - utf8_content_.append(";\n"); |
| } |
| + LOG(ERROR) << "Extension not found:" << url; |
| + return NULL; |
| +} |
| - std::string utf8_content_; |
| -}; |
| +void VirtualKeyboardBrowserTest::InjectJavascript(const base::FilePath& dir, |
| + const base::FilePath& file) { |
| + base::FilePath path = ui_test_utils::GetTestFilePath(dir, file); |
| + std::string library_content; |
| + ASSERT_TRUE(base::ReadFileToString(path, &library_content)) << path.value(); |
| + utf8_content_.append(library_content); |
| + utf8_content_.append(";\n"); |
| +} |
| // crbug.com/367817. Either this feature or just the test are depending |
| // on the presense of Object.observe which is presently disabled by default. |
| IN_PROC_BROWSER_TEST_F(VirtualKeyboardBrowserTest, DISABLED_AttributesTest) { |
| - RunTest(base::FilePath(FILE_PATH_LITERAL("attributes_test.js"))); |
| + RunTest(base::FilePath(FILE_PATH_LITERAL("attributes_test.js")), |
| + VirtualKeyboardBrowserTestConfig()); |
| } |
| IN_PROC_BROWSER_TEST_F(VirtualKeyboardBrowserTest, TypingTest) { |
| - RunTest(base::FilePath(FILE_PATH_LITERAL("typing_test.js"))); |
| + RunTest(base::FilePath(FILE_PATH_LITERAL("typing_test.js")), |
| + VirtualKeyboardBrowserTestConfig()); |
| } |
| IN_PROC_BROWSER_TEST_F(VirtualKeyboardBrowserTest, ControlKeysTest) { |
| - RunTest(base::FilePath(FILE_PATH_LITERAL("control_keys_test.js"))); |
| + RunTest(base::FilePath(FILE_PATH_LITERAL("control_keys_test.js")), |
| + VirtualKeyboardBrowserTestConfig()); |
| } |
| IN_PROC_BROWSER_TEST_F(VirtualKeyboardBrowserTest, HideKeyboardKeyTest) { |
| - RunTest(base::FilePath(FILE_PATH_LITERAL("hide_keyboard_key_test.js"))); |
| + RunTest(base::FilePath(FILE_PATH_LITERAL("hide_keyboard_key_test.js")), |
| + VirtualKeyboardBrowserTestConfig()); |
| } |
| IN_PROC_BROWSER_TEST_F(VirtualKeyboardBrowserTest, KeysetTransitionTest) { |
| - RunTest(base::FilePath(FILE_PATH_LITERAL("keyset_transition_test.js"))); |
| + RunTest(base::FilePath(FILE_PATH_LITERAL("keyset_transition_test.js")), |
| + VirtualKeyboardBrowserTestConfig()); |
| } |
| IN_PROC_BROWSER_TEST_F(VirtualKeyboardBrowserTest, IsKeyboardLoaded) { |
| - content::RenderViewHost* keyboard_rvh = GetKeyboardRenderViewHost(); |
| + content::RenderViewHost* keyboard_rvh = |
| + GetKeyboardRenderViewHost(kExtensionId); |
| ASSERT_TRUE(keyboard_rvh); |
| bool loaded = false; |
| std::string script = "!!chrome.virtualKeyboardPrivate"; |
| @@ -155,7 +162,8 @@ IN_PROC_BROWSER_TEST_F(VirtualKeyboardBrowserTest, IsKeyboardLoaded) { |
| IN_PROC_BROWSER_TEST_F(VirtualKeyboardBrowserTest, DISABLED_EndToEndTest) { |
| // Get the virtual keyboard's render view host. |
| - content::RenderViewHost* keyboard_rvh = GetKeyboardRenderViewHost(); |
| + content::RenderViewHost* keyboard_rvh = |
| + GetKeyboardRenderViewHost(kExtensionId); |
| ASSERT_TRUE(keyboard_rvh); |
| // Get the test page's render view host. |
| @@ -172,7 +180,7 @@ IN_PROC_BROWSER_TEST_F(VirtualKeyboardBrowserTest, DISABLED_EndToEndTest) { |
| // Press 'a' on keyboard. |
| base::FilePath path = ui_test_utils::GetTestFilePath( |
| - kVirtualKeyboardTestDir, |
| + base::FilePath(FILE_PATH_LITERAL(kVirtualKeyboardTestDir)), |
| base::FilePath(FILE_PATH_LITERAL("end_to_end_test.js"))); |
| std::string script; |
| ASSERT_TRUE(base::ReadFileToString(path, &script)); |