public void Test_POST_sessions_Edit_should_rediret_to_home_index() { var changePasswordViewModel = new ChangePasswordViewModel() { Password = "******", ConfirmPassword = "******" }; var userName = "******"; var controllerContext = CreateControllerContext(userName); using (var context = new HeliosDbContext()) { SaveUserInDb(context, userName, password: "******"); var mockFormsAuth = new Mock<IFormsAuthentication>(); var controller = new SessionsController(context, mockFormsAuth.Object) { ControllerContext = controllerContext }; var result = controller.Edit(changePasswordViewModel); // need to commit since we used UnitOfWorkAttribute in production context.Commit(); Assert.IsType<RedirectToRouteResult>(result); var redirectResult = result as RedirectToRouteResult; Assert.Equal("Home", (string)redirectResult.RouteValues["controller"]); Assert.Equal("Index", (string)redirectResult.RouteValues["action"]); } }
public void Test_POST_sessions_Edit_should_not_update_password_when_provide_not_match_password() { var changePasswordViewModel = new ChangePasswordViewModel() { Password = "******", ConfirmPassword = "******" }; var userName = "******"; var controllerContext = CreateControllerContext(userName); using (var context = new HeliosDbContext()) { SaveUserInDb(context, userName, password: "******"); var controller = new SessionsController(context, new Mock<IFormsAuthentication>().Object) { ControllerContext = controllerContext }; var validationResults = ModelTestHelper.ValidateModel<ChangePasswordViewModel>(changePasswordViewModel); foreach (var validationResult in validationResults) { controller.ModelState.AddModelError("*", validationResult.ErrorMessage); } var result = controller.Edit(changePasswordViewModel); // need to commit since we used UnitOfWorkAttribute in production context.Commit(); var dbUser = context.Users.FirstOrDefault(u => u.UserName == userName); Assert.NotNull(dbUser); Assert.Equal(true, dbUser.VerifyPassword("old_password")); Assert.IsType<ViewResult>(result); Assert.Equal(false, controller.ModelState.IsValid); } }
public void Test_should_set_UserPrinciple_if_User_is_authenticated() { var mockHttpContext = new Mock<HttpContextBase>(); var genericPrincipal = new GenericPrincipal(new GenericIdentity("username"), new string[]{}); mockHttpContext.SetupProperty(c => c.User, genericPrincipal); var controllerContext = new ControllerContext() { HttpContext = mockHttpContext.Object }; using (var dbContext = new HeliosDbContext()) { var dbUser = new User() { UserName = "******", IsAdmin = true }; dbUser.SetPassword("secret"); dbContext.Users.Add(dbUser); dbContext.Commit(); var stubController = new StubController(dbContext) { ControllerContext = controllerContext }; stubController.CallOnAuthorization(new AuthorizationContext() { HttpContext = controllerContext.HttpContext }); Assert.Equal(true, stubController.User is UserPrincipal); Assert.Equal("username", stubController.User.Identity.Name); Assert.Equal(true, stubController.User.IsInRole("admin")); } }
public void Test_POST_SignUp_should_create_new_user_with_RequiredToChangePassword() { var validSignUpModel = new SignUpViewModel() { UserName = "******", Password = "******", ConfirmPassword = "******" }; using (var context = new HeliosDbContext()) { var mockFormsAuth = new Mock<IFormsAuthentication>(); var controller = new UsersController(context, mockFormsAuth.Object); controller.Create(validSignUpModel); // need to commit since we used UnitOfWorkAttribute in production context.Commit(); var dbUser = context.Users.FirstOrDefault(u => u.UserName == validSignUpModel.UserName); Assert.NotNull(dbUser); Assert.Equal(true, dbUser.RequiredToChangePassword); } }
public void Test_POST_sessions_Edit_should_update_password_and_set_false_to_RequiredToChangePassword() { var changePasswordViewModel = new ChangePasswordViewModel() { Password = "******", ConfirmPassword = "******" }; var userName = "******"; var controllerContext = CreateControllerContext(userName); using (var context = new HeliosDbContext()) { SaveUserInDb(context, userName, password: "******", requiredToChangePassword: true); var mockFormsAuth = new Mock<IFormsAuthentication>(); var controller = new SessionsController(context, mockFormsAuth.Object) { ControllerContext = controllerContext }; controller.Edit(changePasswordViewModel); // need to commit since we used UnitOfWorkAttribute in production context.Commit(); var dbUser = context.Users.FirstOrDefault(u => u.UserName == userName); Assert.NotNull(dbUser); Assert.Equal(true, dbUser.VerifyPassword(changePasswordViewModel.Password)); Assert.Equal(false, dbUser.RequiredToChangePassword); } }
private static void SaveUserInDb(HeliosDbContext context, string userName, string password, bool requiredToChangePassword = false) { var dbUser = new User() { UserName = userName, RequiredToChangePassword = requiredToChangePassword }; dbUser.SetPassword(password); context.Users.Add(dbUser); context.Commit(); }