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

Unified Diff: chrome/browser/ui/cocoa/extensions/media_galleries_dialog_cocoa_unittest.mm

Issue 10854150: Cocoa: Media gallery dialog unit test (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: rebase Created 8 years, 4 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/ui/cocoa/extensions/media_galleries_dialog_cocoa_unittest.mm
diff --git a/chrome/browser/ui/cocoa/extensions/media_galleries_dialog_cocoa_unittest.mm b/chrome/browser/ui/cocoa/extensions/media_galleries_dialog_cocoa_unittest.mm
new file mode 100644
index 0000000000000000000000000000000000000000..1a4f9d2b8e3ea5d5b686d4f7fd39985d5217d20b
--- /dev/null
+++ b/chrome/browser/ui/cocoa/extensions/media_galleries_dialog_cocoa_unittest.mm
@@ -0,0 +1,125 @@
+// Copyright (c) 2012 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/browser/media_gallery/media_galleries_dialog_controller_mock.h"
+#include "chrome/browser/ui/cocoa/extensions/media_galleries_dialog_cocoa.h"
+#include "testing/gtest/include/gtest/gtest.h"
+
+using ::testing::_;
+using ::testing::NiceMock;
+using ::testing::Return;
+using ::testing::ReturnRef;
+
+namespace chrome {
+
+class MediaGalleriesDialogTest : public testing::Test {
+};
+
+// Tests that checkboxes are initialized according to the contents of
+// permissions().
+TEST_F(MediaGalleriesDialogTest, InitializeCheckboxes) {
+ NiceMock<MediaGalleriesDialogControllerMock> controller;
+
+ MediaGalleriesDialogController::KnownGalleryPermissions permissions;
+ MediaGalleryPrefInfo gallery1;
+ gallery1.device_id = "/a";
+ permissions[1] = MediaGalleriesDialogController::GalleryPermission(
+ gallery1, true);
+ MediaGalleryPrefInfo gallery2;
+ gallery2.device_id = "/b";
+ permissions[2] = MediaGalleriesDialogController::GalleryPermission(
+ gallery2, false);
+ EXPECT_CALL(controller, permissions()).
+ WillRepeatedly(ReturnRef(permissions));
+
+ // Initializing checkboxes should not cause them to be toggled.
+ EXPECT_CALL(controller, DidToggleGallery(_, _)).
+ Times(0);
+
+ scoped_ptr<MediaGalleriesDialogCocoa> dialog(
+ static_cast<MediaGalleriesDialogCocoa*>(
+ MediaGalleriesDialog::Create(&controller)));
+ EXPECT_EQ(2U, [dialog->checkboxes_ count]);
+
+ // Note that checkboxes_ is sorted from bottom up.
+ NSButton* checkbox1 = [dialog->checkboxes_ objectAtIndex:1];
+ EXPECT_EQ([checkbox1 state], NSOnState);
+
+ NSButton* checkbox2 = [dialog->checkboxes_ objectAtIndex:0];
+ EXPECT_EQ([checkbox2 state], NSOffState);
+}
+
+// Tests that toggling checkboxes updates the controller.
+TEST_F(MediaGalleriesDialogTest, ToggleCheckboxes) {
+ NiceMock<MediaGalleriesDialogControllerMock> controller;
+
+ MediaGalleriesDialogController::KnownGalleryPermissions permissions;
+ MediaGalleryPrefInfo gallery;
+ permissions[1] = MediaGalleriesDialogController::GalleryPermission(
+ gallery, true);
+ EXPECT_CALL(controller, permissions()).
+ WillRepeatedly(ReturnRef(permissions));
+
+ scoped_ptr<MediaGalleriesDialogCocoa> dialog(
+ static_cast<MediaGalleriesDialogCocoa*>(
+ MediaGalleriesDialog::Create(&controller)));
+ EXPECT_EQ(1U, [dialog->checkboxes_ count]);
+
+ NSButton* checkbox = [dialog->checkboxes_ objectAtIndex:0];
+ EXPECT_EQ([checkbox state], NSOnState);
+
+ EXPECT_CALL(controller, DidToggleGallery(_, false));
+ [checkbox performClick:nil];
+ EXPECT_EQ([checkbox state], NSOffState);
+
+ EXPECT_CALL(controller, DidToggleGallery(_, true));
+ [checkbox performClick:nil];
+ EXPECT_EQ([checkbox state], NSOnState);
+}
+
+// Tests that UpdateGallery will add a new checkbox, but only if it refers to
+// a gallery that the dialog hasn't seen before.
+TEST_F(MediaGalleriesDialogTest, UpdateAdds) {
+ NiceMock<MediaGalleriesDialogControllerMock> controller;
+
+ MediaGalleriesDialogController::KnownGalleryPermissions permissions;
+ EXPECT_CALL(controller, permissions()).
+ WillRepeatedly(ReturnRef(permissions));
+
+ scoped_ptr<MediaGalleriesDialogCocoa> dialog(
+ static_cast<MediaGalleriesDialogCocoa*>(
+ MediaGalleriesDialog::Create(&controller)));
+
+ EXPECT_EQ(0U, [dialog->checkboxes_ count]);
+ CGFloat old_container_height = NSHeight([dialog->checkbox_container_ frame]);
+
+ MediaGalleryPrefInfo gallery1;
+ gallery1.device_id = "/a";
+ dialog->UpdateGallery(&gallery1, true);
+ EXPECT_EQ(1U, [dialog->checkboxes_ count]);
+
+ // The checkbox container should be taller.
+ CGFloat new_container_height = NSHeight([dialog->checkbox_container_ frame]);
+ EXPECT_GT(new_container_height, old_container_height);
+ old_container_height = new_container_height;
+
+ MediaGalleryPrefInfo gallery2;
+ gallery2.device_id = "/b";
+ dialog->UpdateGallery(&gallery2, true);
+ EXPECT_EQ(2U, [dialog->checkboxes_ count]);
+
+ // The checkbox container should be taller.
+ new_container_height = NSHeight([dialog->checkbox_container_ frame]);
+ EXPECT_GT(new_container_height, old_container_height);
+ old_container_height = new_container_height;
+
+ dialog->UpdateGallery(&gallery2, false);
+ EXPECT_EQ(2U, [dialog->checkboxes_ count]);
+
+ // The checkbox container height should not have changed.
+ new_container_height = NSHeight([dialog->checkbox_container_ frame]);
+ EXPECT_EQ(new_container_height, old_container_height);
+}
+
+} // namespace chrome

Powered by Google App Engine
This is Rietveld 408576698