|
@@ -15,21 +15,32 @@
|
|
*/
|
|
*/
|
|
package org.springframework.security.web.header;
|
|
package org.springframework.security.web.header;
|
|
|
|
|
|
-import static org.assertj.core.api.Assertions.assertThat;
|
|
|
|
-import static org.mockito.Mockito.verify;
|
|
|
|
-
|
|
|
|
|
|
+import java.io.IOException;
|
|
import java.util.ArrayList;
|
|
import java.util.ArrayList;
|
|
|
|
+import java.util.Arrays;
|
|
import java.util.List;
|
|
import java.util.List;
|
|
|
|
|
|
|
|
+import javax.servlet.FilterChain;
|
|
|
|
+import javax.servlet.ServletException;
|
|
|
|
+import javax.servlet.ServletRequest;
|
|
|
|
+import javax.servlet.ServletResponse;
|
|
|
|
+import javax.servlet.http.HttpServletRequest;
|
|
|
|
+import javax.servlet.http.HttpServletResponse;
|
|
|
|
+
|
|
import org.junit.Test;
|
|
import org.junit.Test;
|
|
import org.junit.runner.RunWith;
|
|
import org.junit.runner.RunWith;
|
|
import org.mockito.Mock;
|
|
import org.mockito.Mock;
|
|
-import org.mockito.junit.MockitoJUnitRunner;
|
|
|
|
|
|
+import org.mockito.runners.MockitoJUnitRunner;
|
|
|
|
+
|
|
import org.springframework.mock.web.MockFilterChain;
|
|
import org.springframework.mock.web.MockFilterChain;
|
|
import org.springframework.mock.web.MockHttpServletRequest;
|
|
import org.springframework.mock.web.MockHttpServletRequest;
|
|
import org.springframework.mock.web.MockHttpServletResponse;
|
|
import org.springframework.mock.web.MockHttpServletResponse;
|
|
-import org.springframework.security.web.header.HeaderWriter;
|
|
|
|
-import org.springframework.security.web.header.HeaderWriterFilter;
|
|
|
|
|
|
+
|
|
|
|
+import static org.assertj.core.api.Assertions.assertThat;
|
|
|
|
+import static org.mockito.Matchers.any;
|
|
|
|
+import static org.mockito.Mockito.verify;
|
|
|
|
+import static org.mockito.Mockito.verifyNoMoreInteractions;
|
|
|
|
+import static org.mockito.Mockito.verifyZeroInteractions;
|
|
|
|
|
|
/**
|
|
/**
|
|
* Tests for the {@code HeadersFilter}
|
|
* Tests for the {@code HeadersFilter}
|
|
@@ -60,8 +71,8 @@ public class HeaderWriterFilterTests {
|
|
@Test
|
|
@Test
|
|
public void additionalHeadersShouldBeAddedToTheResponse() throws Exception {
|
|
public void additionalHeadersShouldBeAddedToTheResponse() throws Exception {
|
|
List<HeaderWriter> headerWriters = new ArrayList<>();
|
|
List<HeaderWriter> headerWriters = new ArrayList<>();
|
|
- headerWriters.add(writer1);
|
|
|
|
- headerWriters.add(writer2);
|
|
|
|
|
|
+ headerWriters.add(this.writer1);
|
|
|
|
+ headerWriters.add(this.writer2);
|
|
|
|
|
|
HeaderWriterFilter filter = new HeaderWriterFilter(headerWriters);
|
|
HeaderWriterFilter filter = new HeaderWriterFilter(headerWriters);
|
|
|
|
|
|
@@ -71,9 +82,34 @@ public class HeaderWriterFilterTests {
|
|
|
|
|
|
filter.doFilter(request, response, filterChain);
|
|
filter.doFilter(request, response, filterChain);
|
|
|
|
|
|
- verify(writer1).writeHeaders(request, response);
|
|
|
|
- verify(writer2).writeHeaders(request, response);
|
|
|
|
|
|
+ verify(this.writer1).writeHeaders(request, response);
|
|
|
|
+ verify(this.writer2).writeHeaders(request, response);
|
|
assertThat(filterChain.getRequest()).isEqualTo(request); // verify the filterChain
|
|
assertThat(filterChain.getRequest()).isEqualTo(request); // verify the filterChain
|
|
// continued
|
|
// continued
|
|
}
|
|
}
|
|
|
|
+
|
|
|
|
+ // gh-2953
|
|
|
|
+ @Test
|
|
|
|
+ public void headersDelayed() throws Exception {
|
|
|
|
+ HeaderWriterFilter filter = new HeaderWriterFilter(
|
|
|
|
+ Arrays.<HeaderWriter>asList(this.writer1));
|
|
|
|
+
|
|
|
|
+ MockHttpServletRequest request = new MockHttpServletRequest();
|
|
|
|
+ MockHttpServletResponse response = new MockHttpServletResponse();
|
|
|
|
+
|
|
|
|
+ filter.doFilter(request, response, new FilterChain() {
|
|
|
|
+ @Override
|
|
|
|
+ public void doFilter(ServletRequest request, ServletResponse response)
|
|
|
|
+ throws IOException, ServletException {
|
|
|
|
+ verifyZeroInteractions(HeaderWriterFilterTests.this.writer1);
|
|
|
|
+
|
|
|
|
+ response.flushBuffer();
|
|
|
|
+
|
|
|
|
+ verify(HeaderWriterFilterTests.this.writer1).writeHeaders(
|
|
|
|
+ any(HttpServletRequest.class), any(HttpServletResponse.class));
|
|
|
|
+ }
|
|
|
|
+ });
|
|
|
|
+
|
|
|
|
+ verifyNoMoreInteractions(this.writer1);
|
|
|
|
+ }
|
|
}
|
|
}
|