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_apitest.h" | 7 #include "chrome/browser/extensions/extension_apitest.h" |
8 #include "chrome/browser/extensions/extension_prefs.h" | 8 #include "chrome/browser/extensions/extension_prefs.h" |
9 #include "chrome/browser/extensions/extension_service.h" | 9 #include "chrome/browser/extensions/extension_service.h" |
10 #include "chrome/browser/extensions/extension_tab_util.h" | 10 #include "chrome/browser/extensions/extension_tab_util.h" |
11 #include "chrome/browser/profiles/profile.h" | 11 #include "chrome/browser/profiles/profile.h" |
12 #include "chrome/browser/ui/browser.h" | 12 #include "chrome/browser/ui/browser.h" |
13 #include "chrome/browser/ui/browser_tabstrip.h" | 13 #include "chrome/browser/ui/browser_tabstrip.h" |
14 #include "chrome/browser/ui/browser_window.h" | 14 #include "chrome/browser/ui/browser_window.h" |
15 #include "chrome/browser/ui/omnibox/location_bar.h" | 15 #include "chrome/browser/ui/omnibox/location_bar.h" |
16 #include "chrome/browser/ui/tab_contents/tab_contents.h" | 16 #include "chrome/browser/ui/tab_contents/tab_contents.h" |
17 #include "chrome/common/chrome_switches.h" | 17 #include "chrome/common/chrome_switches.h" |
18 #include "chrome/common/extensions/extension.h" | 18 #include "chrome/common/extensions/extension.h" |
19 #include "chrome/common/extensions/extension_action.h" | 19 #include "chrome/common/extensions/extension_action.h" |
| 20 #include "chrome/common/extensions/extension_icon_factory_delegate.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 |
| 33 class MockActionIconFactory : public ExtensionIconFactoryDelegate { |
| 34 public: |
| 35 virtual ~MockActionIconFactory() {} |
| 36 |
| 37 MOCK_METHOD2(GetIcon, gfx::ImageSkia(const ExtensionIconSet* icon_set, |
| 38 int desired_size)); |
| 39 }; |
| 40 |
30 class PageAsBrowserActionApiTest : public ExtensionApiTest { | 41 class PageAsBrowserActionApiTest : public ExtensionApiTest { |
31 public: | 42 public: |
32 PageAsBrowserActionApiTest() {} | 43 PageAsBrowserActionApiTest() {} |
33 virtual ~PageAsBrowserActionApiTest() {} | 44 virtual ~PageAsBrowserActionApiTest() {} |
34 | 45 |
35 void SetUpCommandLine(CommandLine* command_line) OVERRIDE { | 46 void SetUpCommandLine(CommandLine* command_line) OVERRIDE { |
36 ExtensionApiTest::SetUpCommandLine(command_line); | 47 ExtensionApiTest::SetUpCommandLine(command_line); |
37 command_line->AppendSwitch(switches::kEnableScriptBadges); | 48 command_line->AppendSwitch(switches::kEnableScriptBadges); |
38 } | 49 } |
39 | 50 |
(...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
86 } | 97 } |
87 | 98 |
88 { | 99 { |
89 // Tell the extension to update the page action state again. | 100 // Tell the extension to update the page action state again. |
90 ResultCatcher catcher; | 101 ResultCatcher catcher; |
91 ui_test_utils::NavigateToURL(browser(), | 102 ui_test_utils::NavigateToURL(browser(), |
92 GURL(extension->GetResourceURL("update2.html"))); | 103 GURL(extension->GetResourceURL("update2.html"))); |
93 ASSERT_TRUE(catcher.GetNextResult()); | 104 ASSERT_TRUE(catcher.GetNextResult()); |
94 } | 105 } |
95 | 106 |
| 107 MockActionIconFactory mock_icon_factory; |
| 108 EXPECT_CALL(mock_icon_factory, GetIcon(_, _)).Times(0); |
| 109 |
96 // Test that we received the changes. | 110 // Test that we received the changes. |
97 EXPECT_FALSE(action->GetIcon(tab_id).IsEmpty()); | 111 EXPECT_FALSE(action->GetIcon(tab_id, &mock_icon_factory).IsEmpty()); |
98 } | 112 } |
99 | 113 |
100 // Test that calling chrome.pageAction.setPopup() can enable a popup. | 114 // Test that calling chrome.pageAction.setPopup() can enable a popup. |
101 IN_PROC_BROWSER_TEST_F(PageAsBrowserActionApiTest, AddPopup) { | 115 IN_PROC_BROWSER_TEST_F(PageAsBrowserActionApiTest, AddPopup) { |
102 // Load the extension, which has no default popup. | 116 // Load the extension, which has no default popup. |
103 ASSERT_TRUE(RunExtensionTest("page_action/add_popup")) << message_; | 117 ASSERT_TRUE(RunExtensionTest("page_action/add_popup")) << message_; |
104 const Extension* extension = GetSingleLoadedExtension(); | 118 const Extension* extension = GetSingleLoadedExtension(); |
105 ASSERT_TRUE(extension) << message_; | 119 ASSERT_TRUE(extension) << message_; |
106 | 120 |
107 int tab_id = ExtensionTabUtil::GetTabId( | 121 int tab_id = ExtensionTabUtil::GetTabId( |
(...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
178 const Extension* extension = GetSingleLoadedExtension(); | 192 const Extension* extension = GetSingleLoadedExtension(); |
179 ASSERT_TRUE(extension) << message_; | 193 ASSERT_TRUE(extension) << message_; |
180 | 194 |
181 ResultCatcher catcher; | 195 ResultCatcher catcher; |
182 ui_test_utils::NavigateToURL(browser(), | 196 ui_test_utils::NavigateToURL(browser(), |
183 GURL(extension->GetResourceURL("update.html"))); | 197 GURL(extension->GetResourceURL("update.html"))); |
184 ASSERT_TRUE(catcher.GetNextResult()); | 198 ASSERT_TRUE(catcher.GetNextResult()); |
185 } | 199 } |
186 | 200 |
187 } | 201 } |
OLD | NEW |