public async Task Can_register_as_Customer_and_send_email() { // arrange var company = CompanyBuilder.Create().WithName("test company").Build(ArrangeRepositoryContext); var dto = new Register.Command("*****@*****.**", "test pass", "", "", company.Id); var controller = new AuthorizationController(Mediator); // act var result = await controller.RegisterAsync(dto); // assert result.Should().NotBeNullOrWhiteSpace(); var subject = AssertRepositoryContext.Users.FirstOrDefault(); subject.Should().NotBeNull(); subject.Roles.Should().Be(UserRole.Customer); subject.Email.Should().Be(dto.Email); subject.Password.Text.Should().NotBeNullOrWhiteSpace(); subject.Password.Salt.Should().NotBeNullOrWhiteSpace(); subject.IsActive.Should().BeFalse(); subject.IsRemoved.Should().BeFalse(); subject.PermissionsToken.Token.Should().NotBeNullOrEmpty(); subject.PermissionsToken.Expiration.Should().BeAfter(DateTime.Now); subject.PermissionsToken.Expiration.Should().BeBefore(DateTime.Now.AddDays(2)); MailerMock.Verify(mock => mock.SendAsync(It.Is <string>(x => x == dto.Email), It.IsAny <string>(), It.Is <string>(x => x.Contains(subject.PermissionsToken.Token)), false), Times.Once); MailerMock.VerifyNoOtherCalls(); }
public async Task ResetPassword_Should_change_password_and_reset_pemisiontoken() { // arrange var user = UserBuilder.Create() .WithEmail(HealthyJuicesConstants.DEFAULT_USER_LOGIN) .WithPassword(RandomString) .WithPermissionsToken(RandomString, DateTime.Today.AddDays(1)) .Active() .Build(ArrangeRepositoryContext); var controller = new AuthorizationController(Mediator); var newPass = "******"; var dto = new ResetPassword.Command(HealthyJuicesConstants.DEFAULT_USER_LOGIN, user.PermissionsToken.Token, newPass); // act await controller.ResetPasswordAsync(dto); // assert var subject = AssertRepositoryContext.Users.FirstOrDefault(); subject.Should().NotBeNull(); subject.Password.Salt.Should().NotBe(user.Password.Salt); subject.Password.Salt.Should().NotBe(user.Password.Text); subject.Password.CheckValidity(newPass).Should().BeTrue(); subject.IsActive.Should().BeTrue(); subject.PermissionsToken.Should().BeNull(); MailerMock.VerifyNoOtherCalls(); }
public async Task ForgotPassword_Should_save_new_token_and_send_email() { // arrange var user = UserBuilder.Create().WithRole(UserRole.Customer).WithEmail(HealthyJuicesConstants.DEFAULT_USER_LOGIN).WithPassword(HealthyJuicesConstants.DEFAULT_USER_PASSWORD).Build(ArrangeRepositoryContext); var controller = new AuthorizationController(Mediator); var dto = new ForgotPassword.Command(HealthyJuicesConstants.DEFAULT_USER_LOGIN); // act await controller.ForgotPasswordAsync(dto); // assert var subject = AssertRepositoryContext.Users.FirstOrDefault(); subject.Should().NotBeNull(); subject.PermissionsToken.Token.Should().NotBeNullOrEmpty(); subject.PermissionsToken.Expiration.Should().BeAfter(DateTime.Now); subject.PermissionsToken.Expiration.Should().BeBefore(DateTime.Now.AddDays(2)); MailerMock.Verify(mock => mock.SendAsync(It.Is <string>(x => x == HealthyJuicesConstants.DEFAULT_USER_LOGIN), It.IsAny <string>(), It.Is <string>(x => x.Contains(subject.PermissionsToken.Token)), false), Times.Once); MailerMock.VerifyNoOtherCalls(); }