OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/command_line.h" | 5 #include "base/command_line.h" |
6 #include "chrome/browser/extensions/browser_action_test_util.h" | 6 #include "chrome/browser/extensions/browser_action_test_util.h" |
| 7 #include "chrome/browser/extensions/extension_action_icon_factory.h" |
7 #include "chrome/browser/extensions/extension_apitest.h" | 8 #include "chrome/browser/extensions/extension_apitest.h" |
8 #include "chrome/browser/extensions/extension_prefs.h" | 9 #include "chrome/browser/extensions/extension_prefs.h" |
9 #include "chrome/browser/extensions/extension_service.h" | 10 #include "chrome/browser/extensions/extension_service.h" |
10 #include "chrome/browser/extensions/extension_tab_util.h" | 11 #include "chrome/browser/extensions/extension_tab_util.h" |
11 #include "chrome/browser/profiles/profile.h" | 12 #include "chrome/browser/profiles/profile.h" |
12 #include "chrome/browser/ui/browser.h" | 13 #include "chrome/browser/ui/browser.h" |
13 #include "chrome/browser/ui/browser_tabstrip.h" | 14 #include "chrome/browser/ui/browser_tabstrip.h" |
14 #include "chrome/browser/ui/browser_window.h" | 15 #include "chrome/browser/ui/browser_window.h" |
15 #include "chrome/browser/ui/omnibox/location_bar.h" | 16 #include "chrome/browser/ui/omnibox/location_bar.h" |
16 #include "chrome/browser/ui/tab_contents/tab_contents.h" | 17 #include "chrome/browser/ui/tab_contents/tab_contents.h" |
17 #include "chrome/common/chrome_switches.h" | 18 #include "chrome/common/chrome_switches.h" |
18 #include "chrome/common/extensions/extension.h" | 19 #include "chrome/common/extensions/extension.h" |
19 #include "chrome/common/extensions/extension_action.h" | 20 #include "chrome/common/extensions/extension_action.h" |
20 #include "chrome/test/base/ui_test_utils.h" | 21 #include "chrome/test/base/ui_test_utils.h" |
21 #include "content/public/browser/web_contents.h" | 22 #include "content/public/browser/web_contents.h" |
| 23 #include "testing/gmock/include/gmock/gmock.h" |
22 | 24 |
23 // These are a mash-up of the tests from from page_actions_apitest.cc and | 25 // These are a mash-up of the tests from from page_actions_apitest.cc and |
24 // browser_actions_apitest.cc. | 26 // browser_actions_apitest.cc. |
25 | 27 |
26 using extensions::Extension; | 28 using extensions::Extension; |
| 29 using ::testing::_; |
27 | 30 |
28 namespace { | 31 namespace { |
29 | 32 |
30 class PageAsBrowserActionApiTest : public ExtensionApiTest { | 33 class PageAsBrowserActionApiTest : public ExtensionApiTest { |
31 public: | 34 public: |
32 PageAsBrowserActionApiTest() {} | 35 PageAsBrowserActionApiTest() {} |
33 virtual ~PageAsBrowserActionApiTest() {} | 36 virtual ~PageAsBrowserActionApiTest() {} |
34 | 37 |
35 void SetUpCommandLine(CommandLine* command_line) OVERRIDE { | 38 void SetUpCommandLine(CommandLine* command_line) OVERRIDE { |
36 ExtensionApiTest::SetUpCommandLine(command_line); | 39 ExtensionApiTest::SetUpCommandLine(command_line); |
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
86 } | 89 } |
87 | 90 |
88 { | 91 { |
89 // Tell the extension to update the page action state again. | 92 // Tell the extension to update the page action state again. |
90 ResultCatcher catcher; | 93 ResultCatcher catcher; |
91 ui_test_utils::NavigateToURL(browser(), | 94 ui_test_utils::NavigateToURL(browser(), |
92 GURL(extension->GetResourceURL("update2.html"))); | 95 GURL(extension->GetResourceURL("update2.html"))); |
93 ASSERT_TRUE(catcher.GetNextResult()); | 96 ASSERT_TRUE(catcher.GetNextResult()); |
94 } | 97 } |
95 | 98 |
| 99 // We should not be creating icons asynchronoulsy, so we don't need an |
| 100 // observer. |
| 101 ExtensionActionIconFactory icon_factory(extension, NULL); |
| 102 |
96 // Test that we received the changes. | 103 // Test that we received the changes. |
97 EXPECT_FALSE(action->GetIcon(tab_id).IsEmpty()); | 104 EXPECT_FALSE(icon_factory.GetIcon(action, tab_id).IsEmpty()); |
98 } | 105 } |
99 | 106 |
100 // Test that calling chrome.pageAction.setPopup() can enable a popup. | 107 // Test that calling chrome.pageAction.setPopup() can enable a popup. |
101 IN_PROC_BROWSER_TEST_F(PageAsBrowserActionApiTest, AddPopup) { | 108 IN_PROC_BROWSER_TEST_F(PageAsBrowserActionApiTest, AddPopup) { |
102 // Load the extension, which has no default popup. | 109 // Load the extension, which has no default popup. |
103 ASSERT_TRUE(RunExtensionTest("page_action/add_popup")) << message_; | 110 ASSERT_TRUE(RunExtensionTest("page_action/add_popup")) << message_; |
104 const Extension* extension = GetSingleLoadedExtension(); | 111 const Extension* extension = GetSingleLoadedExtension(); |
105 ASSERT_TRUE(extension) << message_; | 112 ASSERT_TRUE(extension) << message_; |
106 | 113 |
107 int tab_id = ExtensionTabUtil::GetTabId( | 114 int tab_id = ExtensionTabUtil::GetTabId( |
(...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
178 const Extension* extension = GetSingleLoadedExtension(); | 185 const Extension* extension = GetSingleLoadedExtension(); |
179 ASSERT_TRUE(extension) << message_; | 186 ASSERT_TRUE(extension) << message_; |
180 | 187 |
181 ResultCatcher catcher; | 188 ResultCatcher catcher; |
182 ui_test_utils::NavigateToURL(browser(), | 189 ui_test_utils::NavigateToURL(browser(), |
183 GURL(extension->GetResourceURL("update.html"))); | 190 GURL(extension->GetResourceURL("update.html"))); |
184 ASSERT_TRUE(catcher.GetNextResult()); | 191 ASSERT_TRUE(catcher.GetNextResult()); |
185 } | 192 } |
186 | 193 |
187 } | 194 } |
OLD | NEW |