fixed broken tests

This commit is contained in:
Sebastian Sdorra
2019-07-22 14:41:12 +02:00
parent 405ffcf164
commit 4ba9437410

View File

@@ -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,66 +48,89 @@ 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;
@BeforeEach @Nested
void init() { class Browser {
when(userAgentParser.parse(request)).thenReturn(userAgent);
when(userAgent.isBrowser()).thenReturn(false); @BeforeEach
NamespaceAndName existingRepo = new NamespaceAndName("space", "repo"); void prepareMocks() {
when(serviceFactory.create(not(eq(existingRepo)))).thenThrow(new NotFoundException("Test", "a")); when(userAgentParser.parse(request)).thenReturn(userAgent);
when(serviceFactory.create(existingRepo)).thenReturn(repositoryService); when(userAgent.isBrowser()).thenReturn(true);
when(request.getRequestURI()).thenReturn("uri");
}
@Test
void shouldDispatchBrowserRequests() throws ServletException, IOException {
when(userAgent.isBrowser()).thenReturn(true);
when(request.getRequestURI()).thenReturn("uri");
servlet.service(request, response);
verify(dispatcher).dispatch(request, response, "uri");
}
} }
@Test @Nested
void shouldDispatchBrowserRequests() throws ServletException, IOException { class ScmClient {
when(userAgent.isBrowser()).thenReturn(true);
when(request.getRequestURI()).thenReturn("uri");
servlet.service(request, response); @BeforeEach
void prepareMocks() {
when(userAgentParser.parse(request)).thenReturn(userAgent);
when(userAgent.isBrowser()).thenReturn(false);
}
verify(dispatcher).dispatch(request, response, "uri"); @Test
} void shouldHandleBadPaths() throws IOException, ServletException {
when(request.getPathInfo()).thenReturn("/illegal");
@Test servlet.service(request, response);
void shouldHandleBadPaths() throws IOException, ServletException {
when(request.getPathInfo()).thenReturn("/illegal");
servlet.service(request, response); verify(response).setStatus(400);
}
verify(response).setStatus(400); @Test
} void shouldHandleNotExistingRepository() throws IOException, ServletException {
when(request.getPathInfo()).thenReturn("/not/exists");
@Test NamespaceAndName repo = new NamespaceAndName("not", "exists");
void shouldHandleNotExistingRepository() throws IOException, ServletException { when(extractor.fromUri("/not/exists")).thenReturn(Optional.of(repo));
when(request.getPathInfo()).thenReturn("/not/exists"); 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);
} }
@Test @Test
void shouldDelegateToProvider() throws IOException, ServletException { void shouldDelegateToProvider() throws IOException, ServletException {
when(request.getPathInfo()).thenReturn("/space/name"); NamespaceAndName repo = new NamespaceAndName("space", "name");
NamespaceAndName namespaceAndName = new NamespaceAndName("space", "name"); when(extractor.fromUri("/space/name")).thenReturn(Optional.of(repo));
doReturn(repositoryService).when(serviceFactory).create(namespaceAndName); when(serviceFactory.create(repo)).thenReturn(repositoryService);
Repository repository = new Repository();
when(repositoryService.getRepository()).thenReturn(repository);
when(repositoryService.getProtocol(HttpScmProtocol.class)).thenReturn(protocol);
servlet.service(request, response); when(request.getPathInfo()).thenReturn("/space/name");
Repository repository = RepositoryTestData.createHeartOfGold();
when(repositoryService.getRepository()).thenReturn(repository);
when(repositoryService.getProtocol(HttpScmProtocol.class)).thenReturn(protocol);
servlet.service(request, response);
verify(request).setAttribute(DefaultRepositoryProvider.ATTRIBUTE_NAME, repository);
verify(protocol).serve(request, response, null);
verify(repositoryService).close();
}
verify(request).setAttribute(DefaultRepositoryProvider.ATTRIBUTE_NAME, repository);
verify(protocol).serve(request, response, null);
verify(repositoryService).close();
} }
} }