Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 Loading... | |
| 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 Loading... | |
| 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 } | |
| OLD | NEW |