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

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: Fixes and tests after bubble screenshot verification 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/image/image.h"
20 #include "ui/gfx/image/image_unittest_util.h"
14 #include "ui/views/controls/button/label_button.h" 21 #include "ui/views/controls/button/label_button.h"
15 #include "ui/views/controls/link.h" 22 #include "ui/views/controls/link.h"
16 #include "ui/views/test/test_widget_observer.h" 23 #include "ui/views/test/test_widget_observer.h"
17 #include "ui/views/test/views_test_base.h" 24 #include "ui/views/test/views_test_base.h"
18 #include "ui/views/widget/widget.h" 25 #include "ui/views/widget/widget.h"
19 #include "ui/views/window/dialog_client_view.h" 26 #include "ui/views/window/dialog_client_view.h"
20 27
21 class ToolbarActionsBarBubbleViewsTest : public views::ViewsTestBase { 28 class ToolbarActionsBarBubbleViewsTest : public views::ViewsTestBase {
29 public:
30 views::View* TestCreateExtraView() {
31 return (bubble_) ? bubble_->CreateExtraView() : nullptr;
32 }
33
22 protected: 34 protected:
23 ToolbarActionsBarBubbleViewsTest() {} 35 ToolbarActionsBarBubbleViewsTest() {}
24 ~ToolbarActionsBarBubbleViewsTest() override {} 36 ~ToolbarActionsBarBubbleViewsTest() override {}
25 37
26 void TearDown() override { 38 void TearDown() override {
27 anchor_widget_.reset(); 39 anchor_widget_.reset();
28 views::ViewsTestBase::TearDown(); 40 views::ViewsTestBase::TearDown();
29 } 41 }
30 42
31 std::unique_ptr<views::Widget> CreateAnchorWidget() { 43 std::unique_ptr<views::Widget> CreateAnchorWidget() {
(...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after
92 ShowBubble(&delegate); 104 ShowBubble(&delegate);
93 105
94 EXPECT_TRUE(bubble()->GetDialogClientView()->ok_button()); 106 EXPECT_TRUE(bubble()->GetDialogClientView()->ok_button());
95 EXPECT_EQ(ActionString(), 107 EXPECT_EQ(ActionString(),
96 bubble()->GetDialogClientView()->ok_button()->GetText()); 108 bubble()->GetDialogClientView()->ok_button()->GetText());
97 EXPECT_FALSE(bubble()->GetDialogClientView()->cancel_button()); 109 EXPECT_FALSE(bubble()->GetDialogClientView()->cancel_button());
98 110
99 CloseBubble(); 111 CloseBubble();
100 } 112 }
101 113
114 TEST_F(ToolbarActionsBarBubbleViewsTest, TestBubbleLayoutNoButtons) {
115 TestToolbarActionsBarBubbleDelegate delegate(HeadingString(), BodyString(),
116 ActionString());
117 delegate.set_dismiss_button_text(base::string16());
118 delegate.set_action_button_text(base::string16());
119 ShowBubble(&delegate);
120
121 EXPECT_FALSE(bubble()->GetDialogClientView()->ok_button());
122 EXPECT_FALSE(bubble()->GetDialogClientView()->cancel_button());
123
124 CloseBubble();
125 }
126
102 TEST_F(ToolbarActionsBarBubbleViewsTest, 127 TEST_F(ToolbarActionsBarBubbleViewsTest,
103 TestBubbleLayoutActionAndDismissButton) { 128 TestBubbleLayoutActionAndDismissButton) {
104 TestToolbarActionsBarBubbleDelegate delegate(HeadingString(), BodyString(), 129 TestToolbarActionsBarBubbleDelegate delegate(HeadingString(), BodyString(),
105 ActionString()); 130 ActionString());
106 delegate.set_dismiss_button_text(DismissString()); 131 delegate.set_dismiss_button_text(DismissString());
107
108 ShowBubble(&delegate); 132 ShowBubble(&delegate);
109 133
110 EXPECT_TRUE(bubble()->GetDialogClientView()->ok_button()); 134 EXPECT_TRUE(bubble()->GetDialogClientView()->ok_button());
111 EXPECT_EQ(ActionString(), 135 EXPECT_EQ(ActionString(),
112 bubble()->GetDialogClientView()->ok_button()->GetText()); 136 bubble()->GetDialogClientView()->ok_button()->GetText());
113 EXPECT_TRUE(bubble()->GetDialogClientView()->cancel_button()); 137 EXPECT_TRUE(bubble()->GetDialogClientView()->cancel_button());
114 EXPECT_EQ(DismissString(), 138 EXPECT_EQ(DismissString(),
115 bubble()->GetDialogClientView()->cancel_button()->GetText()); 139 bubble()->GetDialogClientView()->cancel_button()->GetText());
116 140
117 EXPECT_FALSE(bubble()->learn_more_button()); 141 EXPECT_FALSE(bubble()->learn_more_button());
118 EXPECT_FALSE(bubble()->item_list()); 142 EXPECT_FALSE(bubble()->item_list());
119 143
120 CloseBubble(); 144 CloseBubble();
121 } 145 }
122 146
123 TEST_F(ToolbarActionsBarBubbleViewsTest, 147 TEST_F(ToolbarActionsBarBubbleViewsTest,
124 TestBubbleLayoutActionDismissAndLearnMoreButton) { 148 TestBubbleLayoutActionDismissAndLearnMoreButton) {
125 TestToolbarActionsBarBubbleDelegate delegate(HeadingString(), BodyString(), 149 TestToolbarActionsBarBubbleDelegate delegate(HeadingString(), BodyString(),
126 ActionString()); 150 ActionString());
127 delegate.set_dismiss_button_text(DismissString()); 151 delegate.set_dismiss_button_text(DismissString());
128 delegate.set_learn_more_button_text(LearnMoreString()); 152
153 ToolbarActionsBarBubbleDelegate::ExtraViewInfo extra_view_info_linked_text;
154
155 extra_view_info_linked_text.text = LearnMoreString();
156 extra_view_info_linked_text.is_text_linked = true;
157 delegate.set_extra_view_info(extra_view_info_linked_text);
158
129 ShowBubble(&delegate); 159 ShowBubble(&delegate);
130 160
131 EXPECT_TRUE(bubble()->GetDialogClientView()->ok_button()); 161 EXPECT_TRUE(bubble()->GetDialogClientView()->ok_button());
132 EXPECT_EQ(ActionString(), 162 EXPECT_EQ(ActionString(),
133 bubble()->GetDialogClientView()->ok_button()->GetText()); 163 bubble()->GetDialogClientView()->ok_button()->GetText());
134 EXPECT_TRUE(bubble()->GetDialogClientView()->cancel_button()); 164 EXPECT_TRUE(bubble()->GetDialogClientView()->cancel_button());
135 EXPECT_EQ(DismissString(), 165 EXPECT_EQ(DismissString(),
136 bubble()->GetDialogClientView()->cancel_button()->GetText()); 166 bubble()->GetDialogClientView()->cancel_button()->GetText());
137 EXPECT_TRUE(bubble()->learn_more_button()); 167 EXPECT_TRUE(bubble()->learn_more_button());
138 EXPECT_EQ(LearnMoreString(), bubble()->learn_more_button()->text()); 168 EXPECT_EQ(LearnMoreString(), bubble()->learn_more_button()->text());
(...skipping 114 matching lines...) Expand 10 before | Expand all | Expand 10 after
253 ShowBubble(&delegate); 283 ShowBubble(&delegate);
254 views::test::TestWidgetObserver bubble_observer(bubble_widget()); 284 views::test::TestWidgetObserver bubble_observer(bubble_widget());
255 285
256 EXPECT_FALSE(delegate.close_action()); 286 EXPECT_FALSE(delegate.close_action());
257 // Activate another widget. The bubble shouldn't close. 287 // Activate another widget. The bubble shouldn't close.
258 anchor_widget()->Activate(); 288 anchor_widget()->Activate();
259 base::RunLoop().RunUntilIdle(); 289 base::RunLoop().RunUntilIdle();
260 EXPECT_FALSE(delegate.close_action()); 290 EXPECT_FALSE(delegate.close_action());
261 CloseBubble(); 291 CloseBubble();
262 } 292 }
293
294 TEST_F(ToolbarActionsBarBubbleViewsTest, TestCreateExtraViewEmpty) {
295 TestToolbarActionsBarBubbleDelegate delegate(HeadingString(), BodyString(),
296 ActionString());
297 ToolbarActionsBarBubbleDelegate::ExtraViewInfo extra_view_info;
298 delegate.set_extra_view_info(extra_view_info);
299 ShowBubble(&delegate);
300
301 std::unique_ptr<views::View> extra_view(TestCreateExtraView());
302 EXPECT_FALSE(extra_view);
303 CloseBubble();
304 }
305
306 TEST_F(ToolbarActionsBarBubbleViewsTest, TestCreateExtraViewIconOnly) {
307 TestToolbarActionsBarBubbleDelegate delegate(HeadingString(), BodyString(),
308 ActionString());
309 ToolbarActionsBarBubbleDelegate::ExtraViewInfo extra_view_info;
310
311 extra_view_info.resource_id = IDR_OMNIBOX_HTTPS_POLICY_WARNING;
312 delegate.set_extra_view_info(extra_view_info);
313 ShowBubble(&delegate);
314 std::unique_ptr<views::View> extra_view(TestCreateExtraView());
315 EXPECT_TRUE(extra_view);
316 EXPECT_EQ("ImageView", std::string(extra_view->GetClassName()));
317 EXPECT_TRUE(gfx::test::AreImagesEqual(
318 gfx::Image(static_cast<views::ImageView*>(extra_view.get())->GetImage()),
319 gfx::Image(*(ResourceBundle::GetSharedInstance().GetImageSkiaNamed(
320 IDR_OMNIBOX_HTTPS_POLICY_WARNING)))));
321 CloseBubble();
322 }
323
324 TEST_F(ToolbarActionsBarBubbleViewsTest, TestCreateExtraViewLinkedTextOnly) {
325 TestToolbarActionsBarBubbleDelegate delegate(HeadingString(), BodyString(),
326 ActionString());
327 ToolbarActionsBarBubbleDelegate::ExtraViewInfo extra_view_info_linked_text;
328
329 extra_view_info_linked_text.text =
330 l10n_util::GetStringUTF16(IDS_EXTENSIONS_INSTALLED_BY_ADMIN);
331 extra_view_info_linked_text.is_text_linked = true;
332 delegate.set_extra_view_info(extra_view_info_linked_text);
333
334 ShowBubble(&delegate);
335
336 std::unique_ptr<views::View> extra_view(TestCreateExtraView());
337 EXPECT_TRUE(extra_view);
338 EXPECT_EQ("Link", std::string(extra_view->GetClassName()));
339 EXPECT_EQ(l10n_util::GetStringUTF16(IDS_EXTENSIONS_INSTALLED_BY_ADMIN),
340 static_cast<views::Label*>(extra_view.get())->text());
341 CloseBubble();
342 }
343
344 TEST_F(ToolbarActionsBarBubbleViewsTest, TestCreateExtraViewLabelTextOnly) {
345 TestToolbarActionsBarBubbleDelegate delegate(HeadingString(), BodyString(),
346 ActionString());
347 ToolbarActionsBarBubbleDelegate::ExtraViewInfo extra_view_info;
348
349 extra_view_info.text =
350 l10n_util::GetStringUTF16(IDS_EXTENSIONS_INSTALLED_BY_ADMIN);
351 extra_view_info.is_text_linked = false;
352 delegate.set_extra_view_info(extra_view_info);
353
354 ShowBubble(&delegate);
355
356 std::unique_ptr<views::View> extra_view(TestCreateExtraView());
357 EXPECT_TRUE(extra_view);
358 EXPECT_EQ("Label", std::string(extra_view->GetClassName()));
359 EXPECT_EQ(l10n_util::GetStringUTF16(IDS_EXTENSIONS_INSTALLED_BY_ADMIN),
360 static_cast<views::Label*>(extra_view.get())->text());
361 CloseBubble();
362 }
363
364 TEST_F(ToolbarActionsBarBubbleViewsTest, TestCreateExtraViewImageAndText) {
365 TestToolbarActionsBarBubbleDelegate delegate(HeadingString(), BodyString(),
366 ActionString());
367 ToolbarActionsBarBubbleDelegate::ExtraViewInfo extra_view_info;
368 extra_view_info.resource_id = IDR_OMNIBOX_HTTPS_POLICY_WARNING;
369 extra_view_info.text =
370 l10n_util::GetStringUTF16(IDS_EXTENSIONS_INSTALLED_BY_ADMIN);
371 extra_view_info.is_text_linked = false;
372 delegate.set_extra_view_info(extra_view_info);
373
374 ShowBubble(&delegate);
375
376 std::unique_ptr<views::View> extra_view(TestCreateExtraView());
377 EXPECT_TRUE(extra_view);
378 EXPECT_EQ("View", std::string(extra_view->GetClassName()));
379 EXPECT_EQ(2, extra_view->child_count());
380
381 for (int i = 0; i < 2; i++) {
382 const views::View* v = extra_view->child_at(i);
383 std::string classType = v->GetClassName();
catmullings 2016/10/06 18:24:19 Wasn't sure how to prevent a copy in converting fr
Devlin 2016/10/10 15:27:29 there isn't a way, because there's actually no cop
catmullings 2016/10/12 18:58:58 Done.
384 EXPECT_TRUE(classType == "Label" || classType == "ImageView");
385 if (classType == "Label") {
386 EXPECT_EQ(l10n_util::GetStringUTF16(IDS_EXTENSIONS_INSTALLED_BY_ADMIN),
387 static_cast<const views::Label*>(v)->text());
388 } else {
389 EXPECT_TRUE(gfx::test::AreImagesEqual(
390 gfx::Image(static_cast<const views::ImageView*>(v)->GetImage()),
391 gfx::Image(*(ResourceBundle::GetSharedInstance().GetImageSkiaNamed(
392 IDR_OMNIBOX_HTTPS_POLICY_WARNING)))));
393 }
394 }
395
396 CloseBubble();
397 }
OLDNEW
« no previous file with comments | « chrome/browser/ui/views/toolbar/toolbar_actions_bar_bubble_views.cc ('k') | chrome/test/BUILD.gn » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698