本文整理匯總了Java中org.cloudfoundry.identity.uaa.scim.ScimUser.setId方法的典型用法代碼示例。如果您正苦於以下問題:Java ScimUser.setId方法的具體用法?Java ScimUser.setId怎麽用?Java ScimUser.setId使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類org.cloudfoundry.identity.uaa.scim.ScimUser
的用法示例。
在下文中一共展示了ScimUser.setId方法的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: test_addOrgUser_userExists
import org.cloudfoundry.identity.uaa.scim.ScimUser; //導入方法依賴的package包/類
@Test
public void test_addOrgUser_userExists() {
List<Role> roles = Collections.singletonList(Role.MANAGERS);
UUID orgGuid = UUID.randomUUID();
UUID userGuid = UUID.randomUUID();
User expectedUser = new User("testuser", userGuid, roles, orgGuid);
String password = "testpassword";
UserRequest cfCreateUser = new UserRequest(expectedUser.getUsername());
cfCreateUser.setRoles(roles);
ScimUser scimUser = ScimUserFactory.newUser(expectedUser.getUsername(), password);
scimUser.setId(expectedUser.getGuid().toString());
UserIdNamePair idNamePair = UserIdNamePair.of(
expectedUser.getGuid(),
expectedUser.getUsername());
when(uaaOperations.findUserIdByName(expectedUser.getUsername())).thenReturn(Optional.ofNullable(idNamePair));
when(uaaOperations.createUser(expectedUser.getUsername(), password)).thenReturn(scimUser);
CfUsersService cfUsersService =
new CfUsersService(ccClient, uaaOperations, invitationService, accessInvitationsService);
Optional<User> resultUser = cfUsersService.addOrgUser(cfCreateUser, orgGuid, "admin_test");
assertThat(resultUser.get(), equalTo(expectedUser));
verify(ccClient).assignOrgRole(eq(userGuid), eq(orgGuid), eq(roles.get(0)));
}
示例2: testSave
import org.cloudfoundry.identity.uaa.scim.ScimUser; //導入方法依賴的package包/類
@Test
public void testSave() throws Exception {
// Arrange
final String id = "id";
final ScimUser scimUser = new ScimUser();
final ScimUser scimUserResponse = new ScimUser();
scimUserResponse.setId(id);
when(restTemplate.postForObject(usersEndpoint, scimUser, ScimUser.class)).thenReturn(scimUserResponse);
// Act
final ScimUser response = sut.save(scimUser);
// Assert
assertEquals(scimUserResponse, response);
}
示例3: testActivateUser
import org.cloudfoundry.identity.uaa.scim.ScimUser; //導入方法依賴的package包/類
@Test
public void testActivateUser() throws Exception {
// Arrange
final Long patientId = 10L;
final Boolean initialVerified = false;
final Boolean verified = true;
final Instant emailTokenExpiration = Instant.now().plus(Period.ofDays(7));
final String verificationCode = "verificationCode";
final String emailToken = "emailToken";
final String firstName = "firstName";
final String lastName = "lastName";
final String email = "email";
final String username = "email";
final String password = "password";
final String confirmPassword = "password";
final String userId = "userId";
final LocalDate birthDateInRequest = LocalDate.of(1980, 1, 1);
final Date birthDateInPhr = Date.from(birthDateInRequest.atStartOfDay(ZoneId.systemDefault()).toInstant());
UserActivationRequestDto userActivationRequest = mock(UserActivationRequestDto.class);
when(userActivationRequest.getVerificationCode()).thenReturn(verificationCode);
when(userActivationRequest.getEmailToken()).thenReturn(emailToken);
when(userActivationRequest.getBirthDate()).thenReturn(birthDateInRequest);
when(userActivationRequest.getPassword()).thenReturn(password);
when(userActivationRequest.getConfirmPassword()).thenReturn(confirmPassword);
when(userActivationRequest.getUsername()).thenReturn(username);
final UserCreation userCreation = mock(UserCreation.class);
when(userCreation.isVerified()).thenReturn(initialVerified).thenReturn(verified);
when(userCreation.getEmailTokenExpirationAsInstant()).thenReturn(emailTokenExpiration);
when(userCreation.getPatientId()).thenReturn(patientId);
when(userCreationRepository.findOneByEmailTokenAndVerificationCode(emailToken, verificationCode)).thenReturn(Optional.of(userCreation));
final PatientDto patientDto = mock(PatientDto.class);
when(patientDto.getBirthDate()).thenReturn(birthDateInPhr);
when(patientDto.getFirstName()).thenReturn(firstName);
when(patientDto.getLastName()).thenReturn(lastName);
when(patientDto.getEmail()).thenReturn(email);
when(phrService.findPatientProfileById(patientId, true)).thenReturn(patientDto);
final UserActivationResponseDto userActivationResponse = mock(UserActivationResponseDto.class);
when(modelMapper.map(patientDto, UserActivationResponseDto.class)).thenReturn(userActivationResponse);
final ScimUser savedScimUser = new ScimUser();
savedScimUser.setId(userId);
when(scimService.save(argThat(matching(
user -> user.getEmails().get(0).getValue().equals(email) &&
user.getUserName().equals(email) &&
user.isVerified() == verified &&
user.getFamilyName().equals(lastName) &&
user.getGivenName().equals(firstName)
)))).thenReturn(savedScimUser);
// Act
final UserActivationResponseDto response = sut.activateUser(userActivationRequest, xForwardedProto, xForwardedHost, xForwardedPort);
// Assert
assertEquals(userActivationResponse, response);
verify(userCreation, times(1)).setVerified(verified);
verify(userCreation, times(1)).setUserId(userId);
verify(userActivationResponse, times(1)).setVerified(verified);
verify(userCreationRepository, times(2)).save(userCreation);
verify(scimService, times(1)).save(argThat(matching(
user -> user.getEmails().get(0).getValue().equals(email) &&
user.getUserName().equals(email) &&
user.isVerified() == true &&
user.getFamilyName().equals(lastName) &&
user.getGivenName().equals(firstName)
)));
verify(scimService, times(1)).addUserToGroups(userCreation);
verify(emailSender, times(1)).sendEmailToConfirmVerification(
eq(xForwardedProto), eq(xForwardedHost), eq(xForwardedPort),
eq(email), argThat(matching(fn -> fn.contains(firstName) && fn.contains(lastName))));
}
示例4: mock
import org.cloudfoundry.identity.uaa.scim.ScimUser; //導入方法依賴的package包/類
@Test
public void testActivateUser_Throws_UserActivationCannotBeVerifiedException_When_Username_Does_Not_Match_Email_In_PHR() throws Exception {
// Arrange
thrown.expect(UserActivationCannotBeVerifiedException.class);
final Long patientId = 10L;
final Boolean initialVerified = false;
final Boolean verified = true;
final Instant emailTokenExpiration = Instant.now().plus(Period.ofDays(7));
final String verificationCode = "verificationCode";
final String emailToken = "emailToken";
final String firstName = "firstName";
final String lastName = "lastName";
final String email = "email";
final String username = "emailDifferent";
final String password = "password";
final String confirmPassword = "password";
final String userId = "userId";
final LocalDate birthDateInRequest = LocalDate.of(1980, 1, 1);
final Date birthDateInPhr = Date.from(birthDateInRequest.atStartOfDay(ZoneId.systemDefault()).toInstant());
UserActivationRequestDto userActivationRequest = mock(UserActivationRequestDto.class);
when(userActivationRequest.getVerificationCode()).thenReturn(verificationCode);
when(userActivationRequest.getEmailToken()).thenReturn(emailToken);
when(userActivationRequest.getBirthDate()).thenReturn(birthDateInRequest);
when(userActivationRequest.getPassword()).thenReturn(password);
when(userActivationRequest.getConfirmPassword()).thenReturn(confirmPassword);
when(userActivationRequest.getUsername()).thenReturn(username);
final UserCreation userCreation = mock(UserCreation.class);
when(userCreation.isVerified()).thenReturn(initialVerified).thenReturn(verified);
when(userCreation.getEmailTokenExpirationAsInstant()).thenReturn(emailTokenExpiration);
when(userCreation.getPatientId()).thenReturn(patientId);
when(userCreationRepository.findOneByEmailTokenAndVerificationCode(emailToken, verificationCode)).thenReturn(Optional.of(userCreation));
final PatientDto patientDto = mock(PatientDto.class);
when(patientDto.getBirthDate()).thenReturn(birthDateInPhr);
when(patientDto.getFirstName()).thenReturn(firstName);
when(patientDto.getLastName()).thenReturn(lastName);
when(patientDto.getEmail()).thenReturn(email);
when(phrService.findPatientProfileById(patientId, true)).thenReturn(patientDto);
final UserActivationResponseDto userActivationResponse = mock(UserActivationResponseDto.class);
when(modelMapper.map(patientDto, UserActivationResponseDto.class)).thenReturn(userActivationResponse);
final ScimUser savedScimUser = new ScimUser();
savedScimUser.setId(userId);
when(scimService.save(argThat(matching(
user -> user.getEmails().get(0).getValue().equals(email) &&
user.getUserName().equals(email) &&
user.isVerified() == verified &&
user.getFamilyName().equals(lastName) &&
user.getGivenName().equals(firstName)
)))).thenReturn(savedScimUser);
// Act
final UserActivationResponseDto response = sut.activateUser(userActivationRequest, xForwardedProto, xForwardedHost, xForwardedPort);
// Assert
assertEquals(userActivationResponse, response);
verify(userCreation, times(1)).setVerified(verified);
verify(userCreation, times(1)).setUserId(userId);
verify(userActivationResponse, times(1)).setVerified(verified);
verify(userCreationRepository, times(2)).save(userCreation);
verify(scimService, times(1)).save(argThat(matching(
user -> user.getEmails().get(0).getValue().equals(email) &&
user.getUserName().equals(email) &&
user.isVerified() == true &&
user.getFamilyName().equals(lastName) &&
user.getGivenName().equals(firstName)
)));
verify(scimService, times(1)).addUserToGroups(userCreation);
verify(emailSender, times(1)).sendEmailToConfirmVerification(
eq(xForwardedProto), eq(xForwardedHost), eq(xForwardedPort),
eq(email), argThat(matching(fn -> fn.contains(firstName) && fn.contains(lastName))));
}
示例5: testActivateUser_Throws_PasswordConfirmationFailedException_When_Password_Confirmation_Fails
import org.cloudfoundry.identity.uaa.scim.ScimUser; //導入方法依賴的package包/類
@Test
public void testActivateUser_Throws_PasswordConfirmationFailedException_When_Password_Confirmation_Fails() throws Exception {
// Arrange
thrown.expect(PasswordConfirmationFailedException.class);
final Long patientId = 10L;
final Boolean initialVerified = false;
final Boolean verified = true;
final Instant emailTokenExpiration = Instant.now().plus(Period.ofDays(7));
final String verificationCode = "verificationCode";
final String emailToken = "emailToken";
final String firstName = "firstName";
final String lastName = "lastName";
final String email = "email";
final String password = "password";
final String confirmPassword = "confirmPassword";
final String userId = "userId";
final LocalDate birthDateInRequest = LocalDate.of(1980, 1, 1);
final Date birthDateInPhr = Date.from(birthDateInRequest.atStartOfDay(ZoneId.systemDefault()).toInstant());
UserActivationRequestDto userActivationRequest = mock(UserActivationRequestDto.class);
when(userActivationRequest.getVerificationCode()).thenReturn(verificationCode);
when(userActivationRequest.getEmailToken()).thenReturn(emailToken);
when(userActivationRequest.getBirthDate()).thenReturn(birthDateInRequest);
when(userActivationRequest.getPassword()).thenReturn(password);
when(userActivationRequest.getConfirmPassword()).thenReturn(confirmPassword);
final UserCreation userCreation = mock(UserCreation.class);
when(userCreation.isVerified()).thenReturn(initialVerified).thenReturn(verified);
when(userCreation.getEmailTokenExpirationAsInstant()).thenReturn(emailTokenExpiration);
when(userCreation.getPatientId()).thenReturn(patientId);
when(userCreationRepository.findOneByEmailTokenAndVerificationCode(emailToken, verificationCode)).thenReturn(Optional.of(userCreation));
final PatientDto patientDto = mock(PatientDto.class);
when(patientDto.getBirthDate()).thenReturn(birthDateInPhr);
when(patientDto.getFirstName()).thenReturn(firstName);
when(patientDto.getLastName()).thenReturn(lastName);
when(patientDto.getEmail()).thenReturn(email);
when(phrService.findPatientProfileById(patientId, true)).thenReturn(patientDto);
final UserActivationResponseDto userActivationResponse = mock(UserActivationResponseDto.class);
when(modelMapper.map(patientDto, UserActivationResponseDto.class)).thenReturn(userActivationResponse);
final ScimUser savedScimUser = new ScimUser();
savedScimUser.setId(userId);
when(scimService.save(argThat(matching(
user -> user.getEmails().get(0).getValue().equals(email) &&
user.getUserName().equals(email) &&
user.isVerified() == verified &&
user.getFamilyName().equals(lastName) &&
user.getGivenName().equals(firstName)
)))).thenReturn(savedScimUser);
// Act
final UserActivationResponseDto response = sut.activateUser(userActivationRequest, xForwardedProto, xForwardedHost, xForwardedPort);
// Assert
assertEquals(userActivationResponse, response);
verify(userCreation, times(1)).setVerified(verified);
verify(userCreation, times(1)).setUserId(userId);
verify(userActivationResponse, times(1)).setVerified(verified);
verify(userCreationRepository, times(2)).save(userCreation);
verify(scimService, times(1)).save(argThat(matching(
user -> user.getEmails().get(0).getValue().equals(email) &&
user.getUserName().equals(email) &&
user.isVerified() == true &&
user.getFamilyName().equals(lastName) &&
user.getGivenName().equals(firstName)
)));
verify(scimService, times(1)).addUserToGroups(userCreation);
verify(emailSender, times(1)).sendEmailToConfirmVerification(
eq(xForwardedProto), eq(xForwardedHost), eq(xForwardedPort),
eq(email), argThat(matching(fn -> fn.contains(firstName) && fn.contains(lastName))));
}
示例6: testActivateUser_Throws_UserActivationCannotBeVerifiedException_When_UserCreation_Not_Found
import org.cloudfoundry.identity.uaa.scim.ScimUser; //導入方法依賴的package包/類
@Test
public void testActivateUser_Throws_UserActivationCannotBeVerifiedException_When_UserCreation_Not_Found() throws Exception {
// Arrange
thrown.expect(UserActivationCannotBeVerifiedException.class);
final Long patientId = 10L;
final Boolean initialVerified = false;
final Boolean verified = true;
final Instant emailTokenExpiration = Instant.now().plus(Period.ofDays(7));
final String verificationCode = "verificationCode";
final String emailToken = "emailToken";
final String firstName = "firstName";
final String lastName = "lastName";
final String email = "email";
final String password = "password";
final String confirmPassword = "password";
final String userId = "userId";
final LocalDate birthDateInRequest = LocalDate.of(1980, 1, 1);
final Date birthDateInPhr = Date.from(birthDateInRequest.atStartOfDay(ZoneId.systemDefault()).toInstant());
UserActivationRequestDto userActivationRequest = mock(UserActivationRequestDto.class);
when(userActivationRequest.getVerificationCode()).thenReturn(verificationCode);
when(userActivationRequest.getEmailToken()).thenReturn(emailToken);
when(userActivationRequest.getBirthDate()).thenReturn(birthDateInRequest);
when(userActivationRequest.getPassword()).thenReturn(password);
when(userActivationRequest.getConfirmPassword()).thenReturn(confirmPassword);
final UserCreation userCreation = mock(UserCreation.class);
when(userCreation.isVerified()).thenReturn(initialVerified).thenReturn(verified);
when(userCreation.getEmailTokenExpirationAsInstant()).thenReturn(emailTokenExpiration);
when(userCreation.getPatientId()).thenReturn(patientId);
when(userCreationRepository.findOneByEmailTokenAndVerificationCode(emailToken, verificationCode)).thenReturn(Optional.empty());
final PatientDto patientDto = mock(PatientDto.class);
when(patientDto.getBirthDate()).thenReturn(birthDateInPhr);
when(patientDto.getFirstName()).thenReturn(firstName);
when(patientDto.getLastName()).thenReturn(lastName);
when(patientDto.getEmail()).thenReturn(email);
when(phrService.findPatientProfileById(patientId, true)).thenReturn(patientDto);
final UserActivationResponseDto userActivationResponse = mock(UserActivationResponseDto.class);
when(modelMapper.map(patientDto, UserActivationResponseDto.class)).thenReturn(userActivationResponse);
final ScimUser savedScimUser = new ScimUser();
savedScimUser.setId(userId);
when(scimService.save(argThat(matching(
user -> user.getEmails().get(0).getValue().equals(email) &&
user.getUserName().equals(email) &&
user.isVerified() == verified &&
user.getFamilyName().equals(lastName) &&
user.getGivenName().equals(firstName)
)))).thenReturn(savedScimUser);
// Act
final UserActivationResponseDto response = sut.activateUser(userActivationRequest, xForwardedProto, xForwardedHost, xForwardedPort);
// Assert
assertEquals(userActivationResponse, response);
verify(userCreation, times(1)).setVerified(verified);
verify(userCreation, times(1)).setUserId(userId);
verify(userActivationResponse, times(1)).setVerified(verified);
verify(userCreationRepository, times(2)).save(userCreation);
verify(scimService, times(1)).save(argThat(matching(
user -> user.getEmails().get(0).getValue().equals(email) &&
user.getUserName().equals(email) &&
user.isVerified() == true &&
user.getFamilyName().equals(lastName) &&
user.getGivenName().equals(firstName)
)));
verify(scimService, times(1)).addUserToGroups(userCreation);
verify(emailSender, times(1)).sendEmailToConfirmVerification(
eq(xForwardedProto), eq(xForwardedHost), eq(xForwardedPort),
eq(email), argThat(matching(fn -> fn.contains(firstName) && fn.contains(lastName))));
}
示例7: testActivateUser_Throws_UserIsAlreadyVerifiedException_When_User_Is_Already_Verified
import org.cloudfoundry.identity.uaa.scim.ScimUser; //導入方法依賴的package包/類
@Test
public void testActivateUser_Throws_UserIsAlreadyVerifiedException_When_User_Is_Already_Verified() throws Exception {
// Arrange
thrown.expect(UserIsAlreadyVerifiedException.class);
final Long patientId = 10L;
final Boolean initialVerified = true;
final Boolean verified = true;
final Instant emailTokenExpiration = Instant.now().plus(Period.ofDays(7));
final String verificationCode = "verificationCode";
final String emailToken = "emailToken";
final String firstName = "firstName";
final String lastName = "lastName";
final String email = "email";
final String password = "password";
final String confirmPassword = "password";
final String userId = "userId";
final LocalDate birthDateInRequest = LocalDate.of(1980, 1, 1);
final Date birthDateInPhr = Date.from(birthDateInRequest.atStartOfDay(ZoneId.systemDefault()).toInstant());
UserActivationRequestDto userActivationRequest = mock(UserActivationRequestDto.class);
when(userActivationRequest.getVerificationCode()).thenReturn(verificationCode);
when(userActivationRequest.getEmailToken()).thenReturn(emailToken);
when(userActivationRequest.getBirthDate()).thenReturn(birthDateInRequest);
when(userActivationRequest.getPassword()).thenReturn(password);
when(userActivationRequest.getConfirmPassword()).thenReturn(confirmPassword);
final UserCreation userCreation = mock(UserCreation.class);
when(userCreation.isVerified()).thenReturn(initialVerified).thenReturn(verified);
when(userCreation.getEmailTokenExpirationAsInstant()).thenReturn(emailTokenExpiration);
when(userCreation.getPatientId()).thenReturn(patientId);
when(userCreationRepository.findOneByEmailTokenAndVerificationCode(emailToken, verificationCode)).thenReturn(Optional.of(userCreation));
final PatientDto patientDto = mock(PatientDto.class);
when(patientDto.getBirthDate()).thenReturn(birthDateInPhr);
when(patientDto.getFirstName()).thenReturn(firstName);
when(patientDto.getLastName()).thenReturn(lastName);
when(patientDto.getEmail()).thenReturn(email);
when(phrService.findPatientProfileById(patientId, true)).thenReturn(patientDto);
final UserActivationResponseDto userActivationResponse = mock(UserActivationResponseDto.class);
when(modelMapper.map(patientDto, UserActivationResponseDto.class)).thenReturn(userActivationResponse);
final ScimUser savedScimUser = new ScimUser();
savedScimUser.setId(userId);
when(scimService.save(argThat(matching(
user -> user.getEmails().get(0).getValue().equals(email) &&
user.getUserName().equals(email) &&
user.isVerified() == verified &&
user.getFamilyName().equals(lastName) &&
user.getGivenName().equals(firstName)
)))).thenReturn(savedScimUser);
// Act
final UserActivationResponseDto response = sut.activateUser(userActivationRequest, xForwardedProto, xForwardedHost, xForwardedPort);
// Assert
assertEquals(userActivationResponse, response);
verify(userCreation, times(1)).setVerified(verified);
verify(userCreation, times(1)).setUserId(userId);
verify(userActivationResponse, times(1)).setVerified(verified);
verify(userCreationRepository, times(2)).save(userCreation);
verify(scimService, times(1)).save(argThat(matching(
user -> user.getEmails().get(0).getValue().equals(email) &&
user.getUserName().equals(email) &&
user.isVerified() == true &&
user.getFamilyName().equals(lastName) &&
user.getGivenName().equals(firstName)
)));
verify(scimService, times(1)).addUserToGroups(userCreation);
verify(emailSender, times(1)).sendEmailToConfirmVerification(
eq(xForwardedProto), eq(xForwardedHost), eq(xForwardedPort),
eq(email), argThat(matching(fn -> fn.contains(firstName) && fn.contains(lastName))));
}
示例8: testActivateUser_Throws_EmailTokenExpiredException_When_Email_Token_Already_Expired
import org.cloudfoundry.identity.uaa.scim.ScimUser; //導入方法依賴的package包/類
@Test
public void testActivateUser_Throws_EmailTokenExpiredException_When_Email_Token_Already_Expired() throws Exception {
// Arrange
thrown.expect(EmailTokenExpiredException.class);
final Long patientId = 10L;
final Boolean initialVerified = false;
final Boolean verified = true;
final Instant emailTokenExpiration = Instant.now().minus(Period.ofDays(7));
final String verificationCode = "verificationCode";
final String emailToken = "emailToken";
final String firstName = "firstName";
final String lastName = "lastName";
final String email = "email";
final String password = "password";
final String confirmPassword = "password";
final String userId = "userId";
final LocalDate birthDateInRequest = LocalDate.of(1980, 1, 1);
final Date birthDateInPhr = Date.from(birthDateInRequest.atStartOfDay(ZoneId.systemDefault()).toInstant());
UserActivationRequestDto userActivationRequest = mock(UserActivationRequestDto.class);
when(userActivationRequest.getVerificationCode()).thenReturn(verificationCode);
when(userActivationRequest.getEmailToken()).thenReturn(emailToken);
when(userActivationRequest.getBirthDate()).thenReturn(birthDateInRequest);
when(userActivationRequest.getPassword()).thenReturn(password);
when(userActivationRequest.getConfirmPassword()).thenReturn(confirmPassword);
final UserCreation userCreation = mock(UserCreation.class);
when(userCreation.isVerified()).thenReturn(initialVerified).thenReturn(verified);
when(userCreation.getEmailTokenExpirationAsInstant()).thenReturn(emailTokenExpiration);
when(userCreation.getPatientId()).thenReturn(patientId);
when(userCreationRepository.findOneByEmailTokenAndVerificationCode(emailToken, verificationCode)).thenReturn(Optional.of(userCreation));
final PatientDto patientDto = mock(PatientDto.class);
when(patientDto.getBirthDate()).thenReturn(birthDateInPhr);
when(patientDto.getFirstName()).thenReturn(firstName);
when(patientDto.getLastName()).thenReturn(lastName);
when(patientDto.getEmail()).thenReturn(email);
when(phrService.findPatientProfileById(patientId, true)).thenReturn(patientDto);
final UserActivationResponseDto userActivationResponse = mock(UserActivationResponseDto.class);
when(modelMapper.map(patientDto, UserActivationResponseDto.class)).thenReturn(userActivationResponse);
final ScimUser savedScimUser = new ScimUser();
savedScimUser.setId(userId);
when(scimService.save(argThat(matching(
user -> user.getEmails().get(0).getValue().equals(email) &&
user.getUserName().equals(email) &&
user.isVerified() == verified &&
user.getFamilyName().equals(lastName) &&
user.getGivenName().equals(firstName)
)))).thenReturn(savedScimUser);
// Act
final UserActivationResponseDto response = sut.activateUser(userActivationRequest, xForwardedProto, xForwardedHost, xForwardedPort);
// Assert
assertEquals(userActivationResponse, response);
verify(userCreation, times(1)).setVerified(verified);
verify(userCreation, times(1)).setUserId(userId);
verify(userActivationResponse, times(1)).setVerified(verified);
verify(userCreationRepository, times(2)).save(userCreation);
verify(scimService, times(1)).save(argThat(matching(
user -> user.getEmails().get(0).getValue().equals(email) &&
user.getUserName().equals(email) &&
user.isVerified() == true &&
user.getFamilyName().equals(lastName) &&
user.getGivenName().equals(firstName)
)));
verify(scimService, times(1)).addUserToGroups(userCreation);
verify(emailSender, times(1)).sendEmailToConfirmVerification(
eq(xForwardedProto), eq(xForwardedHost), eq(xForwardedPort),
eq(email), argThat(matching(fn -> fn.contains(firstName) && fn.contains(lastName))));
}
示例9: testActivateUser_Throws_UserActivationCannotBeVerifiedException_When_Birth_Date_Verification_Failed
import org.cloudfoundry.identity.uaa.scim.ScimUser; //導入方法依賴的package包/類
@Test
public void testActivateUser_Throws_UserActivationCannotBeVerifiedException_When_Birth_Date_Verification_Failed() throws Exception {
// Arrange
thrown.expect(UserActivationCannotBeVerifiedException.class);
final Long patientId = 10L;
final Boolean initialVerified = false;
final Boolean verified = true;
final Instant emailTokenExpiration = Instant.now().plus(Period.ofDays(7));
final String verificationCode = "verificationCode";
final String emailToken = "emailToken";
final String firstName = "firstName";
final String lastName = "lastName";
final String email = "email";
final String password = "password";
final String confirmPassword = "password";
final String userId = "userId";
final LocalDate birthDateInRequest = LocalDate.of(1980, 1, 1);
final Date birthDateInPhr = Date.from(birthDateInRequest.minus(Period.ofDays(1)).atStartOfDay(ZoneId.systemDefault()).toInstant());
UserActivationRequestDto userActivationRequest = mock(UserActivationRequestDto.class);
when(userActivationRequest.getVerificationCode()).thenReturn(verificationCode);
when(userActivationRequest.getEmailToken()).thenReturn(emailToken);
when(userActivationRequest.getBirthDate()).thenReturn(birthDateInRequest);
when(userActivationRequest.getPassword()).thenReturn(password);
when(userActivationRequest.getConfirmPassword()).thenReturn(confirmPassword);
final UserCreation userCreation = mock(UserCreation.class);
when(userCreation.isVerified()).thenReturn(initialVerified).thenReturn(verified);
when(userCreation.getEmailTokenExpirationAsInstant()).thenReturn(emailTokenExpiration);
when(userCreation.getPatientId()).thenReturn(patientId);
when(userCreationRepository.findOneByEmailTokenAndVerificationCode(emailToken, verificationCode)).thenReturn(Optional.of(userCreation));
final PatientDto patientDto = mock(PatientDto.class);
when(patientDto.getBirthDate()).thenReturn(birthDateInPhr);
when(patientDto.getFirstName()).thenReturn(firstName);
when(patientDto.getLastName()).thenReturn(lastName);
when(patientDto.getEmail()).thenReturn(email);
when(phrService.findPatientProfileById(patientId, true)).thenReturn(patientDto);
final UserActivationResponseDto userActivationResponse = mock(UserActivationResponseDto.class);
when(modelMapper.map(patientDto, UserActivationResponseDto.class)).thenReturn(userActivationResponse);
final ScimUser savedScimUser = new ScimUser();
savedScimUser.setId(userId);
when(scimService.save(argThat(matching(
user -> user.getEmails().get(0).getValue().equals(email) &&
user.getUserName().equals(email) &&
user.isVerified() == verified &&
user.getFamilyName().equals(lastName) &&
user.getGivenName().equals(firstName)
)))).thenReturn(savedScimUser);
// Act
final UserActivationResponseDto response = sut.activateUser(userActivationRequest, xForwardedProto, xForwardedHost, xForwardedPort);
// Assert
assertEquals(userActivationResponse, response);
verify(userCreation, times(1)).setVerified(verified);
verify(userCreation, times(1)).setUserId(userId);
verify(userActivationResponse, times(1)).setVerified(verified);
verify(userCreationRepository, times(2)).save(userCreation);
verify(scimService, times(1)).save(argThat(matching(
user -> user.getEmails().get(0).getValue().equals(email) &&
user.getUserName().equals(email) &&
user.isVerified() == true &&
user.getFamilyName().equals(lastName) &&
user.getGivenName().equals(firstName)
)));
verify(scimService, times(1)).addUserToGroups(userCreation);
verify(emailSender, times(1)).sendEmailToConfirmVerification(
eq(xForwardedProto), eq(xForwardedHost), eq(xForwardedPort),
eq(email), argThat(matching(fn -> fn.contains(firstName) && fn.contains(lastName))));
}