Procházet zdrojové kódy

OPEN - issue SEC-881: PreAuthenticatedFilter continues filter chain after unsuccessfulAuthentication(...)
http://jira.springframework.org/browse/SEC-881. Added test class.

Luke Taylor před 17 roky
rodič
revize
000bb1cbed

+ 55 - 0
core/src/test/java/org/springframework/security/ui/preauth/AbstractPreAuthenticatedProcessingFilterTests.java

@@ -0,0 +1,55 @@
+package org.springframework.security.ui.preauth;
+
+import static org.junit.Assert.*;
+
+import javax.servlet.http.HttpServletRequest;
+
+import org.junit.Before;
+import org.junit.Test;
+import org.springframework.mock.web.MockHttpServletRequest;
+import org.springframework.mock.web.MockHttpServletResponse;
+import org.springframework.security.BadCredentialsException;
+import org.springframework.security.MockAuthenticationManager;
+import org.springframework.security.context.SecurityContextHolder;
+import org.springframework.security.util.MockFilterChain;
+
+public class AbstractPreAuthenticatedProcessingFilterTests {
+	private AbstractPreAuthenticatedProcessingFilter filter;
+	
+	@Before
+	public void createFilter() {
+		filter = new AbstractPreAuthenticatedProcessingFilter() {
+			protected Object getPreAuthenticatedCredentials(HttpServletRequest request) {
+				return "n/a";
+			}
+
+			protected Object getPreAuthenticatedPrincipal(HttpServletRequest request) {
+				return "doesntmatter";
+			}
+
+			public int getOrder() {
+				return 0;
+			}
+		};
+		SecurityContextHolder.getContext().setAuthentication(null);
+	}
+
+	@Test
+	public void filterChainProceedsOnFailedAuthenticationByDefault() throws Exception {
+		filter.setAuthenticationManager(new MockAuthenticationManager(false));
+		filter.afterPropertiesSet();		
+		filter.doFilter(new MockHttpServletRequest(), new MockHttpServletResponse(), new MockFilterChain(true));
+		assertNull(SecurityContextHolder.getContext().getAuthentication());
+	}	
+	
+	/* SEC-881 */
+	@Test(expected=BadCredentialsException.class)
+	public void exceptionIsThrownOnFailedAuthenticationIfContinueFilterChainOnUnsuccessfulAuthenticationSetToFalse() throws Exception {
+		filter.setContinueFilterChainOnUnsuccessfulAuthentication(false);
+		filter.setAuthenticationManager(new MockAuthenticationManager(false));
+		filter.afterPropertiesSet();		
+		filter.doFilter(new MockHttpServletRequest(), new MockHttpServletResponse(), new MockFilterChain(false));
+		assertNull(SecurityContextHolder.getContext().getAuthentication());
+	}
+
+}