diff --git a/restservice/src/test/java/com/plannaplan/controllers/UsersControllerTest.java b/restservice/src/test/java/com/plannaplan/controllers/UsersControllerTest.java index 8ea6d14..b55850d 100755 --- a/restservice/src/test/java/com/plannaplan/controllers/UsersControllerTest.java +++ b/restservice/src/test/java/com/plannaplan/controllers/UsersControllerTest.java @@ -1,22 +1,60 @@ package com.plannaplan.controllers; -import static org.junit.jupiter.api.Assertions.assertTrue; +import com.plannaplan.entities.User; +import com.plannaplan.services.UserService; +import com.plannaplan.types.UserRoles; import org.junit.Test; +import org.junit.runner.RunWith; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.boot.test.context.SpringBootTest; +import org.springframework.test.context.ContextConfiguration; +import org.springframework.test.context.junit4.SpringRunner; +import org.springframework.test.web.servlet.MockMvc; +import org.springframework.test.web.servlet.setup.MockMvcBuilders; +import org.springframework.web.context.WebApplicationContext; +import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get; +import static org.springframework.security.test.web.servlet.setup.SecurityMockMvcConfigurers.*; +import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status; + +@RunWith(SpringRunner.class) +@SpringBootTest +@ContextConfiguration public class UsersControllerTest { + private static final String ENDPOINT = "/api/v1/users/searchForStudents"; + + @Autowired + private WebApplicationContext webApplicationContext; + + @Autowired + private UserService service; + @Test - public void shouldRestrun200OK() { - assertTrue(false); + public void shouldRestrun200OK() throws Exception { + final String email = "notexistingassignmentuser@shouldRestrun200OK.test"; + this.service.save(new User(null, null, email, UserRoles.DEANERY)); + final String token = this.service.login(email); + + MockMvc mockMvc = MockMvcBuilders.webAppContextSetup(webApplicationContext).apply(springSecurity()).build(); + mockMvc.perform(get(ENDPOINT).param("query", "").header("Authorization", "Bearer " + token)) + .andExpect(status().isOk()); } @Test - public void shouldRestrunForbiden() { - assertTrue(false); + public void shouldRestrunForbiden() throws Exception { + MockMvc mockMvc = MockMvcBuilders.webAppContextSetup(webApplicationContext).apply(springSecurity()).build(); + mockMvc.perform(get(ENDPOINT)).andExpect(status().is4xxClientError()); } @Test - public void shouldFailedDueToMissingParam() { - assertTrue(false); + public void shouldFailedDueToMissingParam() throws Exception { + final String email = "notexistingassignmentuser@shouldFailedDueToMissingParam.test"; + this.service.save(new User(null, null, email, UserRoles.DEANERY)); + final String token = this.service.login(email); + + MockMvc mockMvc = MockMvcBuilders.webAppContextSetup(webApplicationContext).apply(springSecurity()).build(); + mockMvc.perform(get(ENDPOINT).header("Authorization", "Bearer " + token)) + .andExpect(status().is4xxClientError()); } }