Chromium Code Reviews| Index: chrome/browser/ui/autofill/autofill_popup_controller_unittest.cc |
| diff --git a/chrome/browser/ui/autofill/autofill_popup_controller_unittest.cc b/chrome/browser/ui/autofill/autofill_popup_controller_unittest.cc |
| index 338213caebb9ae2e59f3dc6f9ace9f4f55f54740..d80f9716a65d9852963457d221982fac14f4329a 100644 |
| --- a/chrome/browser/ui/autofill/autofill_popup_controller_unittest.cc |
| +++ b/chrome/browser/ui/autofill/autofill_popup_controller_unittest.cc |
| @@ -7,6 +7,7 @@ |
| #include "base/prefs/testing_pref_service.h" |
| #include "base/utf_string_conversions.h" |
| #include "chrome/browser/ui/autofill/autofill_popup_controller_impl.h" |
| +#include "chrome/browser/ui/autofill/autofill_popup_view.h" |
| #include "chrome/test/base/chrome_render_view_host_test_harness.h" |
| #include "chrome/test/base/testing_profile.h" |
| #include "components/autofill/browser/autofill_external_delegate.h" |
| @@ -109,6 +110,9 @@ class TestAutofillPopupController : public AutofillPopupControllerImpl { |
| const gfx::Font& subtext_font() const { |
| return AutofillPopupControllerImpl::subtext_font(); |
| } |
| + int RowWidthWithoutText(int row) const { |
| + return AutofillPopupControllerImpl::RowWidthWithoutText(row); |
| + } |
| #endif |
| int GetDesiredPopupWidth() const { |
| return AutofillPopupControllerImpl::GetDesiredPopupWidth(); |
| @@ -286,6 +290,39 @@ TEST_F(AutofillPopupControllerUnitTest, SkipSeparator) { |
| EXPECT_EQ(0, autofill_popup_controller_->selected_line()); |
| } |
| +TEST_F(AutofillPopupControllerUnitTest, RowWidthWithoutText) { |
| + std::vector<string16> names(4); |
| + std::vector<string16> subtexts(4); |
| + std::vector<string16> icons(4); |
| + std::vector<int> ids(4); |
| + |
| + // Set up some visible display so the text values are kept. |
| + gfx::Display display(0, |
| + gfx::Rect(0, 0, 100, 100)); |
|
Ilya Sherman
2013/04/16 22:06:01
nit: Looks like this all fits on a single line.
csharp
2013/04/17 13:29:37
Done.
|
| + autofill_popup_controller_->set_display(display); |
| + |
| + // Give elements 1 and 3 subtexts and elements 2 and 3 icons, to ensure |
| + // and combinations of subtexts and icons. |
|
Ilya Sherman
2013/04/16 22:06:01
nit: "and" -> "all"
csharp
2013/04/17 13:29:37
Done.
|
| + subtexts[1] = ASCIIToUTF16("x"); |
| + subtexts[3] = ASCIIToUTF16("x"); |
| + icons[2] = ASCIIToUTF16("x"); |
| + icons[3] = ASCIIToUTF16("x"); |
| + autofill_popup_controller_->Show(names, subtexts, icons, ids); |
| + |
| + int base_size = AutofillPopupView::kEndPadding * 2; |
| + int subtext_increase = AutofillPopupView::kNamePadding; |
| + int icon_increase = AutofillPopupView::kIconPadding + |
| + AutofillPopupView::kAutofillIconWidth; |
| + |
| + EXPECT_EQ(base_size, autofill_popup_controller_->RowWidthWithoutText(0)); |
| + EXPECT_EQ(base_size + subtext_increase, |
| + autofill_popup_controller_->RowWidthWithoutText(1)); |
| + EXPECT_EQ(base_size + icon_increase, |
| + autofill_popup_controller_->RowWidthWithoutText(2)); |
| + EXPECT_EQ(base_size + subtext_increase + icon_increase, |
| + autofill_popup_controller_->RowWidthWithoutText(3)); |
| +} |
| + |
| TEST_F(AutofillPopupControllerUnitTest, GetOrCreate) { |
| MockAutofillExternalDelegate delegate( |
| web_contents(), AutofillManager::FromWebContents(web_contents())); |