From 609cafcb71f113e4b1bd28a05e4f308a6375aa07 Mon Sep 17 00:00:00 2001 From: Rajbir Singh Date: Thu, 10 Oct 2024 17:57:25 +0200 Subject: [PATCH] added shouldNotCreateProjectWhenAdministratorDoesNotExist test --- .../java/de/hmmh/pmt/project/CreateTest.java | 33 +++++++++++++++++-- 1 file changed, 30 insertions(+), 3 deletions(-) diff --git a/src/test/java/de/hmmh/pmt/project/CreateTest.java b/src/test/java/de/hmmh/pmt/project/CreateTest.java index 3fbd7b2..111d09b 100644 --- a/src/test/java/de/hmmh/pmt/project/CreateTest.java +++ b/src/test/java/de/hmmh/pmt/project/CreateTest.java @@ -5,12 +5,16 @@ import de.hmmh.pmt.dtos.CreateProjectDTO; import de.hmmh.pmt.employee.dtos.EmployeeResponseDTO; import org.junit.jupiter.api.Test; import org.mockito.Mockito; +import org.springframework.http.HttpStatusCode; import org.springframework.http.MediaType; import org.springframework.test.web.servlet.RequestBuilder; import org.springframework.test.web.servlet.request.MockMvcRequestBuilders; +import org.springframework.web.client.HttpClientErrorException; import java.time.LocalDateTime; +import static org.mockito.Mockito.mock; +import static org.mockito.Mockito.when; import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.jsonPath; import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status; @@ -18,8 +22,7 @@ public class CreateTest extends IntegrationTest { @Test void successfullyCreate() throws Exception { - Mockito - .when(this.mockEmployeeApi.findById(Mockito.anyLong())) + when(this.mockEmployeeApi.findById(Mockito.anyLong())) .thenReturn(new EmployeeResponseDTO()); CreateProjectDTO createDTO = new CreateProjectDTO(); @@ -49,7 +52,7 @@ public class CreateTest extends IntegrationTest { createDTO.setName("Test"); createDTO.setGoal("A Test Goal"); createDTO.setCustomerId(10L); - createDTO.setAdministratorId(10L); + createDTO.setAdministratorId(1L); createDTO.setStart(LocalDateTime.of(2000, 1, 13, 12, 51)); createDTO.setPlannedEnd(LocalDateTime.of(2002, 3, 21, 11, 42)); @@ -67,6 +70,30 @@ public class CreateTest extends IntegrationTest { .andExpect(status().isConflict()); } + @Test + void shouldNotCreateProjectWhenAdministratorDoesNotExist() throws Exception { + HttpClientErrorException httpClientErrorException = mock(HttpClientErrorException.class); + + when(httpClientErrorException.getStatusCode()).thenReturn(HttpStatusCode.valueOf(404)); + + when(this.mockEmployeeApi.findById(1L)) + .thenThrow(httpClientErrorException); + + CreateProjectDTO createDTO = new CreateProjectDTO(); + createDTO.setName("Test"); + createDTO.setGoal("A Test Goal"); + createDTO.setCustomerId(10L); + createDTO.setAdministratorId(1L); + createDTO.setStart(LocalDateTime.of(2000, 1, 13, 12, 51)); + createDTO.setPlannedEnd(LocalDateTime.of(2002, 3, 21, 11, 42)); + + RequestBuilder projectRequestBuilder = createProjectRequestBuilder(createDTO); + + this.mvc + .perform(projectRequestBuilder) + .andExpect(status().isNotFound()); + } + private RequestBuilder createProjectRequestBuilder(CreateProjectDTO createDTO) throws Exception { return MockMvcRequestBuilders