mirror of
https://github.com/scm-manager/scm-manager.git
synced 2025-11-14 17:26:22 +01:00
fixed broken tests
This commit is contained in:
@@ -1,6 +1,7 @@
|
|||||||
package sonia.scm.web.protocol;
|
package sonia.scm.web.protocol;
|
||||||
|
|
||||||
import org.junit.jupiter.api.BeforeEach;
|
import org.junit.jupiter.api.BeforeEach;
|
||||||
|
import org.junit.jupiter.api.Nested;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.junit.jupiter.api.extension.ExtendWith;
|
import org.junit.jupiter.api.extension.ExtendWith;
|
||||||
import org.mockito.InjectMocks;
|
import org.mockito.InjectMocks;
|
||||||
@@ -11,6 +12,7 @@ import sonia.scm.PushStateDispatcher;
|
|||||||
import sonia.scm.repository.DefaultRepositoryProvider;
|
import sonia.scm.repository.DefaultRepositoryProvider;
|
||||||
import sonia.scm.repository.NamespaceAndName;
|
import sonia.scm.repository.NamespaceAndName;
|
||||||
import sonia.scm.repository.Repository;
|
import sonia.scm.repository.Repository;
|
||||||
|
import sonia.scm.repository.RepositoryTestData;
|
||||||
import sonia.scm.repository.api.RepositoryService;
|
import sonia.scm.repository.api.RepositoryService;
|
||||||
import sonia.scm.repository.api.RepositoryServiceFactory;
|
import sonia.scm.repository.api.RepositoryServiceFactory;
|
||||||
import sonia.scm.repository.spi.HttpScmProtocol;
|
import sonia.scm.repository.spi.HttpScmProtocol;
|
||||||
@@ -21,18 +23,23 @@ import javax.servlet.ServletException;
|
|||||||
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletRequest;
|
||||||
import javax.servlet.http.HttpServletResponse;
|
import javax.servlet.http.HttpServletResponse;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.util.Optional;
|
||||||
|
|
||||||
import static org.mockito.AdditionalMatchers.not;
|
import static org.mockito.Mockito.verify;
|
||||||
import static org.mockito.ArgumentMatchers.eq;
|
import static org.mockito.Mockito.when;
|
||||||
import static org.mockito.Mockito.*;
|
|
||||||
|
|
||||||
@ExtendWith(MockitoExtension.class)
|
@ExtendWith(MockitoExtension.class)
|
||||||
class HttpProtocolServletTest {
|
class HttpProtocolServletTest {
|
||||||
|
|
||||||
@Mock
|
@Mock
|
||||||
private RepositoryServiceFactory serviceFactory;
|
private RepositoryServiceFactory serviceFactory;
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
private NamespaceAndNameFromPathExtractor extractor;
|
||||||
|
|
||||||
@Mock
|
@Mock
|
||||||
private PushStateDispatcher dispatcher;
|
private PushStateDispatcher dispatcher;
|
||||||
|
|
||||||
@Mock
|
@Mock
|
||||||
private UserAgentParser userAgentParser;
|
private UserAgentParser userAgentParser;
|
||||||
|
|
||||||
@@ -41,23 +48,27 @@ class HttpProtocolServletTest {
|
|||||||
|
|
||||||
@Mock
|
@Mock
|
||||||
private RepositoryService repositoryService;
|
private RepositoryService repositoryService;
|
||||||
|
|
||||||
@Mock
|
@Mock
|
||||||
private UserAgent userAgent;
|
private UserAgent userAgent;
|
||||||
|
|
||||||
@Mock
|
@Mock
|
||||||
private HttpServletRequest request;
|
private HttpServletRequest request;
|
||||||
|
|
||||||
@Mock
|
@Mock
|
||||||
private HttpServletResponse response;
|
private HttpServletResponse response;
|
||||||
|
|
||||||
@Mock
|
@Mock
|
||||||
private HttpScmProtocol protocol;
|
private HttpScmProtocol protocol;
|
||||||
|
|
||||||
|
@Nested
|
||||||
|
class Browser {
|
||||||
|
|
||||||
@BeforeEach
|
@BeforeEach
|
||||||
void init() {
|
void prepareMocks() {
|
||||||
when(userAgentParser.parse(request)).thenReturn(userAgent);
|
when(userAgentParser.parse(request)).thenReturn(userAgent);
|
||||||
when(userAgent.isBrowser()).thenReturn(false);
|
when(userAgent.isBrowser()).thenReturn(true);
|
||||||
NamespaceAndName existingRepo = new NamespaceAndName("space", "repo");
|
when(request.getRequestURI()).thenReturn("uri");
|
||||||
when(serviceFactory.create(not(eq(existingRepo)))).thenThrow(new NotFoundException("Test", "a"));
|
|
||||||
when(serviceFactory.create(existingRepo)).thenReturn(repositoryService);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -70,6 +81,17 @@ class HttpProtocolServletTest {
|
|||||||
verify(dispatcher).dispatch(request, response, "uri");
|
verify(dispatcher).dispatch(request, response, "uri");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Nested
|
||||||
|
class ScmClient {
|
||||||
|
|
||||||
|
@BeforeEach
|
||||||
|
void prepareMocks() {
|
||||||
|
when(userAgentParser.parse(request)).thenReturn(userAgent);
|
||||||
|
when(userAgent.isBrowser()).thenReturn(false);
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
void shouldHandleBadPaths() throws IOException, ServletException {
|
void shouldHandleBadPaths() throws IOException, ServletException {
|
||||||
when(request.getPathInfo()).thenReturn("/illegal");
|
when(request.getPathInfo()).thenReturn("/illegal");
|
||||||
@@ -83,6 +105,10 @@ class HttpProtocolServletTest {
|
|||||||
void shouldHandleNotExistingRepository() throws IOException, ServletException {
|
void shouldHandleNotExistingRepository() throws IOException, ServletException {
|
||||||
when(request.getPathInfo()).thenReturn("/not/exists");
|
when(request.getPathInfo()).thenReturn("/not/exists");
|
||||||
|
|
||||||
|
NamespaceAndName repo = new NamespaceAndName("not", "exists");
|
||||||
|
when(extractor.fromUri("/not/exists")).thenReturn(Optional.of(repo));
|
||||||
|
when(serviceFactory.create(repo)).thenThrow(new NotFoundException("Test", "a"));
|
||||||
|
|
||||||
servlet.service(request, response);
|
servlet.service(request, response);
|
||||||
|
|
||||||
verify(response).setStatus(404);
|
verify(response).setStatus(404);
|
||||||
@@ -90,10 +116,12 @@ class HttpProtocolServletTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
void shouldDelegateToProvider() throws IOException, ServletException {
|
void shouldDelegateToProvider() throws IOException, ServletException {
|
||||||
|
NamespaceAndName repo = new NamespaceAndName("space", "name");
|
||||||
|
when(extractor.fromUri("/space/name")).thenReturn(Optional.of(repo));
|
||||||
|
when(serviceFactory.create(repo)).thenReturn(repositoryService);
|
||||||
|
|
||||||
when(request.getPathInfo()).thenReturn("/space/name");
|
when(request.getPathInfo()).thenReturn("/space/name");
|
||||||
NamespaceAndName namespaceAndName = new NamespaceAndName("space", "name");
|
Repository repository = RepositoryTestData.createHeartOfGold();
|
||||||
doReturn(repositoryService).when(serviceFactory).create(namespaceAndName);
|
|
||||||
Repository repository = new Repository();
|
|
||||||
when(repositoryService.getRepository()).thenReturn(repository);
|
when(repositoryService.getRepository()).thenReturn(repository);
|
||||||
when(repositoryService.getProtocol(HttpScmProtocol.class)).thenReturn(protocol);
|
when(repositoryService.getProtocol(HttpScmProtocol.class)).thenReturn(protocol);
|
||||||
|
|
||||||
@@ -103,4 +131,6 @@ class HttpProtocolServletTest {
|
|||||||
verify(protocol).serve(request, response, null);
|
verify(protocol).serve(request, response, null);
|
||||||
verify(repositoryService).close();
|
verify(repositoryService).close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user