I'm trying to test the home controller
@RequestMapping("/")
@ResponseBody
String home() {
return "Hello World!";
}
I'm using spring security using as username "user" and test as password by default but @PreAuthorize is not working
@RunWith(SpringRunner.class)
@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT)
@PreAuthorize("hasRole('ADMIN')")
public class HomeControllerTest {
@Autowired
private TestRestTemplate restTemplate;
@Test
@WithMockUser(username = "user", password = "test", roles = "ADMIN")
public void home() throws Exception {
String body = this.restTemplate.getForObject("/", String.class);
assertThat(body).isEqualTo("Hello World!");
}
}
The result
Expected result:
<"[Hello World!]">
Actual result:
<"{"timestamp":1501100448216,"status":401,"error":"Unauthorized","message":"Full authentication is required to access this resource","path":"/"}]">
Am I missing something?
You used invaild password, because
You can create custom user and do test againe
Try to add the following to your test class:
And the following dependency if you don't have it:
Spring security require an extra listener that is not present in tests by default so you need to tell spring to add it by specifing the
@TestExecutionListeners
annotation inmerge
mode so it will merge the current listed listeners with the listeners you want to add - in this caseWithSecurityContextTestExecutionListener