Files
spring-security-study/src/test/java/com/example/springsecuritystudy/SampleControllerTest.java
2023-02-06 11:13:13 +09:00

84 lines
2.1 KiB
Java

package com.example.springsecuritystudy;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.security.test.context.support.WithMockUser;
import org.springframework.test.web.servlet.MockMvc;
import org.springframework.test.web.servlet.setup.MockMvcBuilders;
import org.springframework.web.context.WebApplicationContext;
import com.example.springsecuritystudy.helper.WithMockAdmin;
import static org.springframework.security.test.web.servlet.request.SecurityMockMvcRequestBuilders.*;
import static org.springframework.security.test.web.servlet.setup.SecurityMockMvcConfigurers.*;
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.*;
import static org.springframework.test.web.servlet.result.MockMvcResultHandlers.*;
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.*;
@SpringBootTest
class SampleControllerTest {
@Autowired
private WebApplicationContext applicationContext;
private MockMvc mvc;
@BeforeEach
public void setUp() {
mvc = MockMvcBuilders.webAppContextSetup(applicationContext)
.apply(springSecurity())
.alwaysDo(print())
.build();
}
@Test
void example() throws Exception {
mvc.perform(
get("/example")
).andExpect(status().isOk());
}
@Test
void login_user() throws Exception {
mvc.perform(
formLogin("/login")
.user("user")
.password("user")
).andExpect(status().is3xxRedirection());
}
@Test
void login_admin() throws Exception {
mvc.perform(
formLogin("/login")
.user("admin")
.password("admin")
).andExpect(status().is3xxRedirection());
}
@Test
@WithMockUser
void access_user() throws Exception {
mvc.perform(
get("/post")
).andExpect(status().isOk());
}
@Test
@WithMockAdmin
void access_admin() throws Exception {
mvc.perform(
get("/admin")
).andExpect(status().isOk());
}
@Test
@WithMockUser
void access_denied() throws Exception {
mvc.perform(
get("/admin")
).andExpect(status().isForbidden());
}
}