TestGroupApi.java 10.02 KiB
package org.gitlab4j.api;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertTrue;
import static org.junit.Assume.assumeNotNull;
import static org.junit.Assume.assumeTrue;
import java.util.List;
import java.util.Optional;
import java.util.stream.Stream;
import javax.ws.rs.core.Response;
import org.gitlab4j.api.models.AccessLevel;
import org.gitlab4j.api.models.AccessRequest;
import org.gitlab4j.api.models.Group;
import org.gitlab4j.api.models.GroupParams;
import org.gitlab4j.api.models.Member;
import org.gitlab4j.api.models.User;
import org.junit.AfterClass;
import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Test;
import org.junit.experimental.categories.Category;
/**
 * In order for these tests to run you must set the following properties in test-gitlab4j.properties
 * TEST_HOST_URL
 * TEST_PRIVATE_TOKEN
 * TEST_USERNAME
 * TEST_GROUP
 * TEST_GROUP_MEMBER_USERNAME
 * If any of the above are NULL, all tests in this class will be skipped.
@Category(IntegrationTest.class)
public class TestGroupApi extends AbstractIntegrationTest {
    // The following needs to be set to your test repository
    private static final String TEST_GROUP = HelperUtils.getProperty(GROUP_KEY);
    private static final String TEST_GROUP_MEMBER_USERNAME = HelperUtils.getProperty(GROUP_MEMBER_USERNAME_KEY);
    private static final String TEST_REQUEST_ACCESS_USERNAME = HelperUtils.getProperty(TEST_REQUEST_ACCESS_USERNAME_KEY);
    private static GitLabApi gitLabApi;
    private static Group testGroup;
    private static User testUser;
    public TestGroupApi() {
        super();
    @BeforeClass
    public static void setup() {
        // Must setup the connection to the GitLab test server
        gitLabApi = baseTestSetup();
        String problems = "";
        if (gitLabApi != null) {
            Optional<Group> group = gitLabApi.getGroupApi().getOptionalGroup(TEST_GROUP);
            if (group.isPresent()) {
        	testGroup = group.get();
            } else {
                problems += "Problem fetching test group\n";
7172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
if (TEST_GROUP_MEMBER_USERNAME != null && TEST_GROUP_MEMBER_USERNAME.length() > 0) { try { testUser = gitLabApi.getUserApi().getUser(TEST_GROUP_MEMBER_USERNAME); } catch (GitLabApiException gle) { problems += "Problem fetching test user, error=" + gle.getMessage() + "\n"; } } } if (!problems.isEmpty()) { System.err.print(problems); } removeGroupMembers(); } @AfterClass public static void teardown() { removeGroupMembers(); } private static void removeGroupMembers() { if (gitLabApi != null && testGroup != null && testUser != null) { try { gitLabApi.getGroupApi().removeMember(testGroup.getId(), testUser.getId()); } catch (GitLabApiException ignore) { } } if (TEST_REQUEST_ACCESS_USERNAME != null) { Optional<User> user = gitLabApi.getUserApi().getOptionalUser(TEST_REQUEST_ACCESS_USERNAME); if (user.isPresent()) { Integer userId = user.get().getId(); try { gitLabApi.getGroupApi().denyAccessRequest(testGroup, userId); } catch (Exception e) { try { gitLabApi.getGroupApi().removeMember(testGroup, userId); } catch (Exception ignore) {} } } } } @Before public void beforeMethod() { assumeNotNull(gitLabApi); assumeNotNull(testGroup); assumeNotNull(testUser); } @Test public void testMemberOperations() throws GitLabApiException { // Arrange and Act Member member = gitLabApi.getGroupApi().addMember(testGroup.getId(), testUser.getId(), AccessLevel.DEVELOPER); // Assert assertNotNull(member); assertEquals(testUser.getId(), member.getId()); assertEquals(AccessLevel.DEVELOPER, member.getAccessLevel()); // Act Optional<Member> optionalMember = gitLabApi.getGroupApi().getOptionalMember(testGroup, testUser.getId()); // Assert assertTrue(optionalMember.isPresent()); // Act
141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210
List<Member> members = gitLabApi.getGroupApi().getMembers(testGroup); // Assert assertNotNull(members); Boolean found = (members.stream().filter(m -> m.getId().equals(member.getId())).findAny().orElse(null) != null); assertTrue(found); // Act gitLabApi.getGroupApi().removeMember(testGroup.getId(), testUser.getId()); // Act optionalMember = gitLabApi.getGroupApi().getOptionalMember(testGroup, testUser.getId()); // Assert assertFalse(optionalMember.isPresent()); } @Test public void testAllMemberOperations() throws GitLabApiException { // Arrange and Act Member member = gitLabApi.getGroupApi().addMember(testGroup.getId(), testUser.getId(), AccessLevel.DEVELOPER); // Assert assertNotNull(member); assertEquals(testUser.getId(), member.getId()); assertEquals(AccessLevel.DEVELOPER, member.getAccessLevel()); // Act List<Member> members = gitLabApi.getGroupApi().getAllMembers(testGroup); // Assert assertNotNull(members); Boolean found = (members.stream().filter(m -> m.getId().equals(member.getId())).findAny().orElse(null) != null); assertTrue(found); gitLabApi.getGroupApi().removeMember(testGroup.getId(), testUser.getId()); } @Test public void getGroup() throws GitLabApiException { Group group = gitLabApi.getGroupApi().getGroup(TEST_GROUP); assertNotNull(group); } @Test public void getOptionalGroup() { Optional<Group> optional = gitLabApi.getGroupApi().getOptionalGroup(TEST_GROUP); assertTrue(optional.isPresent()); assertEquals(testGroup.getId(), optional.get().getId()); optional = gitLabApi.getGroupApi().getOptionalGroup(12345); assertNotNull(optional); assertFalse(optional.isPresent()); assertEquals(Response.Status.NOT_FOUND.getStatusCode(), GitLabApi.getOptionalException(optional).getHttpStatus()); } @Test public void testRequestAccess() throws GitLabApiException { assumeTrue(TEST_REQUEST_ACCESS_USERNAME != null && TEST_REQUEST_ACCESS_USERNAME.length() > 0); gitLabApi.sudo(TEST_REQUEST_ACCESS_USERNAME); User user = gitLabApi.getUserApi().getCurrentUser(); assertNotNull(user); final Integer userId = user.getId(); try { try {
211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280
AccessRequest accessRequest = gitLabApi.getGroupApi().requestAccess(testGroup); assertNotNull(accessRequest); assertEquals(userId, accessRequest.getId()); } finally { gitLabApi.unsudo(); } Stream<AccessRequest> requests = gitLabApi.getGroupApi().getAccessRequestsStream(testGroup); assertTrue(requests.anyMatch(r -> r.getId() == userId)); AccessRequest accessRequest = gitLabApi.getGroupApi().approveAccessRequest(testGroup, user.getId(), AccessLevel.DEVELOPER); assertNotNull(accessRequest); assertEquals(user.getId(), accessRequest.getId()); assertEquals(AccessLevel.DEVELOPER, accessRequest.getAccessLevel()); user = null; requests = gitLabApi.getGroupApi().getAccessRequestsStream(testGroup); assertFalse(requests.anyMatch(r -> r.getId() == userId)); } finally { try { if (user == null) { gitLabApi.getGroupApi().removeMember(testGroup, userId); } else { gitLabApi.getGroupApi().denyAccessRequest(testGroup, userId); } } catch (Exception ignore) {} } } @Test public void testDenyRequestAccess() throws GitLabApiException { assumeTrue(TEST_REQUEST_ACCESS_USERNAME != null && TEST_REQUEST_ACCESS_USERNAME.length() > 0); gitLabApi.sudo(TEST_REQUEST_ACCESS_USERNAME); User user = gitLabApi.getUserApi().getCurrentUser(); assertNotNull(user); final Integer userId = user.getId(); try { try { AccessRequest accessRequest = gitLabApi.getGroupApi().requestAccess(testGroup); assertNotNull(accessRequest); assertEquals(userId, accessRequest.getId()); } finally { gitLabApi.unsudo(); } List<AccessRequest> requests = gitLabApi.getGroupApi().getAccessRequests(testGroup); assertTrue(requests.stream().anyMatch(r -> r.getId() == userId)); gitLabApi.getGroupApi().denyAccessRequest(testGroup, userId); requests = gitLabApi.getGroupApi().getAccessRequests(testGroup); assertFalse(requests.stream().anyMatch(r -> r.getId() == userId)); user = null; } finally { try { if (user != null) { gitLabApi.getGroupApi().denyAccessRequest(testGroup, userId); } } catch (Exception ignore) {
281282283284285286287288289290291292293294295296297298299300
} } } @Test public void updateGroup() throws GitLabApiException { String description = "Test Group (" + HelperUtils.getRandomInt(1000) + ")"; GroupParams params = new GroupParams().withDescription(description); Group updatedGroup = gitLabApi.getGroupApi().updateGroup(testGroup, params); assertEquals(description, updatedGroup.getDescription()); Optional<Group> optional = gitLabApi.getGroupApi().getOptionalGroup(TEST_GROUP); assertTrue(optional.isPresent()); assertEquals(testGroup.getId(), optional.get().getId()); assertEquals(description, optional.get().getDescription()); } }