Add formLogin() Accept Test

Issue gh-3920
This commit is contained in:
Rob Winch 2016-06-20 16:23:29 -05:00
parent 314828859e
commit a2a06d19c1
1 changed files with 26 additions and 12 deletions

View File

@ -15,34 +15,37 @@
*/ */
package org.springframework.security.test.web.servlet.request; package org.springframework.security.test.web.servlet.request;
import static org.assertj.core.api.Assertions.assertThat;
import static org.springframework.security.test.web.servlet.request.SecurityMockMvcRequestBuilders.formLogin;
import org.junit.Before; import org.junit.Before;
import org.junit.Test; import org.junit.Test;
import org.springframework.http.MediaType;
import org.springframework.mock.web.MockHttpServletRequest; import org.springframework.mock.web.MockHttpServletRequest;
import org.springframework.mock.web.MockServletContext; import org.springframework.mock.web.MockServletContext;
import org.springframework.security.test.web.servlet.request.SecurityMockMvcRequestPostProcessors.CsrfRequestPostProcessor; import org.springframework.security.test.web.servlet.request.SecurityMockMvcRequestPostProcessors.CsrfRequestPostProcessor;
import org.springframework.security.web.csrf.CsrfToken; import org.springframework.security.web.csrf.CsrfToken;
import static org.assertj.core.api.Assertions.assertThat;
import static org.springframework.security.test.web.servlet.request.SecurityMockMvcRequestBuilders.formLogin;
public class SecurityMockMvcRequestBuildersFormLoginTests { public class SecurityMockMvcRequestBuildersFormLoginTests {
private MockServletContext servletContext; private MockServletContext servletContext;
@Before @Before
public void setup() throws Exception { public void setup() throws Exception {
servletContext = new MockServletContext(); this.servletContext = new MockServletContext();
} }
@Test @Test
public void defaults() throws Exception { public void defaults() throws Exception {
MockHttpServletRequest request = formLogin().buildRequest(servletContext); MockHttpServletRequest request = formLogin().buildRequest(this.servletContext);
CsrfToken token = (CsrfToken) request.getAttribute(CsrfRequestPostProcessor.TestCsrfTokenRepository.ATTR_NAME); CsrfToken token = (CsrfToken) request
.getAttribute(CsrfRequestPostProcessor.TestCsrfTokenRepository.ATTR_NAME);
assertThat(request.getParameter("username")).isEqualTo("user"); assertThat(request.getParameter("username")).isEqualTo("user");
assertThat(request.getParameter("password")).isEqualTo("password"); assertThat(request.getParameter("password")).isEqualTo("password");
assertThat(request.getMethod()).isEqualTo("POST"); assertThat(request.getMethod()).isEqualTo("POST");
assertThat(request.getParameter(token.getParameterName())).isEqualTo( assertThat(request.getParameter(token.getParameterName()))
token.getToken()); .isEqualTo(token.getToken());
assertThat(request.getRequestURI()).isEqualTo("/login"); assertThat(request.getRequestURI()).isEqualTo("/login");
assertThat(request.getParameter("_csrf")).isNotNull(); assertThat(request.getParameter("_csrf")).isNotNull();
} }
@ -50,15 +53,26 @@ public class SecurityMockMvcRequestBuildersFormLoginTests {
@Test @Test
public void custom() throws Exception { public void custom() throws Exception {
MockHttpServletRequest request = formLogin("/login").user("username", "admin") MockHttpServletRequest request = formLogin("/login").user("username", "admin")
.password("password", "secret").buildRequest(servletContext); .password("password", "secret").buildRequest(this.servletContext);
CsrfToken token = (CsrfToken) request.getAttribute(CsrfRequestPostProcessor.TestCsrfTokenRepository.ATTR_NAME); CsrfToken token = (CsrfToken) request
.getAttribute(CsrfRequestPostProcessor.TestCsrfTokenRepository.ATTR_NAME);
assertThat(request.getParameter("username")).isEqualTo("admin"); assertThat(request.getParameter("username")).isEqualTo("admin");
assertThat(request.getParameter("password")).isEqualTo("secret"); assertThat(request.getParameter("password")).isEqualTo("secret");
assertThat(request.getMethod()).isEqualTo("POST"); assertThat(request.getMethod()).isEqualTo("POST");
assertThat(request.getParameter(token.getParameterName())).isEqualTo( assertThat(request.getParameter(token.getParameterName()))
token.getToken()); .isEqualTo(token.getToken());
assertThat(request.getRequestURI()).isEqualTo("/login"); assertThat(request.getRequestURI()).isEqualTo("/login");
} }
// gh-3920
@Test
public void usesAcceptMediaForContentNegotiation() throws Exception {
MockHttpServletRequest request = formLogin("/login").user("username", "admin")
.password("password", "secret").buildRequest(this.servletContext);
assertThat(request.getHeader("Accept"))
.isEqualTo(MediaType.APPLICATION_FORM_URLENCODED_VALUE);
}
} }