mirror of
https://github.com/scm-manager/scm-manager.git
synced 2025-11-17 02:31:14 +01:00
fix Tests / add Test
This commit is contained in:
@@ -1,10 +1,14 @@
|
|||||||
package sonia.scm.api.v2.resources;
|
package sonia.scm.api.v2.resources;
|
||||||
|
|
||||||
|
import com.github.sdorra.shiro.SubjectAware;
|
||||||
import com.google.common.io.Resources;
|
import com.google.common.io.Resources;
|
||||||
import com.google.inject.util.Providers;
|
import com.google.inject.util.Providers;
|
||||||
|
import org.apache.shiro.subject.Subject;
|
||||||
|
import org.apache.shiro.util.ThreadContext;
|
||||||
import org.jboss.resteasy.core.Dispatcher;
|
import org.jboss.resteasy.core.Dispatcher;
|
||||||
import org.jboss.resteasy.mock.MockHttpRequest;
|
import org.jboss.resteasy.mock.MockHttpRequest;
|
||||||
import org.jboss.resteasy.mock.MockHttpResponse;
|
import org.jboss.resteasy.mock.MockHttpResponse;
|
||||||
|
import org.junit.jupiter.api.AfterEach;
|
||||||
import org.junit.jupiter.api.BeforeEach;
|
import org.junit.jupiter.api.BeforeEach;
|
||||||
import org.junit.jupiter.api.Nested;
|
import org.junit.jupiter.api.Nested;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
@@ -13,6 +17,7 @@ import org.mockito.InjectMocks;
|
|||||||
import org.mockito.Mock;
|
import org.mockito.Mock;
|
||||||
import org.mockito.junit.jupiter.MockitoExtension;
|
import org.mockito.junit.jupiter.MockitoExtension;
|
||||||
import sonia.scm.repository.NamespaceAndName;
|
import sonia.scm.repository.NamespaceAndName;
|
||||||
|
import sonia.scm.repository.Repository;
|
||||||
import sonia.scm.repository.api.MergeCommandBuilder;
|
import sonia.scm.repository.api.MergeCommandBuilder;
|
||||||
import sonia.scm.repository.api.MergeCommandResult;
|
import sonia.scm.repository.api.MergeCommandResult;
|
||||||
import sonia.scm.repository.api.MergeDryRunCommandResult;
|
import sonia.scm.repository.api.MergeDryRunCommandResult;
|
||||||
@@ -26,12 +31,20 @@ import java.net.URL;
|
|||||||
import static java.util.Arrays.asList;
|
import static java.util.Arrays.asList;
|
||||||
import static org.assertj.core.api.Assertions.assertThat;
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
import static org.mockito.ArgumentMatchers.any;
|
import static org.mockito.ArgumentMatchers.any;
|
||||||
|
import static org.mockito.Mockito.lenient;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
import static sonia.scm.repository.RepositoryTestData.createHeartOfGold;
|
||||||
|
|
||||||
@ExtendWith(MockitoExtension.class)
|
@ExtendWith(MockitoExtension.class)
|
||||||
|
@SubjectAware(
|
||||||
|
configuration = "classpath:sonia/scm/shiro-001.ini",
|
||||||
|
username = "trillian",
|
||||||
|
password = "secret"
|
||||||
|
)
|
||||||
public class MergeResourceTest extends RepositoryTestBase {
|
public class MergeResourceTest extends RepositoryTestBase {
|
||||||
|
|
||||||
public static final String MERGE_URL = "/" + RepositoryRootResource.REPOSITORIES_PATH_V2 + "space/repo/merge/";
|
public static final String MERGE_URL = "/" + RepositoryRootResource.REPOSITORIES_PATH_V2 + "space/repo/merge/";
|
||||||
|
private Repository repository = createHeartOfGold();
|
||||||
|
|
||||||
private Dispatcher dispatcher;
|
private Dispatcher dispatcher;
|
||||||
@Mock
|
@Mock
|
||||||
@@ -72,10 +85,21 @@ public class MergeResourceTest extends RepositoryTestBase {
|
|||||||
@Nested
|
@Nested
|
||||||
class ExecutingMergeCommand {
|
class ExecutingMergeCommand {
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
private Subject subject;
|
||||||
|
|
||||||
@BeforeEach
|
@BeforeEach
|
||||||
void initRepository() {
|
void initRepository() {
|
||||||
when(serviceFactory.create(new NamespaceAndName("space", "repo"))).thenReturn(repositoryService);
|
when(serviceFactory.create(new NamespaceAndName("space", "repo"))).thenReturn(repositoryService);
|
||||||
when(repositoryService.getMergeCommand()).thenReturn(mergeCommandBuilder);
|
lenient().when(repositoryService.getMergeCommand()).thenReturn(mergeCommandBuilder);
|
||||||
|
when(repositoryService.getRepository()).thenReturn(repository);
|
||||||
|
|
||||||
|
ThreadContext.bind(subject);
|
||||||
|
}
|
||||||
|
|
||||||
|
@AfterEach
|
||||||
|
void tearDownShiro() {
|
||||||
|
ThreadContext.unbindSubject();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -115,6 +139,7 @@ public class MergeResourceTest extends RepositoryTestBase {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
void shouldHandleSuccessfulDryRun() throws Exception {
|
void shouldHandleSuccessfulDryRun() throws Exception {
|
||||||
|
when(subject.isPermitted("repository:push:" + repositoryService.getRepository().getId())).thenReturn(true);
|
||||||
when(mergeCommand.dryRun(any())).thenReturn(new MergeDryRunCommandResult(true));
|
when(mergeCommand.dryRun(any())).thenReturn(new MergeDryRunCommandResult(true));
|
||||||
|
|
||||||
URL url = Resources.getResource("sonia/scm/api/v2/mergeCommand.json");
|
URL url = Resources.getResource("sonia/scm/api/v2/mergeCommand.json");
|
||||||
@@ -132,6 +157,7 @@ public class MergeResourceTest extends RepositoryTestBase {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
void shouldHandleFailedDryRun() throws Exception {
|
void shouldHandleFailedDryRun() throws Exception {
|
||||||
|
when(subject.isPermitted("repository:push:" + repositoryService.getRepository().getId())).thenReturn(true);
|
||||||
when(mergeCommand.dryRun(any())).thenReturn(new MergeDryRunCommandResult(false));
|
when(mergeCommand.dryRun(any())).thenReturn(new MergeDryRunCommandResult(false));
|
||||||
|
|
||||||
URL url = Resources.getResource("sonia/scm/api/v2/mergeCommand.json");
|
URL url = Resources.getResource("sonia/scm/api/v2/mergeCommand.json");
|
||||||
@@ -146,5 +172,22 @@ public class MergeResourceTest extends RepositoryTestBase {
|
|||||||
|
|
||||||
assertThat(response.getStatus()).isEqualTo(409);
|
assertThat(response.getStatus()).isEqualTo(409);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void shouldSkipDryRunIfSubjectHasNoPushPermission() throws Exception {
|
||||||
|
when(subject.isPermitted("repository:push:" + repositoryService.getRepository().getId())).thenReturn(false);
|
||||||
|
|
||||||
|
URL url = Resources.getResource("sonia/scm/api/v2/mergeCommand.json");
|
||||||
|
byte[] mergeCommandJson = Resources.toByteArray(url);
|
||||||
|
|
||||||
|
MockHttpRequest request = MockHttpRequest
|
||||||
|
.post(MERGE_URL + "dry-run/")
|
||||||
|
.content(mergeCommandJson)
|
||||||
|
.contentType(VndMediaType.MERGE_COMMAND);
|
||||||
|
MockHttpResponse response = new MockHttpResponse();
|
||||||
|
dispatcher.invoke(request, response);
|
||||||
|
|
||||||
|
assertThat(response.getStatus()).isEqualTo(204);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user