package com.plannaplan.controllers; 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 static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get; import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status; import static org.springframework.security.test.web.servlet.setup.SecurityMockMvcConfigurers.*; import com.plannaplan.entities.User; import com.plannaplan.services.UserService; import com.plannaplan.types.UserRoles; @RunWith(SpringRunner.class) @SpringBootTest @ContextConfiguration public class StatisticsControllerTest extends AbstractControllerTest { private static final String GROUP_AMMOUNTS_ENDPOINT = "/api/v1/statistics/groups/created"; @Autowired private UserService userService; /* GROUP AMMOUNTS TESTS */ @Test public void shouldFailWithWrongAccesGroupsAmmounts() throws Exception { final String mail = "shouldFailWithWrongAccesGroupsAmmounts@StatisticsController.test"; final User usr = this.userService.save(new User(null, null, mail, UserRoles.TEST_USER)); final String token = this.userService.login(usr).getToken(); MockMvc mockMvc = MockMvcBuilders.webAppContextSetup(webApplicationContext).apply(springSecurity()).build(); mockMvc.perform(get(GROUP_AMMOUNTS_ENDPOINT).header("Authorization", "Bearer " + token)) .andExpect(status().is4xxClientError()); } @Test public void shouldOkGettingGroupsAmmounts() throws Exception { final String mail = "shouldOkGettingGroupsAmmounts@StatisticsController.test"; final User usr = this.userService.save(new User(null, null, mail, UserRoles.DEANERY)); final String token = this.userService.login(usr).getToken(); MockMvc mockMvc = MockMvcBuilders.webAppContextSetup(webApplicationContext).apply(springSecurity()).build(); mockMvc.perform(get(GROUP_AMMOUNTS_ENDPOINT).header("Authorization", "Bearer " + token)) .andExpect(status().isOk()); } @Test public void shouldFailWithNoTokenGroupsAmmounts() throws Exception { MockMvc mockMvc = MockMvcBuilders.webAppContextSetup(webApplicationContext).apply(springSecurity()).build(); mockMvc.perform(get(GROUP_AMMOUNTS_ENDPOINT)).andExpect(status().is4xxClientError()); } }