Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 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 | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include "chrome/browser/extensions/active_script_controller.h" | |
| 6 #include "chrome/browser/extensions/extension_action.h" | |
| 7 #include "chrome/browser/extensions/extension_browsertest.h" | |
| 8 #include "chrome/browser/extensions/extension_test_message_listener.h" | |
| 9 #include "chrome/browser/extensions/location_bar_controller.h" | |
| 10 #include "chrome/browser/extensions/tab_helper.h" | |
| 11 #include "chrome/browser/ui/browser.h" | |
| 12 #include "chrome/browser/ui/tabs/tab_strip_model.h" | |
| 13 #include "chrome/test/base/ui_test_utils.h" | |
| 14 #include "extensions/common/feature_switch.h" | |
| 15 #include "net/test/embedded_test_server/embedded_test_server.h" | |
| 16 #include "testing/gtest/include/gtest/gtest.h" | |
| 17 | |
| 18 namespace extensions { | |
| 19 | |
| 20 class ActiveScriptControllerBrowserTest : public ExtensionBrowserTest { | |
| 21 public: | |
| 22 ActiveScriptControllerBrowserTest() | |
| 23 : feature_override_(FeatureSwitch::scripts_require_action(), | |
| 24 FeatureSwitch::OVERRIDE_ENABLED) {} | |
| 25 private: | |
| 26 FeatureSwitch::ScopedOverride feature_override_; | |
| 27 }; | |
| 28 | |
| 29 IN_PROC_BROWSER_TEST_F(ActiveScriptControllerBrowserTest, | |
| 30 ActiveScriptsAreDisplayed) { | |
| 31 base::FilePath active_script_path = | |
| 32 test_data_dir_.AppendASCII("active_script"); | |
| 33 | |
| 34 // First, we load up three extensions: | |
| 35 // - An extension with a content script that runs on all hosts, | |
| 36 // - An extension that injects scripts into all hosts, | |
| 37 // - An extension with a content script that runs on explicit hosts. | |
| 38 const Extension* content_scripts_all_hosts = LoadExtension( | |
| 39 active_script_path.AppendASCII("content_scripts_all_hosts")); | |
| 40 ASSERT_TRUE(content_scripts_all_hosts); | |
| 41 const Extension* inject_scripts_all_hosts = LoadExtension( | |
| 42 active_script_path.AppendASCII("inject_scripts_all_hosts")); | |
| 43 ASSERT_TRUE(inject_scripts_all_hosts); | |
| 44 const Extension* content_scripts_explicit_hosts = LoadExtension( | |
| 45 active_script_path.AppendASCII("content_scripts_explicit_hosts")); | |
| 46 ASSERT_TRUE(content_scripts_explicit_hosts); | |
| 47 | |
| 48 // All of these extensions should inject a script (either through content | |
| 49 // scripts or through chrome.tabs.executeScript()) that sends a message with | |
| 50 // their names (for verification). | |
| 51 // Be prepared to wait for each extension to inject the script. | |
| 52 ExtensionTestMessageListener content_scripts_all_hosts_listener( | |
| 53 "content_scripts_all_hosts", false /* won't reply */); | |
| 54 ExtensionTestMessageListener inject_scripts_all_hosts_listener( | |
| 55 "inject_scripts_all_hosts", false /* won't reply */); | |
| 56 ExtensionTestMessageListener content_scripts_explicit_hosts_listener( | |
| 57 "content_scripts_explicit_hosts", false /* won't reply */); | |
| 58 | |
| 59 // Navigate to an URL (which matches the explicit host specified in the | |
| 60 // extension content_scripts_explicit_hosts). All three extensions should | |
| 61 // inject the script. | |
| 62 ASSERT_TRUE(embedded_test_server()->InitializeAndWaitUntilReady()); | |
| 63 ui_test_utils::NavigateToURL( | |
| 64 browser(), | |
| 65 embedded_test_server()->GetURL("/extensions/test_file.html")); | |
| 66 | |
| 67 // Wait for them all to complete. | |
| 68 content_scripts_all_hosts_listener.WaitUntilSatisfied(); | |
| 69 content_scripts_explicit_hosts_listener.WaitUntilSatisfied(); | |
| 70 inject_scripts_all_hosts_listener.WaitUntilSatisfied(); | |
| 71 | |
| 72 // Retrieve the ActiveScriptController for that tab. | |
| 73 content::WebContents* web_contents = | |
| 74 browser()->tab_strip_model()->GetActiveWebContents(); | |
| 75 ASSERT_TRUE(web_contents); | |
| 76 TabHelper* tab_helper = TabHelper::FromWebContents(web_contents); | |
| 77 ASSERT_TRUE(tab_helper); | |
| 78 ActiveScriptController* controller = | |
| 79 tab_helper->location_bar_controller()->active_script_controller(); | |
| 80 ASSERT_TRUE(controller); | |
| 81 | |
| 82 // Verify the shown ExtensionActions. Each of the extensions with "all hosts" | |
| 83 // should be displayed, but the extension that specified explicit hosts | |
| 84 // should not. | |
| 85 EXPECT_TRUE(controller->GetActionForExtension(content_scripts_all_hosts)); | |
| 86 EXPECT_TRUE(controller->GetActionForExtension(inject_scripts_all_hosts)); | |
| 87 EXPECT_FALSE( | |
| 88 controller->GetActionForExtension(content_scripts_explicit_hosts)); | |
|
not at google - send to devlin
2014/05/08 20:47:09
A lot of repeated code here. how about defining a
Devlin
2014/05/08 23:01:00
Definitely not as pretty as it was when you wrote
| |
| 89 } | |
| 90 | |
| 91 } // namespace extensions | |
| OLD | NEW |