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

Side by Side Diff: chrome/browser/ui/views/toolbar/toolbar_actions_bar_bubble_views_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
1 // Copyright 2016 The Chromium Authors. All rights reserved. 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 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 "chrome/browser/ui/views/toolbar/toolbar_actions_bar_bubble_views.h" 5 #include "chrome/browser/ui/views/toolbar/toolbar_actions_bar_bubble_views.h"
6 6
7 #include <memory> 7 #include <memory>
8 8
9 #include "base/run_loop.h" 9 #include "base/run_loop.h"
10 #include "base/strings/utf_string_conversions.h" 10 #include "base/strings/utf_string_conversions.h"
11 #include "chrome/browser/ui/toolbar/test_toolbar_actions_bar_bubble_delegate.h" 11 #include "chrome/browser/ui/toolbar/test_toolbar_actions_bar_bubble_delegate.h"
12 #include "chrome/browser/ui/toolbar/toolbar_actions_bar_bubble_delegate.h"
13 #include "chrome/grit/generated_resources.h"
14 #include "components/grit/components_scaled_resources.h"
15 #include "ui/base/l10n/l10n_util.h"
16 #include "ui/base/resource/resource_bundle.h"
12 #include "ui/events/event_utils.h" 17 #include "ui/events/event_utils.h"
13 #include "ui/events/test/event_generator.h" 18 #include "ui/events/test/event_generator.h"
19 #include "ui/gfx/color_palette.h"
20 #include "ui/gfx/image/image.h"
21 #include "ui/gfx/image/image_unittest_util.h"
22 #include "ui/gfx/paint_vector_icon.h"
23 #include "ui/gfx/vector_icons_public.h"
14 #include "ui/views/controls/button/label_button.h" 24 #include "ui/views/controls/button/label_button.h"
15 #include "ui/views/controls/link.h" 25 #include "ui/views/controls/link.h"
16 #include "ui/views/test/test_widget_observer.h" 26 #include "ui/views/test/test_widget_observer.h"
17 #include "ui/views/test/views_test_base.h" 27 #include "ui/views/test/views_test_base.h"
18 #include "ui/views/widget/widget.h" 28 #include "ui/views/widget/widget.h"
19 #include "ui/views/window/dialog_client_view.h" 29 #include "ui/views/window/dialog_client_view.h"
20 30
21 class ToolbarActionsBarBubbleViewsTest : public views::ViewsTestBase { 31 class ToolbarActionsBarBubbleViewsTest : public views::ViewsTestBase {
32 public:
33 views::View* TestCreateExtraView() {
34 DCHECK(bubble_);
35 return bubble_->CreateExtraView();
36 }
37
22 protected: 38 protected:
23 ToolbarActionsBarBubbleViewsTest() {} 39 ToolbarActionsBarBubbleViewsTest() {}
24 ~ToolbarActionsBarBubbleViewsTest() override {} 40 ~ToolbarActionsBarBubbleViewsTest() override {}
25 41
26 void TearDown() override { 42 void TearDown() override {
27 anchor_widget_.reset(); 43 anchor_widget_.reset();
28 views::ViewsTestBase::TearDown(); 44 views::ViewsTestBase::TearDown();
29 } 45 }
30 46
31 std::unique_ptr<views::Widget> CreateAnchorWidget() { 47 std::unique_ptr<views::Widget> CreateAnchorWidget() {
(...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after
92 ShowBubble(&delegate); 108 ShowBubble(&delegate);
93 109
94 EXPECT_TRUE(bubble()->GetDialogClientView()->ok_button()); 110 EXPECT_TRUE(bubble()->GetDialogClientView()->ok_button());
95 EXPECT_EQ(ActionString(), 111 EXPECT_EQ(ActionString(),
96 bubble()->GetDialogClientView()->ok_button()->GetText()); 112 bubble()->GetDialogClientView()->ok_button()->GetText());
97 EXPECT_FALSE(bubble()->GetDialogClientView()->cancel_button()); 113 EXPECT_FALSE(bubble()->GetDialogClientView()->cancel_button());
98 114
99 CloseBubble(); 115 CloseBubble();
100 } 116 }
101 117
118 TEST_F(ToolbarActionsBarBubbleViewsTest, TestBubbleLayoutNoButtons) {
119 TestToolbarActionsBarBubbleDelegate delegate(HeadingString(), BodyString(),
120 ActionString());
121 ToolbarActionsBarBubbleDelegate::ExtraViewInfo extra_view_info;
122 delegate.set_extra_view_info(extra_view_info);
123 delegate.set_dismiss_button_text(base::string16());
124 delegate.set_action_button_text(base::string16());
125 ShowBubble(&delegate);
126
127 std::unique_ptr<views::View> extra_view(TestCreateExtraView());
128 EXPECT_FALSE(bubble()->GetDialogClientView()->ok_button());
129 EXPECT_FALSE(bubble()->GetDialogClientView()->cancel_button());
130 EXPECT_FALSE(bubble()->learn_more_button());
131
132 CloseBubble();
133 }
134
102 TEST_F(ToolbarActionsBarBubbleViewsTest, 135 TEST_F(ToolbarActionsBarBubbleViewsTest,
103 TestBubbleLayoutActionAndDismissButton) { 136 TestBubbleLayoutActionAndDismissButton) {
104 TestToolbarActionsBarBubbleDelegate delegate(HeadingString(), BodyString(), 137 TestToolbarActionsBarBubbleDelegate delegate(HeadingString(), BodyString(),
105 ActionString()); 138 ActionString());
106 delegate.set_dismiss_button_text(DismissString()); 139 delegate.set_dismiss_button_text(DismissString());
107
108 ShowBubble(&delegate); 140 ShowBubble(&delegate);
109 141
110 EXPECT_TRUE(bubble()->GetDialogClientView()->ok_button()); 142 EXPECT_TRUE(bubble()->GetDialogClientView()->ok_button());
111 EXPECT_EQ(ActionString(), 143 EXPECT_EQ(ActionString(),
112 bubble()->GetDialogClientView()->ok_button()->GetText()); 144 bubble()->GetDialogClientView()->ok_button()->GetText());
113 EXPECT_TRUE(bubble()->GetDialogClientView()->cancel_button()); 145 EXPECT_TRUE(bubble()->GetDialogClientView()->cancel_button());
114 EXPECT_EQ(DismissString(), 146 EXPECT_EQ(DismissString(),
115 bubble()->GetDialogClientView()->cancel_button()->GetText()); 147 bubble()->GetDialogClientView()->cancel_button()->GetText());
116 148
117 EXPECT_FALSE(bubble()->learn_more_button()); 149 EXPECT_FALSE(bubble()->learn_more_button());
118 EXPECT_FALSE(bubble()->item_list()); 150 EXPECT_FALSE(bubble()->item_list());
119 151
120 CloseBubble(); 152 CloseBubble();
121 } 153 }
122 154
123 TEST_F(ToolbarActionsBarBubbleViewsTest, 155 TEST_F(ToolbarActionsBarBubbleViewsTest,
124 TestBubbleLayoutActionDismissAndLearnMoreButton) { 156 TestBubbleLayoutActionDismissAndLearnMoreButton) {
125 TestToolbarActionsBarBubbleDelegate delegate(HeadingString(), BodyString(), 157 TestToolbarActionsBarBubbleDelegate delegate(HeadingString(), BodyString(),
126 ActionString()); 158 ActionString());
127 delegate.set_dismiss_button_text(DismissString()); 159 delegate.set_dismiss_button_text(DismissString());
128 delegate.set_learn_more_button_text(LearnMoreString()); 160
161 ToolbarActionsBarBubbleDelegate::ExtraViewInfo extra_view_info_linked_text;
162
163 extra_view_info_linked_text.text = LearnMoreString();
164 extra_view_info_linked_text.is_text_linked = true;
165 delegate.set_extra_view_info(extra_view_info_linked_text);
166
129 ShowBubble(&delegate); 167 ShowBubble(&delegate);
130 168
131 EXPECT_TRUE(bubble()->GetDialogClientView()->ok_button()); 169 EXPECT_TRUE(bubble()->GetDialogClientView()->ok_button());
132 EXPECT_EQ(ActionString(), 170 EXPECT_EQ(ActionString(),
133 bubble()->GetDialogClientView()->ok_button()->GetText()); 171 bubble()->GetDialogClientView()->ok_button()->GetText());
134 EXPECT_TRUE(bubble()->GetDialogClientView()->cancel_button()); 172 EXPECT_TRUE(bubble()->GetDialogClientView()->cancel_button());
135 EXPECT_EQ(DismissString(), 173 EXPECT_EQ(DismissString(),
136 bubble()->GetDialogClientView()->cancel_button()->GetText()); 174 bubble()->GetDialogClientView()->cancel_button()->GetText());
137 EXPECT_TRUE(bubble()->learn_more_button()); 175 EXPECT_TRUE(bubble()->learn_more_button());
138 EXPECT_EQ(LearnMoreString(), bubble()->learn_more_button()->text()); 176 EXPECT_EQ(LearnMoreString(), bubble()->learn_more_button()->text());
(...skipping 114 matching lines...) Expand 10 before | Expand all | Expand 10 after
253 ShowBubble(&delegate); 291 ShowBubble(&delegate);
254 views::test::TestWidgetObserver bubble_observer(bubble_widget()); 292 views::test::TestWidgetObserver bubble_observer(bubble_widget());
255 293
256 EXPECT_FALSE(delegate.close_action()); 294 EXPECT_FALSE(delegate.close_action());
257 // Activate another widget. The bubble shouldn't close. 295 // Activate another widget. The bubble shouldn't close.
258 anchor_widget()->Activate(); 296 anchor_widget()->Activate();
259 base::RunLoop().RunUntilIdle(); 297 base::RunLoop().RunUntilIdle();
260 EXPECT_FALSE(delegate.close_action()); 298 EXPECT_FALSE(delegate.close_action());
261 CloseBubble(); 299 CloseBubble();
262 } 300 }
301
302 TEST_F(ToolbarActionsBarBubbleViewsTest, TestCreateExtraViewIconOnly) {
303 TestToolbarActionsBarBubbleDelegate delegate(HeadingString(), BodyString(),
304 ActionString());
305 ToolbarActionsBarBubbleDelegate::ExtraViewInfo extra_view_info;
306
307 extra_view_info.resource_id = gfx::VectorIconId::BUSINESS;
308 delegate.set_extra_view_info(extra_view_info);
309 ShowBubble(&delegate);
310 std::unique_ptr<views::View> extra_view(TestCreateExtraView());
311 EXPECT_TRUE(extra_view);
312 EXPECT_EQ("ImageView", std::string(extra_view->GetClassName()));
Devlin 2016/10/20 17:04:07 the static cast below will fail if this isn't true
catmullings 2016/10/21 03:49:29 Done.
313 EXPECT_TRUE(gfx::test::AreImagesEqual(
314 gfx::Image(static_cast<views::ImageView*>(extra_view.get())->GetImage()),
315 gfx::Image(gfx::CreateVectorIcon(gfx::VectorIconId::BUSINESS, 16,
316 gfx::kChromeIconGrey))));
317 CloseBubble();
318 }
319
320 TEST_F(ToolbarActionsBarBubbleViewsTest, TestCreateExtraViewLinkedTextOnly) {
321 TestToolbarActionsBarBubbleDelegate delegate(HeadingString(), BodyString(),
322 ActionString());
323 ToolbarActionsBarBubbleDelegate::ExtraViewInfo extra_view_info_linked_text;
324
325 extra_view_info_linked_text.text =
326 l10n_util::GetStringUTF16(IDS_EXTENSIONS_INSTALLED_BY_ADMIN);
327 extra_view_info_linked_text.is_text_linked = true;
328 delegate.set_extra_view_info(extra_view_info_linked_text);
329
330 ShowBubble(&delegate);
331
332 std::unique_ptr<views::View> extra_view(TestCreateExtraView());
333 EXPECT_TRUE(extra_view);
334 EXPECT_EQ("Link", std::string(extra_view->GetClassName()));
Devlin 2016/10/20 17:04:07 Here and below as well, prefer FooView::GetClassNa
catmullings 2016/10/21 03:49:29 Done.
335 EXPECT_EQ(l10n_util::GetStringUTF16(IDS_EXTENSIONS_INSTALLED_BY_ADMIN),
336 static_cast<views::Label*>(extra_view.get())->text());
337 CloseBubble();
338 }
339
340 TEST_F(ToolbarActionsBarBubbleViewsTest, TestCreateExtraViewLabelTextOnly) {
341 TestToolbarActionsBarBubbleDelegate delegate(HeadingString(), BodyString(),
342 ActionString());
343 ToolbarActionsBarBubbleDelegate::ExtraViewInfo extra_view_info;
344
345 extra_view_info.text =
346 l10n_util::GetStringUTF16(IDS_EXTENSIONS_INSTALLED_BY_ADMIN);
347 extra_view_info.is_text_linked = false;
348 delegate.set_extra_view_info(extra_view_info);
349
350 ShowBubble(&delegate);
351
352 std::unique_ptr<views::View> extra_view(TestCreateExtraView());
353 EXPECT_TRUE(extra_view);
354 EXPECT_EQ("Label", std::string(extra_view->GetClassName()));
355 EXPECT_EQ(l10n_util::GetStringUTF16(IDS_EXTENSIONS_INSTALLED_BY_ADMIN),
356 static_cast<views::Label*>(extra_view.get())->text());
357 CloseBubble();
358 }
359
360 TEST_F(ToolbarActionsBarBubbleViewsTest, TestCreateExtraViewImageAndText) {
361 TestToolbarActionsBarBubbleDelegate delegate(HeadingString(), BodyString(),
362 ActionString());
363 ToolbarActionsBarBubbleDelegate::ExtraViewInfo extra_view_info;
364 extra_view_info.resource_id = gfx::VectorIconId::BUSINESS;
365 extra_view_info.text =
366 l10n_util::GetStringUTF16(IDS_EXTENSIONS_INSTALLED_BY_ADMIN);
367 extra_view_info.is_text_linked = false;
368 delegate.set_extra_view_info(extra_view_info);
369
370 ShowBubble(&delegate);
371
372 std::unique_ptr<views::View> extra_view(TestCreateExtraView());
373 EXPECT_TRUE(extra_view);
374 EXPECT_EQ("View", std::string(extra_view->GetClassName()));
375 EXPECT_EQ(2, extra_view->child_count());
376
377 for (int i = 0; i < 2; i++) {
378 const views::View* v = extra_view->child_at(i);
379 std::string classType = v->GetClassName();
Devlin 2016/10/20 17:04:07 s/classType/class_name, and use a const char*.
catmullings 2016/10/21 03:49:29 Why is const char* better than std::string?
380 EXPECT_TRUE(classType == "Label" || classType == "ImageView");
381 if (classType == "Label") {
382 EXPECT_EQ(l10n_util::GetStringUTF16(IDS_EXTENSIONS_INSTALLED_BY_ADMIN),
383 static_cast<const views::Label*>(v)->text());
384 } else {
385 EXPECT_TRUE(gfx::test::AreImagesEqual(
386 gfx::Image(static_cast<const views::ImageView*>(v)->GetImage()),
387 gfx::Image(gfx::CreateVectorIcon(gfx::VectorIconId::BUSINESS, 16,
388 gfx::kChromeIconGrey))));
389 }
390 }
391
392 CloseBubble();
393 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698