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/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 Loading... | |
| 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 Loading... | |
| 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 } | |
| OLD | NEW |