Index: chrome/browser/extensions/browser_action_apitest.cc |
diff --git a/chrome/browser/extensions/browser_action_apitest.cc b/chrome/browser/extensions/browser_action_apitest.cc |
index 13b73d8694d04f8914fff8e770e963e0646b1a1b..3e47ad131809322c5c41377087140cb6e4549585 100644 |
--- a/chrome/browser/extensions/browser_action_apitest.cc |
+++ b/chrome/browser/extensions/browser_action_apitest.cc |
@@ -13,7 +13,7 @@ |
#include "chrome/browser/views/browser_actions_container.h" |
#include "chrome/browser/views/extensions/extension_popup.h" |
#include "chrome/browser/views/toolbar_view.h" |
-#include "chrome/common/extensions/extension_action.h" |
+#include "chrome/common/extensions/extension_action2.h" |
#include "chrome/test/ui_test_utils.h" |
IN_PROC_BROWSER_TEST_F(ExtensionApiTest, BrowserAction) { |
@@ -35,20 +35,19 @@ IN_PROC_BROWSER_TEST_F(ExtensionApiTest, BrowserAction) { |
ASSERT_TRUE(catcher.GetNextResult()); |
// Test that we received the changes. |
- ExtensionActionState* action_state = extension->browser_action_state(); |
- ASSERT_EQ("Modified", action_state->title()); |
- ASSERT_EQ("badge", action_state->badge_text()); |
+ ExtensionAction2* action = extension->browser_action(); |
+ ASSERT_EQ("Modified", action->GetTitle(ExtensionAction2::kDefaultTabId)); |
+ ASSERT_EQ("badge", action->GetBadgeText(ExtensionAction2::kDefaultTabId)); |
ASSERT_EQ(SkColorSetARGB(255, 255, 255, 255), |
- action_state->badge_background_color()); |
+ action->GetBadgeBackgroundColor(ExtensionAction2::kDefaultTabId)); |
// Simulate the browser action being clicked. |
ui_test_utils::NavigateToURL(browser(), |
GURL("http://localhost:1337/files/extensions/test_file.txt")); |
- ExtensionAction* browser_action = service->GetBrowserActions(false)[0]; |
int window_id = ExtensionTabUtil::GetWindowId(browser()); |
ExtensionBrowserEventRouter::GetInstance()->BrowserActionExecuted( |
- browser()->profile(), browser_action->extension_id(), browser()); |
+ browser()->profile(), action->extension_id(), browser()); |
// Verify the command worked. |
TabContents* tab = browser()->GetSelectedTabContents(); |
@@ -97,6 +96,50 @@ IN_PROC_BROWSER_TEST_F(ExtensionApiTest, DynamicBrowserAction) { |
// TODO(aa): Would be nice here to actually compare that the pixels change. |
} |
+IN_PROC_BROWSER_TEST_F(ExtensionApiTest, TabSpecificBrowserActionState) { |
+ ASSERT_TRUE(RunExtensionTest("browser_action_tab_specific_state")) |
+ << message_; |
+ |
+ // Test that there is a browser action in the toolbar and that it has no icon. |
+ BrowserActionsContainer* browser_actions = |
+ browser()->window()->GetBrowserWindowTesting()->GetToolbarView()-> |
+ browser_actions(); |
+ ASSERT_EQ(1, browser_actions->num_browser_actions()); |
+ ASSERT_FALSE(browser_actions->GetBrowserActionViewAt(0)->button()->icon() |
+ .empty()); |
+ |
+ // Execute the action, its title should change |
+ std::wstring text; |
+ ResultCatcher catcher; |
+ browser_actions->TestExecuteBrowserAction(0); |
+ ASSERT_TRUE(catcher.GetNextResult()); |
+ ASSERT_TRUE( |
+ browser_actions->GetBrowserActionViewAt(0)->button()->GetTooltipText( |
+ 0, 0, &text)); |
+ ASSERT_EQ(L"Showing icon 2", text); |
+ |
+ // open a new tab, the title should go back |
+ browser()->NewTab(); |
+ ASSERT_TRUE( |
+ browser_actions->GetBrowserActionViewAt(0)->button()->GetTooltipText( |
+ 0, 0, &text)); |
+ ASSERT_EQ(L"hi!", text); |
+ |
+ // go back to first tab, changed title should reappear |
+ browser()->SelectTabContentsAt(0, true); |
+ ASSERT_TRUE( |
+ browser_actions->GetBrowserActionViewAt(0)->button()->GetTooltipText( |
+ 0, 0, &text)); |
+ ASSERT_EQ(L"Showing icon 2", text); |
+ |
+ // reload that tab, default title should come back |
+ ui_test_utils::NavigateToURL(browser(), GURL("about:blank")); |
+ ASSERT_TRUE( |
+ browser_actions->GetBrowserActionViewAt(0)->button()->GetTooltipText( |
+ 0, 0, &text)); |
+ ASSERT_EQ(L"hi!", text); |
+} |
+ |
IN_PROC_BROWSER_TEST_F(ExtensionApiTest, BrowserActionPopup) { |
ASSERT_TRUE(LoadExtension(test_data_dir_.AppendASCII("popup"))); |