 Chromium Code Reviews
 Chromium Code Reviews Issue 2749703003:
  Adding mediator for Sign-in promo  (Closed)
    
  
    Issue 2749703003:
  Adding mediator for Sign-in promo  (Closed) 
  | 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 |