Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(28)

Side by Side Diff: chrome/browser/ui/extensions/extension_message_bubble_bridge_unittest.cc

Issue 2206693002: Improve settings override bubble to indicate policy installed extensions (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebase master Created 4 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2016 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 "base/command_line.h"
6 #include "base/logging.h"
7 #include "base/path_service.h"
8 #include "base/values.h"
9 #include "chrome/browser/extensions/extension_service.h"
10 #include "chrome/browser/extensions/extension_service_test_with_install.h"
11 #include "chrome/browser/extensions/extension_web_ui_override_registrar.h"
12 #include "chrome/browser/extensions/ntp_overridden_bubble_delegate.h"
13 #include "chrome/browser/ui/browser.h"
14 #include "chrome/browser/ui/extensions/extension_message_bubble_bridge.h"
15 #include "chrome/browser/ui/toolbar/test_toolbar_actions_bar_bubble_delegate.h"
16 #include "chrome/browser/ui/toolbar/toolbar_actions_bar_bubble_delegate.h"
17 #include "chrome/browser/ui/toolbar/toolbar_actions_model.h"
18 #include "chrome/browser/ui/toolbar/toolbar_actions_model_factory.h"
19 #include "chrome/common/chrome_paths.h"
20 #include "chrome/grit/generated_resources.h"
21 #include "chrome/test/base/test_browser_window.h"
22 #include "chrome/test/base/testing_profile.h"
23 #include "components/grit/components_scaled_resources.h"
24 #include "components/keyed_service/core/keyed_service.h"
25 #include "components/strings/grit/components_strings.h"
26 #include "content/public/browser/browser_context.h"
27 #include "extensions/browser/extension_registry.h"
28 #include "extensions/browser/extension_system.h"
29 #include "extensions/common/extension_builder.h"
30 #include "extensions/common/manifest.h"
31 #include "extensions/common/value_builder.h"
32 #include "testing/gtest/include/gtest/gtest.h"
33 #include "ui/base/l10n/l10n_util.h"
34 #include "ui/gfx/vector_icons_public.h"
35
36 namespace {
37
38 std::unique_ptr<KeyedService> BuildOverrideRegistrar(
39 content::BrowserContext* context) {
40 return base::MakeUnique<extensions::ExtensionWebUIOverrideRegistrar>(context);
41 }
42
43 std::unique_ptr<KeyedService> BuildToolbarModel(
44 content::BrowserContext* context) {
45 return base::MakeUnique<ToolbarActionsModel>(
46 Profile::FromBrowserContext(context),
47 extensions::ExtensionPrefs::Get(context));
48 }
49
50 } // namespace
51
52 namespace extensions {
Devlin 2016/10/20 17:04:07 nit: Tests should be in the same namespace as the
catmullings 2016/10/21 03:49:29 Done.
53
54 class ExtensionMessageBubbleBridgeUnitTest
55 : public ExtensionServiceTestWithInstall {
56 public:
57 ExtensionMessageBubbleBridgeUnitTest() {}
58 ~ExtensionMessageBubbleBridgeUnitTest() override {}
59 Browser* browser() { return browser_.get(); }
60
61 private:
62 void SetUp() override {
63 ExtensionServiceTestWithInstall::SetUp();
64 InitializeEmptyExtensionService();
65
66 browser_window_.reset(new TestBrowserWindow());
67 Browser::CreateParams params(profile());
68 params.type = Browser::TYPE_TABBED;
69 params.window = browser_window_.get();
70 browser_.reset(new Browser(params));
71
72 ExtensionWebUIOverrideRegistrar::GetFactoryInstance()->SetTestingFactory(
73 browser()->profile(), &BuildOverrideRegistrar);
74 ExtensionWebUIOverrideRegistrar::GetFactoryInstance()->Get(
75 browser()->profile());
76 ToolbarActionsModelFactory::GetInstance()->SetTestingFactory(
77 browser()->profile(), &BuildToolbarModel);
78 }
79
80 void TearDown() override {
81 browser_.reset();
82 browser_window_.reset();
83 ExtensionServiceTestWithInstall::TearDown();
84 }
85
86 std::unique_ptr<TestBrowserWindow> browser_window_;
87 std::unique_ptr<Browser> browser_;
88
89 DISALLOW_COPY_AND_ASSIGN(ExtensionMessageBubbleBridgeUnitTest);
90 };
91
92 TEST_F(ExtensionMessageBubbleBridgeUnitTest,
93 TestGetExtraViewInfoMethodWithNormalSettingsOverrideExtension) {
94 base::FilePath fp(data_dir().AppendASCII("api_test/override/newtab/"));
Devlin 2016/10/20 17:04:07 nit: prefer a short name over an acronym for varia
catmullings 2016/10/21 03:49:29 Done.
95 EXPECT_NE(nullptr, PackAndInstallCRX(fp, INSTALL_NEW));
96
97 std::unique_ptr<ExtensionMessageBubbleController> ntp_bubble_controller(
98 new ExtensionMessageBubbleController(
99 new NtpOverriddenBubbleDelegate(browser()->profile()), browser()));
100
101 ASSERT_EQ(1U, ntp_bubble_controller->GetExtensionList().size());
102
103 std::unique_ptr<ToolbarActionsBarBubbleDelegate> bridge(
104 new ExtensionMessageBubbleBridge(std::move(ntp_bubble_controller)));
105
106 std::unique_ptr<ToolbarActionsBarBubbleDelegate::ExtraViewInfo>
107 extra_view_info = bridge->GetExtraViewInfo();
108
109 EXPECT_EQ(gfx::VectorIconId::VECTOR_ICON_NONE, extra_view_info->resource_id);
110 EXPECT_EQ(l10n_util::GetStringUTF16(IDS_LEARN_MORE), extra_view_info->text);
111 EXPECT_EQ(true, extra_view_info->is_text_linked);
112
113 EXPECT_EQ(
114 l10n_util::GetStringUTF16(IDS_EXTENSION_CONTROLLED_RESTORE_SETTINGS),
115 bridge->GetActionButtonText());
116 }
117
118 TEST_F(ExtensionMessageBubbleBridgeUnitTest,
119 TestGetExtraViewInfoMethodWithPolicyInstalledSettingsOverrideExtension) {
120 base::FilePath fp(data_dir().AppendASCII("api_test/override/newtab/"));
121 EXPECT_NE(nullptr,
122 PackAndInstallCRX(fp, Manifest::EXTERNAL_POLICY, INSTALL_NEW));
123
124 std::unique_ptr<ExtensionMessageBubbleController> ntp_bubble_controller(
125 new ExtensionMessageBubbleController(
126 new NtpOverriddenBubbleDelegate(browser()->profile()), browser()));
127
128 ASSERT_EQ(1U, ntp_bubble_controller->GetExtensionList().size());
129
130 std::unique_ptr<ToolbarActionsBarBubbleDelegate> bridge(
131 new ExtensionMessageBubbleBridge(std::move(ntp_bubble_controller)));
132
133 std::unique_ptr<ToolbarActionsBarBubbleDelegate::ExtraViewInfo>
134 extra_view_info = bridge->GetExtraViewInfo();
135
136 extra_view_info = bridge->GetExtraViewInfo();
137
138 EXPECT_EQ(gfx::VectorIconId::BUSINESS, extra_view_info->resource_id);
139 EXPECT_EQ(l10n_util::GetStringUTF16(IDS_EXTENSIONS_INSTALLED_BY_ADMIN),
140 extra_view_info->text);
141 EXPECT_EQ(false, extra_view_info->is_text_linked);
142
143 EXPECT_EQ(base::string16(), bridge->GetActionButtonText());
144 }
145 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698