Exemplo n.º 1
0
        public void IsValid_WhenUser_IsFound_ByUserLoginInfo()
        {
            var loginProvider = FakeData.String();
            var providerKey   = FakeData.String();
            var queries       = new Mock <IProcessQueries>(MockBehavior.Strict);
            var command       = new FakeMustFindUserByLoginProviderKeyCommand
            {
                LoginProvider = loginProvider,
                ProviderKey   = providerKey,
            };
            var user = new ProxiedUser(FakeData.Id());

            user.RemoteMemberships.Add(new ProxiedRemoteMembership(loginProvider, providerKey)
            {
                User   = user,
                UserId = user.Id,
            });
            Expression <Func <UserBy, bool> > expectedQuery = x => x.UserLoginInfo.LoginProvider == loginProvider &&
                                                              x.UserLoginInfo.ProviderKey == providerKey;

            queries.Setup(x => x.Execute(It.Is(expectedQuery))).Returns(Task.FromResult(user as User));
            var validator = new FakeMustFindUserByLoginProviderKeyValidator(queries.Object);

            var result = validator.Validate(command);

            result.IsValid.ShouldBeTrue();
            queries.Verify(x => x.Execute(It.Is(expectedQuery)), Times.Once);
            validator.ShouldNotHaveValidationErrorFor(x => x.ProviderKey, command);
            queries.Verify(x => x.Execute(It.Is(expectedQuery)), Times.Exactly(2));
        }
Exemplo n.º 2
0
        public void IsInvalid_WhenUser_IsNotFound_ByUserLoginInfo()
        {
            var loginProvider = FakeData.String();
            var providerKey   = FakeData.String();
            var queries       = new Mock <IProcessQueries>(MockBehavior.Strict);
            var command       = new FakeMustFindUserByLoginProviderKeyCommand
            {
                LoginProvider = loginProvider,
                ProviderKey   = providerKey,
            };
            Expression <Func <UserBy, bool> > expectedQuery = x => x.UserLoginInfo.LoginProvider == loginProvider &&
                                                              x.UserLoginInfo.ProviderKey == providerKey;

            queries.Setup(x => x.Execute(It.Is(expectedQuery))).Returns(Task.FromResult(null as User));
            var validator = new FakeMustFindUserByLoginProviderKeyValidator(queries.Object);

            var result = validator.Validate(command);

            result.IsValid.ShouldBeFalse();
            Func <ValidationFailure, bool> emailIdError = x => x.PropertyName == command.PropertyName(y => y.ProviderKey);

            result.Errors.Count(emailIdError).ShouldEqual(1);
            result.Errors.Single(emailIdError).ErrorMessage.ShouldEqual(Resources.Validation_NoUserByLoginProviderKey
                                                                        .Replace("{PropertyName}", RemoteMembership.Constraints.ProviderUserIdLabel)
                                                                        );
            queries.Verify(x => x.Execute(It.Is(expectedQuery)), Times.Once);
            validator.ShouldHaveValidationErrorFor(x => x.ProviderKey, command);
            queries.Verify(x => x.Execute(It.Is(expectedQuery)), Times.Exactly(2));
        }