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

Unified Diff: ios/chrome/browser/ui/authentication/signin_promo_view_mediator_unittest.mm

Issue 2749703003: Adding mediator for Sign-in promo (Closed)
Patch Set: Visual constraints Created 3 years, 9 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: ios/chrome/browser/ui/authentication/signin_promo_view_mediator_unittest.mm
diff --git a/ios/chrome/browser/ui/authentication/signin_promo_view_mediator_unittest.mm b/ios/chrome/browser/ui/authentication/signin_promo_view_mediator_unittest.mm
new file mode 100644
index 0000000000000000000000000000000000000000..2d15bd68f2bf601b337c706c7f92b2f20366e9c7
--- /dev/null
+++ b/ios/chrome/browser/ui/authentication/signin_promo_view_mediator_unittest.mm
@@ -0,0 +1,152 @@
+// Copyright 2017 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.
+
+#import "ios/chrome/browser/ui/authentication/signin_promo_view_mediator.h"
+
+#import "ios/third_party/material_components_ios/src/components/Buttons/src/MaterialButtons.h"
+#import "testing/platform_test.h"
+#import "third_party/ocmock/OCMock/OCMock.h"
+#include "third_party/ocmock/gtest_support.h"
+
+#if !defined(__has_feature) || !__has_feature(objc_arc)
+#error "This file requires ARC support."
+#endif
+
+namespace {
+
+class SigninPromoViewMediatorTest : public PlatformTest {
+ protected:
+ void SetUp() override {
+ _mediator = [[SigninPromoViewMediator alloc] init];
+
+ _signinPromoView = OCMStrictClassMock([SigninPromoView class]);
lpromero 2017/03/24 10:36:20 Why not just a real SigninPromoView? You don't rea
jlebel 2017/03/24 20:59:09 I have a better control about what is done on Sign
lpromero 2017/03/27 13:14:46 You mean that the view takes the configurator data
+ _primaryButton = OCMStrictClassMock([MDCFlatButton class]);
+ OCMStub([_signinPromoView primaryButton]).andReturn(_primaryButton);
+ _secondaryButton = OCMStrictClassMock([MDCFlatButton class]);
+ OCMStub([_signinPromoView secondaryButton]).andReturn(_secondaryButton);
+ }
+
+ void TearDown() override {
+ _mediator = nil;
+ EXPECT_OCMOCK_VERIFY((id)_signinPromoView);
+ EXPECT_OCMOCK_VERIFY((id)_primaryButton);
+ EXPECT_OCMOCK_VERIFY((id)_secondaryButton);
+ }
+
+ void ExpectColdStartConfiguration() {
+ OCMExpect([_signinPromoView setMode:SigninPromoViewColdStartMode]);
+ _imageViewProfileImage = nil;
+ _primaryButtonTitle = nil;
+ OCMExpect([_primaryButton setTitle:[OCMArg checkWithBlock:^BOOL(id value) {
+ _primaryButtonTitle = value;
+ return YES;
+ }]
+ forState:UIControlStateNormal]);
+ _secondaryButtonTitle = nil;
+ }
+
+ void CheckColdStartConfiguration() {
+ EXPECT_EQ(nil, _imageViewProfileImage);
+ EXPECT_NE(nil, _primaryButtonTitle);
+ EXPECT_EQ(nil, _secondaryButtonTitle);
+ }
+
+ void ExpectWarmStartConfiguration() {
+ OCMExpect([_signinPromoView setMode:SigninPromoViewWarmStartMode]);
+ OCMExpect([_signinPromoView
+ setProfileImage:[OCMArg checkWithBlock:^BOOL(id value) {
+ _imageViewProfileImage = value;
+ return YES;
+ }]]);
+ _primaryButtonTitle = nil;
+ OCMExpect([_primaryButton setTitle:[OCMArg checkWithBlock:^BOOL(id value) {
+ _primaryButtonTitle = value;
+ return YES;
+ }]
+ forState:UIControlStateNormal]);
+ _secondaryButtonTitle = nil;
+ OCMExpect([_secondaryButton
+ setTitle:[OCMArg checkWithBlock:^BOOL(id value) {
+ _secondaryButtonTitle = value;
+ return YES;
+ }]
+ forState:UIControlStateNormal]);
+ }
+
+ void CheckWarmStartConfiguration() {
+ EXPECT_NE(nil, _imageViewProfileImage);
+ NSRange profileNameRange =
+ [_primaryButtonTitle rangeOfString:_mediator.userFullName];
+ EXPECT_NE(profileNameRange.length, 0u);
+ NSRange profileEmailRange =
+ [_secondaryButtonTitle rangeOfString:_mediator.userEmail];
+ EXPECT_NE(profileEmailRange.length, 0u);
+ }
+
+ // Mediator used for the tests.
+ SigninPromoViewMediator* _mediator;
lpromero 2017/03/24 10:36:20 C++ class, so use trailing underscore and snake ca
jlebel 2017/03/24 20:59:09 Done.
+
+ // Mocks.
+ SigninPromoView* _signinPromoView;
+ MDCFlatButton* _primaryButton;
+ MDCFlatButton* _secondaryButton;
+
+ // Value set by -[SigninPromoView setProfileImage:].
+ UIImage* _imageViewProfileImage;
+ // Value set by -[_primaryButton setTitle: forState:UIControlStateNormal].
+ NSString* _primaryButtonTitle;
+ // Value set by -[_secondaryButton setTitle: forState:UIControlStateNormal].
+ NSString* _secondaryButtonTitle;
+};
+
+TEST_F(SigninPromoViewMediatorTest, ColdStartConfigureSigninPromoView) {
+ EXPECT_TRUE(_mediator.coldStart);
lpromero 2017/03/24 10:36:20 I don;t see this property on the mediator. Where i
jlebel 2017/03/24 20:59:10 Done.
+ EXPECT_EQ(nil, _mediator.userFullName);
+ EXPECT_EQ(nil, _mediator.userEmail);
+ EXPECT_EQ(nil, _mediator.userImage);
+
+ ExpectColdStartConfiguration();
+ [_mediator configureSigninPromoView:_signinPromoView];
+ CheckColdStartConfiguration();
+}
+
+TEST_F(SigninPromoViewMediatorTest,
+ WarmStartConfigureSigninPromoViewWithoutImage) {
+ _mediator.userFullName = @"John Doe";
+ _mediator.userEmail = @"johndoe@example.com";
+ EXPECT_FALSE(_mediator.coldStart);
+
+ ExpectWarmStartConfiguration();
+ [_mediator configureSigninPromoView:_signinPromoView];
+ CheckWarmStartConfiguration();
+}
+
+TEST_F(SigninPromoViewMediatorTest,
+ WarmStartConfigureSigninPromoViewWithImage) {
+ _mediator.userFullName = @"John Doe";
+ _mediator.userEmail = @"johndoe@example.com";
+ _mediator.userImage = [[UIImage alloc] init];
+ EXPECT_FALSE(_mediator.coldStart);
+
+ ExpectWarmStartConfiguration();
+ [_mediator configureSigninPromoView:_signinPromoView];
+ CheckWarmStartConfiguration();
+ EXPECT_EQ(_mediator.userImage, _imageViewProfileImage);
+}
+
+// Cold start configuration and then warm start configuration.
+TEST_F(SigninPromoViewMediatorTest, TwoConfigureSigninPromoView) {
+ ExpectColdStartConfiguration();
+ [_mediator configureSigninPromoView:_signinPromoView];
+ CheckColdStartConfiguration();
+
+ _mediator.userFullName = @"John Doe";
+ _mediator.userEmail = @"johndoe@example.com";
+
+ ExpectWarmStartConfiguration();
+ [_mediator configureSigninPromoView:_signinPromoView];
+ CheckWarmStartConfiguration();
+}
+
+} // namespace

Powered by Google App Engine
This is Rietveld 408576698