mirror of
https://github.com/scm-manager/scm-manager.git
synced 2025-11-10 23:45:44 +01:00
Split up test methods for each user
This commit is contained in:
@@ -53,6 +53,7 @@ import static org.junit.Assert.assertEquals;
|
|||||||
import static sonia.scm.it.RepositoryUtil.addAndCommitRandomFile;
|
import static sonia.scm.it.RepositoryUtil.addAndCommitRandomFile;
|
||||||
import static sonia.scm.it.RestUtil.given;
|
import static sonia.scm.it.RestUtil.given;
|
||||||
import static sonia.scm.it.ScmTypes.availableScmTypes;
|
import static sonia.scm.it.ScmTypes.availableScmTypes;
|
||||||
|
import static sonia.scm.it.TestData.callUserPermissions;
|
||||||
|
|
||||||
@RunWith(Parameterized.class)
|
@RunWith(Parameterized.class)
|
||||||
public class PermissionsITCase {
|
public class PermissionsITCase {
|
||||||
@@ -61,6 +62,7 @@ public class PermissionsITCase {
|
|||||||
public static final String USER_PASS = "pass";
|
public static final String USER_PASS = "pass";
|
||||||
private static final String USER_WRITE = "user_write";
|
private static final String USER_WRITE = "user_write";
|
||||||
private static final String USER_OWNER = "user_owner";
|
private static final String USER_OWNER = "user_owner";
|
||||||
|
private static final String USER_OTHER = "user_other";
|
||||||
|
|
||||||
@Rule
|
@Rule
|
||||||
public TemporaryFolder temporaryFolder = new TemporaryFolder();
|
public TemporaryFolder temporaryFolder = new TemporaryFolder();
|
||||||
@@ -87,29 +89,56 @@ public class PermissionsITCase {
|
|||||||
TestData.createUserPermission(USER_WRITE, PermissionType.WRITE, repositoryType);
|
TestData.createUserPermission(USER_WRITE, PermissionType.WRITE, repositoryType);
|
||||||
TestData.createUser(USER_OWNER, USER_PASS);
|
TestData.createUser(USER_OWNER, USER_PASS);
|
||||||
TestData.createUserPermission(USER_OWNER, PermissionType.OWNER, repositoryType);
|
TestData.createUserPermission(USER_OWNER, PermissionType.OWNER, repositoryType);
|
||||||
|
TestData.createUser(USER_OTHER, USER_PASS);
|
||||||
createdPermissions = 3;
|
createdPermissions = 3;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void everyUserShouldSeePermissions() {
|
public void readUserShouldSeePermissions() {
|
||||||
List<Object> userPermissions = TestData.getUserPermissions(USER_READ, USER_PASS, repositoryType);
|
List<Object> userPermissions = TestData.getUserPermissions(USER_READ, USER_PASS, repositoryType);
|
||||||
assertEquals(userPermissions.size(), createdPermissions);
|
assertEquals(userPermissions.size(), createdPermissions);
|
||||||
userPermissions = TestData.getUserPermissions(USER_WRITE, USER_PASS, repositoryType);
|
|
||||||
assertEquals(userPermissions.size(), createdPermissions);
|
|
||||||
userPermissions = TestData.getUserPermissions(USER_OWNER, USER_PASS, repositoryType);
|
|
||||||
assertEquals(userPermissions.size(), createdPermissions);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void everyUserShouldCloneRepository() throws IOException {
|
public void writeUserShouldSeePermissions() {
|
||||||
|
List<Object> userPermissions = TestData.getUserPermissions(USER_WRITE, USER_PASS, repositoryType);
|
||||||
|
assertEquals(userPermissions.size(), createdPermissions);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void ownerShouldSeePermissions() {
|
||||||
|
List<Object> userPermissions = TestData.getUserPermissions(USER_OWNER, USER_PASS, repositoryType);
|
||||||
|
assertEquals(userPermissions.size(), createdPermissions);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void otherUserShouldNotSeePermissions() {
|
||||||
|
callUserPermissions(USER_OTHER, USER_PASS, repositoryType, HttpStatus.SC_FORBIDDEN);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void readUserShouldCloneRepository() throws IOException {
|
||||||
RepositoryClient client = RepositoryUtil.createRepositoryClient(repositoryType, temporaryFolder.newFolder(), USER_READ, USER_PASS);
|
RepositoryClient client = RepositoryUtil.createRepositoryClient(repositoryType, temporaryFolder.newFolder(), USER_READ, USER_PASS);
|
||||||
assertEquals(1, Objects.requireNonNull(client.getWorkingCopy().list()).length);
|
assertEquals(1, Objects.requireNonNull(client.getWorkingCopy().list()).length);
|
||||||
client = RepositoryUtil.createRepositoryClient(repositoryType, temporaryFolder.newFolder(), USER_WRITE, USER_PASS);
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void writeUserShouldCloneRepository() throws IOException {
|
||||||
|
RepositoryClient client = RepositoryUtil.createRepositoryClient(repositoryType, temporaryFolder.newFolder(), USER_WRITE, USER_PASS);
|
||||||
assertEquals(1, Objects.requireNonNull(client.getWorkingCopy().list()).length);
|
assertEquals(1, Objects.requireNonNull(client.getWorkingCopy().list()).length);
|
||||||
client = RepositoryUtil.createRepositoryClient(repositoryType, temporaryFolder.newFolder(), USER_OWNER, USER_PASS);
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void ownerShouldCloneRepository() throws IOException {
|
||||||
|
RepositoryClient client = RepositoryUtil.createRepositoryClient(repositoryType, temporaryFolder.newFolder(), USER_OWNER, USER_PASS);
|
||||||
assertEquals(1, Objects.requireNonNull(client.getWorkingCopy().list()).length);
|
assertEquals(1, Objects.requireNonNull(client.getWorkingCopy().list()).length);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void otherUserShouldNotCloneRepository() {
|
||||||
|
TestData.callRepository(USER_OTHER, USER_PASS, repositoryType, HttpStatus.SC_FORBIDDEN);
|
||||||
|
}
|
||||||
|
|
||||||
@Test(expected = RepositoryClientException.class)
|
@Test(expected = RepositoryClientException.class)
|
||||||
public void userWithReadPermissionShouldBeNotAuthorizedToCommit() throws IOException {
|
public void userWithReadPermissionShouldBeNotAuthorizedToCommit() throws IOException {
|
||||||
createAndCommit(USER_READ);
|
createAndCommit(USER_READ);
|
||||||
|
|||||||
@@ -8,14 +8,11 @@ import sonia.scm.repository.Person;
|
|||||||
import sonia.scm.repository.client.api.ClientCommand;
|
import sonia.scm.repository.client.api.ClientCommand;
|
||||||
import sonia.scm.repository.client.api.RepositoryClient;
|
import sonia.scm.repository.client.api.RepositoryClient;
|
||||||
import sonia.scm.repository.client.api.RepositoryClientFactory;
|
import sonia.scm.repository.client.api.RepositoryClientFactory;
|
||||||
import sonia.scm.web.VndMediaType;
|
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
import static sonia.scm.it.RestUtil.given;
|
|
||||||
|
|
||||||
public class RepositoryUtil {
|
public class RepositoryUtil {
|
||||||
|
|
||||||
private static final RepositoryClientFactory REPOSITORY_CLIENT_FACTORY = new RepositoryClientFactory();
|
private static final RepositoryClientFactory REPOSITORY_CLIENT_FACTORY = new RepositoryClientFactory();
|
||||||
@@ -25,13 +22,7 @@ public class RepositoryUtil {
|
|||||||
}
|
}
|
||||||
|
|
||||||
static RepositoryClient createRepositoryClient(String repositoryType, File folder, String username, String password) throws IOException {
|
static RepositoryClient createRepositoryClient(String repositoryType, File folder, String username, String password) throws IOException {
|
||||||
String httpProtocolUrl = given(VndMediaType.REPOSITORY, username, password)
|
String httpProtocolUrl = TestData.callRepository(username, password, repositoryType, HttpStatus.SC_OK)
|
||||||
|
|
||||||
.when()
|
|
||||||
.get(TestData.getDefaultRepositoryUrl(repositoryType))
|
|
||||||
|
|
||||||
.then()
|
|
||||||
.statusCode(HttpStatus.SC_OK)
|
|
||||||
.extract()
|
.extract()
|
||||||
.path("_links.httpProtocol.href");
|
.path("_links.httpProtocol.href");
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
package sonia.scm.it;
|
package sonia.scm.it;
|
||||||
|
|
||||||
|
import io.restassured.response.ValidatableResponse;
|
||||||
import org.apache.http.HttpStatus;
|
import org.apache.http.HttpStatus;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
@@ -22,7 +23,7 @@ public class TestData {
|
|||||||
|
|
||||||
public static final String USER_SCM_ADMIN = "scmadmin";
|
public static final String USER_SCM_ADMIN = "scmadmin";
|
||||||
public static final String USER_ANONYMOUS = "anonymous";
|
public static final String USER_ANONYMOUS = "anonymous";
|
||||||
private static final List<String> PROTECTED_USERS = asList(USER_SCM_ADMIN, USER_ANONYMOUS);
|
private static final List<String> PROTECTED_USERS = asList(USER_SCM_ADMIN, USER_ANONYMOUS);
|
||||||
|
|
||||||
private static Map<String, String> DEFAULT_REPOSITORIES = new HashMap<>();
|
private static Map<String, String> DEFAULT_REPOSITORIES = new HashMap<>();
|
||||||
|
|
||||||
@@ -48,7 +49,7 @@ private static final List<String> PROTECTED_USERS = asList(USER_SCM_ADMIN, USER_
|
|||||||
" \"active\": true,\n" +
|
" \"active\": true,\n" +
|
||||||
" \"admin\": false,\n" +
|
" \"admin\": false,\n" +
|
||||||
" \"creationDate\": \"2018-08-21T12:26:46.084Z\",\n" +
|
" \"creationDate\": \"2018-08-21T12:26:46.084Z\",\n" +
|
||||||
" \"displayName\": \""+username+"\",\n" +
|
" \"displayName\": \"" + username + "\",\n" +
|
||||||
" \"mail\": \"user1@scm-manager.org\",\n" +
|
" \"mail\": \"user1@scm-manager.org\",\n" +
|
||||||
" \"name\": \"" + username + "\",\n" +
|
" \"name\": \"" + username + "\",\n" +
|
||||||
" \"password\": \"" + password + "\",\n" +
|
" \"password\": \"" + password + "\",\n" +
|
||||||
@@ -66,8 +67,8 @@ private static final List<String> PROTECTED_USERS = asList(USER_SCM_ADMIN, USER_
|
|||||||
given(VndMediaType.PERMISSION)
|
given(VndMediaType.PERMISSION)
|
||||||
.when()
|
.when()
|
||||||
.content("{\n" +
|
.content("{\n" +
|
||||||
"\t\"type\": \""+permissionType.name()+"\",\n" +
|
"\t\"type\": \"" + permissionType.name() + "\",\n" +
|
||||||
"\t\"name\": \""+name+"\",\n" +
|
"\t\"name\": \"" + name + "\",\n" +
|
||||||
"\t\"groupPermission\": false\n" +
|
"\t\"groupPermission\": false\n" +
|
||||||
"\t\n" +
|
"\t\n" +
|
||||||
"}")
|
"}")
|
||||||
@@ -78,17 +79,31 @@ private static final List<String> PROTECTED_USERS = asList(USER_SCM_ADMIN, USER_
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static List<Object> getUserPermissions(String username, String password, String repositoryType) {
|
public static List<Object> getUserPermissions(String username, String password, String repositoryType) {
|
||||||
return given(VndMediaType.PERMISSION, username, password)
|
return callUserPermissions(username, password, repositoryType, HttpStatus.SC_OK)
|
||||||
.when()
|
|
||||||
.get(TestData.getDefaultPermissionUrl(repositoryType))
|
|
||||||
.then()
|
|
||||||
.statusCode(HttpStatus.SC_OK)
|
|
||||||
.extract()
|
.extract()
|
||||||
.body().jsonPath().getList("");
|
.body().jsonPath().getList("");
|
||||||
}
|
}
|
||||||
|
|
||||||
private static String getDefaultPermissionUrl(String repositoryType) {
|
public static ValidatableResponse callUserPermissions(String username, String password, String repositoryType, int expectedStatusCode) {
|
||||||
return getDefaultRepositoryUrl(repositoryType)+"/permissions/";
|
return given(VndMediaType.PERMISSION, username, password)
|
||||||
|
.when()
|
||||||
|
.get(TestData.getDefaultPermissionUrl(repositoryType))
|
||||||
|
.then()
|
||||||
|
.statusCode(expectedStatusCode);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ValidatableResponse callRepository(String username, String password, String repositoryType, int expectedStatusCode) {
|
||||||
|
return given(VndMediaType.REPOSITORY, username, password)
|
||||||
|
|
||||||
|
.when()
|
||||||
|
.get(getDefaultRepositoryUrl(repositoryType))
|
||||||
|
|
||||||
|
.then()
|
||||||
|
.statusCode(expectedStatusCode);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String getDefaultPermissionUrl(String repositoryType) {
|
||||||
|
return getDefaultRepositoryUrl(repositoryType) + "/permissions/";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user