2018-09-19 15:54:24 +02:00
|
|
|
package sonia.scm.it;
|
|
|
|
|
|
|
|
|
|
import org.junit.Assert;
|
|
|
|
|
import org.junit.Before;
|
|
|
|
|
import org.junit.Test;
|
|
|
|
|
import sonia.scm.it.utils.ScmRequests;
|
|
|
|
|
import sonia.scm.it.utils.TestData;
|
|
|
|
|
|
|
|
|
|
import static org.assertj.core.api.Assertions.assertThat;
|
|
|
|
|
|
|
|
|
|
public class UserITCase {
|
|
|
|
|
|
|
|
|
|
@Before
|
|
|
|
|
public void init(){
|
|
|
|
|
TestData.cleanup();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
public void adminShouldChangeOwnPassword() {
|
2018-09-20 11:51:10 +02:00
|
|
|
String newUser = "user";
|
|
|
|
|
String password = "pass";
|
|
|
|
|
TestData.createUser(newUser, password, true, "xml");
|
|
|
|
|
String newPassword = "new_password";
|
2018-09-19 15:54:24 +02:00
|
|
|
// admin change the own password
|
|
|
|
|
ScmRequests.start()
|
|
|
|
|
.given()
|
2018-09-20 11:51:10 +02:00
|
|
|
.url(TestData.getUserUrl(newUser))
|
|
|
|
|
.usernameAndPassword(newUser, password)
|
2018-09-19 15:54:24 +02:00
|
|
|
.getUserResource()
|
|
|
|
|
.assertStatusCode(200)
|
|
|
|
|
.usingUserResponse()
|
|
|
|
|
.assertAdmin(aBoolean -> assertThat(aBoolean).isEqualTo(Boolean.TRUE))
|
|
|
|
|
.assertPassword(Assert::assertNull)
|
2018-10-16 10:47:52 +02:00
|
|
|
.requestChangePassword(password, newPassword) // the oldPassword is needed when the own password should be changed
|
2018-09-19 15:54:24 +02:00
|
|
|
.assertStatusCode(204);
|
2018-09-20 11:51:10 +02:00
|
|
|
// assert password is changed -> login with the new Password
|
2018-09-19 15:54:24 +02:00
|
|
|
ScmRequests.start()
|
|
|
|
|
.given()
|
2018-09-20 11:51:10 +02:00
|
|
|
.url(TestData.getUserUrl(newUser))
|
|
|
|
|
.usernameAndPassword(newUser, newPassword)
|
2018-09-19 15:54:24 +02:00
|
|
|
.getUserResource()
|
|
|
|
|
.assertStatusCode(200)
|
|
|
|
|
.usingUserResponse()
|
2018-09-20 11:51:10 +02:00
|
|
|
.assertAdmin(isAdmin -> assertThat(isAdmin).isEqualTo(Boolean.TRUE))
|
|
|
|
|
.assertPassword(Assert::assertNull);
|
2018-09-19 15:54:24 +02:00
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
public void adminShouldChangePasswordOfOtherUser() {
|
|
|
|
|
String newUser = "user";
|
|
|
|
|
String password = "pass";
|
|
|
|
|
TestData.createUser(newUser, password, true, "xml");
|
|
|
|
|
String newPassword = "new_password";
|
|
|
|
|
// admin change the password of the user
|
|
|
|
|
ScmRequests.start()
|
|
|
|
|
.given()
|
|
|
|
|
.url(TestData.getUserUrl(newUser))// the admin get the user object
|
|
|
|
|
.usernameAndPassword(TestData.USER_SCM_ADMIN, TestData.USER_SCM_ADMIN)
|
|
|
|
|
.getUserResource()
|
|
|
|
|
.assertStatusCode(200)
|
|
|
|
|
.usingUserResponse()
|
2018-10-16 10:47:52 +02:00
|
|
|
.assertAdmin(aBoolean -> assertThat(aBoolean).isEqualTo(Boolean.TRUE))
|
2018-09-19 15:54:24 +02:00
|
|
|
.assertPassword(Assert::assertNull)
|
|
|
|
|
.requestChangePassword(newPassword) // the oldPassword is not needed in the user resource
|
|
|
|
|
.assertStatusCode(204);
|
|
|
|
|
// assert password is changed
|
|
|
|
|
ScmRequests.start()
|
|
|
|
|
.given()
|
|
|
|
|
.url(TestData.getUserUrl(newUser))
|
|
|
|
|
.usernameAndPassword(newUser, newPassword)
|
|
|
|
|
.getUserResource()
|
|
|
|
|
.assertStatusCode(200);
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
2018-10-12 15:20:58 +02:00
|
|
|
@Test
|
2018-10-16 10:47:52 +02:00
|
|
|
public void nonAdminUserShouldNotChangePasswordOfOtherUser() {
|
|
|
|
|
String user = "user";
|
|
|
|
|
String password = "pass";
|
|
|
|
|
TestData.createUser(user, password, false, "xml");
|
|
|
|
|
String user2 = "user2";
|
|
|
|
|
TestData.createUser(user2, password, false, "xml");
|
|
|
|
|
ScmRequests.start()
|
|
|
|
|
.given()
|
|
|
|
|
.url(TestData.getUserUrl(user2))
|
|
|
|
|
.usernameAndPassword(user, password)
|
|
|
|
|
.getUserResource()
|
|
|
|
|
.assertStatusCode(403);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
2018-10-12 15:20:58 +02:00
|
|
|
public void nonAdminUserShouldChangeOwnPassword() {
|
|
|
|
|
String newUser = "user";
|
|
|
|
|
String password = "pass";
|
|
|
|
|
TestData.createUser(newUser, password, false, "xml");
|
|
|
|
|
String newPassword = "new_password";
|
|
|
|
|
ScmRequests.start()
|
|
|
|
|
.given()
|
|
|
|
|
.url(TestData.getUserUrl(newUser))
|
|
|
|
|
.usernameAndPassword(newUser, password)
|
|
|
|
|
.getUserResource()
|
|
|
|
|
.assertStatusCode(200)
|
|
|
|
|
.usingUserResponse()
|
|
|
|
|
.assertAdmin(aBoolean -> assertThat(aBoolean).isEqualTo(Boolean.FALSE))
|
2018-10-16 10:47:52 +02:00
|
|
|
.requestChangePassword(password, newPassword) // the oldPassword is needed when the own password should be changed
|
2018-10-12 15:20:58 +02:00
|
|
|
.assertStatusCode(204);
|
|
|
|
|
// assert password is changed -> login with the new Password
|
|
|
|
|
ScmRequests.start()
|
|
|
|
|
.given()
|
|
|
|
|
.url(TestData.getUserUrl(newUser))
|
|
|
|
|
.usernameAndPassword(newUser, newPassword)
|
|
|
|
|
.getUserResource()
|
|
|
|
|
.assertStatusCode(200)
|
|
|
|
|
.usingUserResponse()
|
|
|
|
|
.assertAdmin(isAdmin -> assertThat(isAdmin).isEqualTo(Boolean.FALSE))
|
|
|
|
|
.assertPassword(Assert::assertNull);
|
|
|
|
|
}
|
2018-09-19 15:54:24 +02:00
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
public void shouldHidePasswordLinkIfUserTypeIsNotXML() {
|
|
|
|
|
String newUser = "user";
|
|
|
|
|
String password = "pass";
|
|
|
|
|
String type = "not XML Type";
|
|
|
|
|
TestData.createUser(newUser, password, true, type);
|
|
|
|
|
ScmRequests.start()
|
|
|
|
|
.given()
|
|
|
|
|
.url(TestData.getMeUrl())
|
|
|
|
|
.usernameAndPassword(newUser, password)
|
|
|
|
|
.getUserResource()
|
|
|
|
|
.assertStatusCode(200)
|
|
|
|
|
.usingUserResponse()
|
|
|
|
|
.assertAdmin(aBoolean -> assertThat(aBoolean).isEqualTo(Boolean.TRUE))
|
|
|
|
|
.assertPassword(Assert::assertNull)
|
|
|
|
|
.assertType(s -> assertThat(s).isEqualTo(type))
|
|
|
|
|
.assertPasswordLinkDoesNotExists();
|
|
|
|
|
}
|
|
|
|
|
}
|