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

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: Mac implementation with test 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
35 namespace {
36
37 std::unique_ptr<KeyedService> BuildOverrideRegistrar(
38 content::BrowserContext* context) {
39 return base::MakeUnique<extensions::ExtensionWebUIOverrideRegistrar>(context);
40 }
41
42 std::unique_ptr<KeyedService> BuildToolbarModel(
43 content::BrowserContext* context) {
44 return base::MakeUnique<ToolbarActionsModel>(
45 Profile::FromBrowserContext(context),
46 extensions::ExtensionPrefs::Get(context));
47 }
48
49 } // namespace
50
51 namespace extensions {
52
53 class ExtensionMessageBubbleBridgeUnitTest
54 : public ExtensionServiceTestWithInstall {
55 public:
56 ExtensionMessageBubbleBridgeUnitTest() {}
57 ~ExtensionMessageBubbleBridgeUnitTest() override {}
58 Browser* browser() { return browser_.get(); }
59
60 private:
61 void SetUp() override {
62 ExtensionServiceTestWithInstall::SetUp();
63 InitializeEmptyExtensionService();
64
65 browser_window_.reset(new TestBrowserWindow());
66 Browser::CreateParams params(profile());
67 params.type = Browser::TYPE_TABBED;
68 params.window = browser_window_.get();
69 browser_.reset(new Browser(params));
70
71 ExtensionWebUIOverrideRegistrar::GetFactoryInstance()->SetTestingFactory(
72 browser()->profile(), &BuildOverrideRegistrar);
73 ExtensionWebUIOverrideRegistrar::GetFactoryInstance()->Get(
74 browser()->profile());
75 ToolbarActionsModelFactory::GetInstance()->SetTestingFactory(
76 browser()->profile(), &BuildToolbarModel);
77 }
78
79 void TearDown() override {
80 browser_.reset();
81 browser_window_.reset();
82 ExtensionServiceTestWithInstall::TearDown();
83 }
84
85 std::unique_ptr<TestBrowserWindow> browser_window_;
86 std::unique_ptr<Browser> browser_;
87
88 DISALLOW_COPY_AND_ASSIGN(ExtensionMessageBubbleBridgeUnitTest);
89 };
90
91 TEST_F(ExtensionMessageBubbleBridgeUnitTest,
92 TestGetExtraViewInfoMethodWithNormalSettingsOverrideExtension) {
93 base::FilePath fp(data_dir().AppendASCII("api_test/override/newtab/"));
94 EXPECT_NE(nullptr, PackAndInstallCRX(fp, INSTALL_NEW));
95
96 std::unique_ptr<ExtensionMessageBubbleController> ntp_bubble_controller(
97 new ExtensionMessageBubbleController(
98 new NtpOverriddenBubbleDelegate(browser()->profile()), browser()));
99
100 ASSERT_EQ(1U, ntp_bubble_controller->GetExtensionList().size());
101
102 std::unique_ptr<ToolbarActionsBarBubbleDelegate> bridge(
103 new ExtensionMessageBubbleBridge(std::move(ntp_bubble_controller)));
104
105 std::unique_ptr<ToolbarActionsBarBubbleDelegate::ExtraViewInfo>
106 extra_view_info = bridge->GetExtraViewInfo();
107
108 EXPECT_EQ(-1, extra_view_info->resource_id);
109 EXPECT_EQ(l10n_util::GetStringUTF16(IDS_LEARN_MORE), extra_view_info->text);
110 EXPECT_EQ(true, extra_view_info->is_text_linked);
111
112 EXPECT_EQ(
113 l10n_util::GetStringUTF16(IDS_EXTENSION_CONTROLLED_RESTORE_SETTINGS),
114 bridge->GetActionButtonText());
115 }
116
117 TEST_F(ExtensionMessageBubbleBridgeUnitTest,
118 TestGetExtraViewInfoMethodWithPolicyInstalledSettingsOverrideExtension) {
119 base::FilePath fp(data_dir().AppendASCII("api_test/override/newtab/"));
120 EXPECT_NE(nullptr,
121 PackAndInstallCRX(fp, Manifest::EXTERNAL_POLICY, INSTALL_NEW));
122
123 std::unique_ptr<ExtensionMessageBubbleController> ntp_bubble_controller(
124 new ExtensionMessageBubbleController(
125 new NtpOverriddenBubbleDelegate(browser()->profile()), browser()));
126
127 ASSERT_EQ(1U, ntp_bubble_controller->GetExtensionList().size());
128
129 std::unique_ptr<ToolbarActionsBarBubbleDelegate> bridge(
130 new ExtensionMessageBubbleBridge(std::move(ntp_bubble_controller)));
131
132 std::unique_ptr<ToolbarActionsBarBubbleDelegate::ExtraViewInfo>
133 extra_view_info = bridge->GetExtraViewInfo();
134
135 extra_view_info = bridge->GetExtraViewInfo();
136
137 EXPECT_EQ(IDR_OMNIBOX_HTTPS_POLICY_WARNING, extra_view_info->resource_id);
138 EXPECT_EQ(l10n_util::GetStringUTF16(IDS_EXTENSIONS_INSTALLED_BY_ADMIN),
139 extra_view_info->text);
140 EXPECT_EQ(false, extra_view_info->is_text_linked);
141
142 EXPECT_EQ(base::string16(), bridge->GetActionButtonText());
143 }
144 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698