OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "base/strings/string_number_conversions.h" | 5 #include "base/strings/string_number_conversions.h" |
6 #include "base/strings/utf_string_conversions.h" | 6 #include "base/strings/utf_string_conversions.h" |
7 #include "chrome/browser/media_galleries/media_galleries_dialog_controller_mock. h" | 7 #include "chrome/browser/media_galleries/media_galleries_dialog_controller_mock. h" |
8 #include "chrome/browser/ui/views/extensions/media_galleries_dialog_views.h" | 8 #include "chrome/browser/ui/views/extensions/media_galleries_dialog_views.h" |
9 #include "chrome/browser/ui/views/extensions/media_gallery_checkbox_view.h" | 9 #include "chrome/browser/ui/views/extensions/media_gallery_checkbox_view.h" |
10 #include "components/storage_monitor/storage_info.h" | 10 #include "components/storage_monitor/storage_info.h" |
11 #include "extensions/common/extension.h" | 11 #include "extensions/common/extension.h" |
Lei Zhang
2014/06/05 07:56:25
ditto, remove
vandebo (ex-Chrome)
2014/06/05 19:25:30
Done.
| |
12 #include "extensions/common/test_util.h" | 12 #include "extensions/common/test_util.h" |
13 #include "testing/gtest/include/gtest/gtest.h" | 13 #include "testing/gtest/include/gtest/gtest.h" |
14 #include "ui/views/controls/button/checkbox.h" | 14 #include "ui/views/controls/button/checkbox.h" |
15 | 15 |
16 using ::testing::_; | 16 using ::testing::_; |
17 using ::testing::AnyNumber; | |
18 using ::testing::Mock; | |
17 using ::testing::NiceMock; | 19 using ::testing::NiceMock; |
18 using ::testing::Return; | 20 using ::testing::Return; |
19 using ::testing::ReturnPointee; | 21 using ::testing::ReturnPointee; |
20 | 22 |
21 namespace { | 23 namespace { |
22 | 24 |
23 MediaGalleryPrefInfo MakePrefInfoForTesting(MediaGalleryPrefId id) { | 25 MediaGalleryPrefInfo MakePrefInfoForTesting(MediaGalleryPrefId id) { |
24 MediaGalleryPrefInfo gallery; | 26 MediaGalleryPrefInfo gallery; |
25 gallery.pref_id = id; | 27 gallery.pref_id = id; |
26 gallery.device_id = storage_monitor::StorageInfo::MakeDeviceId( | 28 gallery.device_id = storage_monitor::StorageInfo::MakeDeviceId( |
27 storage_monitor::StorageInfo::FIXED_MASS_STORAGE, | 29 storage_monitor::StorageInfo::FIXED_MASS_STORAGE, |
28 base::Int64ToString(id)); | 30 base::Int64ToString(id)); |
29 gallery.display_name = base::ASCIIToUTF16("Display Name"); | 31 gallery.display_name = base::ASCIIToUTF16("Display Name"); |
30 return gallery; | 32 return gallery; |
31 } | 33 } |
32 | 34 |
33 } // namespace | 35 } // namespace |
34 | 36 |
35 class MediaGalleriesDialogTest : public testing::Test { | 37 class MediaGalleriesDialogTest : public testing::Test { |
36 public: | 38 public: |
37 MediaGalleriesDialogTest() {} | 39 MediaGalleriesDialogTest() {} |
38 virtual ~MediaGalleriesDialogTest() {} | 40 virtual ~MediaGalleriesDialogTest() {} |
39 virtual void SetUp() OVERRIDE { | 41 virtual void SetUp() OVERRIDE { |
40 dummy_extension_ = extensions::test_util::CreateExtensionWithID("dummy"); | 42 std::vector<base::string16> headers; |
41 } | 43 headers.push_back(base::string16()); |
42 virtual void TearDown() OVERRIDE { | 44 headers.push_back(base::ASCIIToUTF16("header2")); |
43 dummy_extension_ = NULL; | 45 ON_CALL(controller_, GetSectionHeaders()). |
46 WillByDefault(Return(headers)); | |
47 EXPECT_CALL(controller_, GetSectionEntries(_)). | |
48 Times(AnyNumber()); | |
44 } | 49 } |
45 | 50 |
46 const extensions::Extension& dummy_extension() const { | 51 virtual void TearDown() OVERRIDE { |
47 return *dummy_extension_; | 52 Mock::VerifyAndClearExpectations(&controller_); |
53 } | |
54 | |
55 NiceMock<MediaGalleriesDialogControllerMock>* controller() { | |
56 return &controller_; | |
48 } | 57 } |
49 | 58 |
50 private: | 59 private: |
51 scoped_refptr<extensions::Extension> dummy_extension_; | 60 // TODO(gbillock): Get rid of this mock; make something specialized. |
61 NiceMock<MediaGalleriesDialogControllerMock> controller_; | |
52 | 62 |
53 DISALLOW_COPY_AND_ASSIGN(MediaGalleriesDialogTest); | 63 DISALLOW_COPY_AND_ASSIGN(MediaGalleriesDialogTest); |
54 }; | 64 }; |
55 | 65 |
56 // Tests that checkboxes are initialized according to the contents of | 66 // Tests that checkboxes are initialized according to the contents of |
57 // permissions in the registry. | 67 // permissions in the registry. |
58 TEST_F(MediaGalleriesDialogTest, InitializeCheckboxes) { | 68 TEST_F(MediaGalleriesDialogTest, InitializeCheckboxes) { |
59 // TODO(gbillock): Get rid of this mock; make something specialized. | 69 MediaGalleriesDialogController::Entries attached_permissions; |
60 NiceMock<MediaGalleriesDialogControllerMock> controller(dummy_extension()); | |
61 | |
62 MediaGalleriesDialogController::GalleryPermissionsVector attached_permissions; | |
63 attached_permissions.push_back( | 70 attached_permissions.push_back( |
64 MediaGalleriesDialogController::GalleryPermission( | 71 MediaGalleriesDialogController::Entry(MakePrefInfoForTesting(1), true)); |
65 1, MakePrefInfoForTesting(10), true)); | |
66 attached_permissions.push_back( | 72 attached_permissions.push_back( |
67 MediaGalleriesDialogController::GalleryPermission( | 73 MediaGalleriesDialogController::Entry(MakePrefInfoForTesting(2), false)); |
68 2, MakePrefInfoForTesting(20), false)); | 74 EXPECT_CALL(*controller(), GetSectionEntries(0)). |
69 EXPECT_CALL(controller, AttachedPermissions()). | |
70 WillRepeatedly(Return(attached_permissions)); | 75 WillRepeatedly(Return(attached_permissions)); |
71 | 76 |
72 MediaGalleriesDialogController::GalleryPermissionsVector | 77 MediaGalleriesDialogViews dialog(controller()); |
73 unattached_permissions; | |
74 EXPECT_CALL(controller, UnattachedPermissions()). | |
75 WillRepeatedly(Return(unattached_permissions)); | |
76 | |
77 MediaGalleriesDialogViews dialog(&controller); | |
78 EXPECT_EQ(2U, dialog.checkbox_map_.size()); | 78 EXPECT_EQ(2U, dialog.checkbox_map_.size()); |
79 | 79 |
80 MediaGalleryCheckboxView* checkbox_view1 = dialog.checkbox_map_[1]; | 80 MediaGalleryCheckboxView* checkbox_view1 = dialog.checkbox_map_[1]; |
81 EXPECT_TRUE(checkbox_view1->checkbox()->checked()); | 81 EXPECT_TRUE(checkbox_view1->checkbox()->checked()); |
82 | 82 |
83 MediaGalleryCheckboxView* checkbox_view2 = dialog.checkbox_map_[2]; | 83 MediaGalleryCheckboxView* checkbox_view2 = dialog.checkbox_map_[2]; |
84 EXPECT_FALSE(checkbox_view2->checkbox()->checked()); | 84 EXPECT_FALSE(checkbox_view2->checkbox()->checked()); |
85 } | 85 } |
86 | 86 |
87 // Tests that toggling checkboxes updates the controller. | 87 // Tests that toggling checkboxes updates the controller. |
88 TEST_F(MediaGalleriesDialogTest, ToggleCheckboxes) { | 88 TEST_F(MediaGalleriesDialogTest, ToggleCheckboxes) { |
89 NiceMock<MediaGalleriesDialogControllerMock> controller(dummy_extension()); | 89 MediaGalleriesDialogController::Entries attached_permissions; |
90 | |
91 MediaGalleriesDialogController::GalleryPermissionsVector attached_permissions; | |
92 attached_permissions.push_back( | 90 attached_permissions.push_back( |
93 MediaGalleriesDialogController::GalleryPermission( | 91 MediaGalleriesDialogController::Entry(MakePrefInfoForTesting(1), true)); |
94 1, MakePrefInfoForTesting(10), true)); | 92 EXPECT_CALL(*controller(), GetSectionEntries(0)). |
95 EXPECT_CALL(controller, AttachedPermissions()). | |
96 WillRepeatedly(Return(attached_permissions)); | 93 WillRepeatedly(Return(attached_permissions)); |
97 | 94 |
98 MediaGalleriesDialogController::GalleryPermissionsVector | 95 MediaGalleriesDialogViews dialog(controller()); |
99 unattached_permissions; | |
100 EXPECT_CALL(controller, UnattachedPermissions()). | |
101 WillRepeatedly(Return(unattached_permissions)); | |
102 | |
103 MediaGalleriesDialogViews dialog(&controller); | |
104 EXPECT_EQ(1U, dialog.checkbox_map_.size()); | 96 EXPECT_EQ(1U, dialog.checkbox_map_.size()); |
105 views::Checkbox* checkbox = dialog.checkbox_map_[1]->checkbox(); | 97 views::Checkbox* checkbox = dialog.checkbox_map_[1]->checkbox(); |
106 EXPECT_TRUE(checkbox->checked()); | 98 EXPECT_TRUE(checkbox->checked()); |
107 | 99 |
108 ui::KeyEvent dummy_event(ui::ET_KEY_PRESSED, ui::VKEY_A, ui::EF_NONE, false); | 100 ui::KeyEvent dummy_event(ui::ET_KEY_PRESSED, ui::VKEY_A, ui::EF_NONE, false); |
109 EXPECT_CALL(controller, DidToggleGallery(1, false)); | 101 EXPECT_CALL(*controller(), DidToggleEntry(1, false)); |
110 checkbox->SetChecked(false); | 102 checkbox->SetChecked(false); |
111 dialog.ButtonPressed(checkbox, dummy_event); | 103 dialog.ButtonPressed(checkbox, dummy_event); |
112 | 104 |
113 EXPECT_CALL(controller, DidToggleGallery(1, true)); | 105 EXPECT_CALL(*controller(), DidToggleEntry(1, true)); |
114 checkbox->SetChecked(true); | 106 checkbox->SetChecked(true); |
115 dialog.ButtonPressed(checkbox, dummy_event); | 107 dialog.ButtonPressed(checkbox, dummy_event); |
116 } | 108 } |
117 | 109 |
118 // Tests that UpdateGallery will add a new checkbox, but only if it refers to | 110 // Tests that UpdateGallery will add a new checkbox, but only if it refers to |
119 // a gallery that the dialog hasn't seen before. | 111 // a gallery that the dialog hasn't seen before. |
120 TEST_F(MediaGalleriesDialogTest, UpdateAdds) { | 112 TEST_F(MediaGalleriesDialogTest, UpdateAdds) { |
121 NiceMock<MediaGalleriesDialogControllerMock> controller(dummy_extension()); | 113 MediaGalleriesDialogViews dialog(controller()); |
122 | 114 |
123 MediaGalleriesDialogController::GalleryPermissionsVector attached_permissions; | 115 MediaGalleriesDialogController::Entries attached_permissions; |
124 EXPECT_CALL(controller, AttachedPermissions()). | 116 EXPECT_CALL(*controller(), GetSectionEntries(0)). |
125 WillRepeatedly(ReturnPointee(&attached_permissions)); | 117 WillRepeatedly(ReturnPointee(&attached_permissions)); |
126 | 118 |
127 MediaGalleriesDialogController::GalleryPermissionsVector | |
128 unattached_permissions; | |
129 EXPECT_CALL(controller, UnattachedPermissions()). | |
130 WillRepeatedly(Return(unattached_permissions)); | |
131 | |
132 MediaGalleriesDialogViews dialog(&controller); | |
133 | |
134 EXPECT_TRUE(dialog.checkbox_map_.empty()); | 119 EXPECT_TRUE(dialog.checkbox_map_.empty()); |
135 | 120 |
136 MediaGalleryPrefInfo gallery1 = MakePrefInfoForTesting(10); | 121 MediaGalleryPrefInfo gallery1 = MakePrefInfoForTesting(1); |
137 attached_permissions.push_back( | 122 attached_permissions.push_back( |
138 MediaGalleriesDialogController::GalleryPermission(1, gallery1, true)); | 123 MediaGalleriesDialogController::Entry(gallery1, true)); |
139 dialog.UpdateGalleries(); | 124 dialog.UpdateGalleries(); |
140 EXPECT_EQ(1U, dialog.checkbox_map_.size()); | 125 EXPECT_EQ(1U, dialog.checkbox_map_.size()); |
141 | 126 |
142 MediaGalleryPrefInfo gallery2 = MakePrefInfoForTesting(20); | 127 MediaGalleryPrefInfo gallery2 = MakePrefInfoForTesting(2); |
143 attached_permissions.push_back( | 128 attached_permissions.push_back( |
144 MediaGalleriesDialogController::GalleryPermission(2, gallery2, true)); | 129 MediaGalleriesDialogController::Entry(gallery2, true)); |
145 dialog.UpdateGalleries(); | 130 dialog.UpdateGalleries(); |
146 EXPECT_EQ(2U, dialog.checkbox_map_.size()); | 131 EXPECT_EQ(2U, dialog.checkbox_map_.size()); |
147 | 132 |
148 attached_permissions.push_back( | 133 attached_permissions.push_back( |
149 MediaGalleriesDialogController::GalleryPermission(2, gallery2, false)); | 134 MediaGalleriesDialogController::Entry(gallery2, false)); |
150 dialog.UpdateGalleries(); | 135 dialog.UpdateGalleries(); |
151 EXPECT_EQ(2U, dialog.checkbox_map_.size()); | 136 EXPECT_EQ(2U, dialog.checkbox_map_.size()); |
152 } | 137 } |
153 | 138 |
154 TEST_F(MediaGalleriesDialogTest, ForgetDeletes) { | 139 TEST_F(MediaGalleriesDialogTest, ForgetDeletes) { |
155 NiceMock<MediaGalleriesDialogControllerMock> controller(dummy_extension()); | 140 MediaGalleriesDialogViews dialog(controller()); |
156 | 141 |
157 MediaGalleriesDialogController::GalleryPermissionsVector attached_permissions; | 142 MediaGalleriesDialogController::Entries attached_permissions; |
158 EXPECT_CALL(controller, AttachedPermissions()). | 143 EXPECT_CALL(*controller(), GetSectionEntries(0)). |
159 WillRepeatedly(ReturnPointee(&attached_permissions)); | 144 WillRepeatedly(ReturnPointee(&attached_permissions)); |
160 | 145 |
161 MediaGalleriesDialogController::GalleryPermissionsVector | |
162 unattached_permissions; | |
163 EXPECT_CALL(controller, UnattachedPermissions()). | |
164 WillRepeatedly(Return(unattached_permissions)); | |
165 | |
166 MediaGalleriesDialogViews dialog(&controller); | |
167 | |
168 EXPECT_TRUE(dialog.checkbox_map_.empty()); | 146 EXPECT_TRUE(dialog.checkbox_map_.empty()); |
169 | 147 |
170 MediaGalleryPrefInfo gallery1 = MakePrefInfoForTesting(10); | 148 MediaGalleryPrefInfo gallery1 = MakePrefInfoForTesting(1); |
171 attached_permissions.push_back( | 149 attached_permissions.push_back( |
172 MediaGalleriesDialogController::GalleryPermission(1, gallery1, true)); | 150 MediaGalleriesDialogController::Entry(gallery1, true)); |
173 dialog.UpdateGalleries(); | 151 dialog.UpdateGalleries(); |
174 EXPECT_EQ(1U, dialog.checkbox_map_.size()); | 152 EXPECT_EQ(1U, dialog.checkbox_map_.size()); |
175 | 153 |
176 MediaGalleryPrefInfo gallery2 = MakePrefInfoForTesting(20); | 154 MediaGalleryPrefInfo gallery2 = MakePrefInfoForTesting(2); |
177 attached_permissions.push_back( | 155 attached_permissions.push_back( |
178 MediaGalleriesDialogController::GalleryPermission(2, gallery2, true)); | 156 MediaGalleriesDialogController::Entry(gallery2, true)); |
179 dialog.UpdateGalleries(); | 157 dialog.UpdateGalleries(); |
180 EXPECT_EQ(2U, dialog.checkbox_map_.size()); | 158 EXPECT_EQ(2U, dialog.checkbox_map_.size()); |
181 | 159 |
182 attached_permissions.pop_back(); | 160 attached_permissions.pop_back(); |
183 dialog.UpdateGalleries(); | 161 dialog.UpdateGalleries(); |
184 EXPECT_EQ(1U, dialog.checkbox_map_.size()); | 162 EXPECT_EQ(1U, dialog.checkbox_map_.size()); |
185 } | 163 } |
OLD | NEW |