提交 51eccf55 编写于 作者: S Sam Brannen

Polish ServletTestExecutionListener[Tests]

上级 bb590db3
...@@ -61,6 +61,7 @@ import org.springframework.web.context.request.ServletWebRequest; ...@@ -61,6 +61,7 @@ import org.springframework.web.context.request.ServletWebRequest;
* See the Javadoc for individual methods in this class for details. * See the Javadoc for individual methods in this class for details.
* *
* @author Sam Brannen * @author Sam Brannen
* @author Phillip Webb
* @since 3.2 * @since 3.2
*/ */
public class ServletTestExecutionListener extends AbstractTestExecutionListener { public class ServletTestExecutionListener extends AbstractTestExecutionListener {
...@@ -99,14 +100,16 @@ public class ServletTestExecutionListener extends AbstractTestExecutionListener ...@@ -99,14 +100,16 @@ public class ServletTestExecutionListener extends AbstractTestExecutionListener
ServletTestExecutionListener.class, "createdByTheTestContextFramework"); ServletTestExecutionListener.class, "createdByTheTestContextFramework");
/** /**
* Attribute name for a {@link TestContext} attribute which indicates that * Attribute name for a {@link TestContext} attribute which indicates that that
* that the {@link ServletTestExecutionListener} should be activated. When * the {@code ServletTestExecutionListener} should be activated. When not set to
* not specified activation occurs when the {@linkplain TestContext#getTestClass() * {@code true}, activation occurs when the {@linkplain TestContext#getTestClass()
* test class} is annotated with {@link WebAppConfiguration @WebAppConfiguration}. * test class} is annotated with {@link WebAppConfiguration @WebAppConfiguration}.
* @since 4.4 *
* <p>Permissible values include {@link Boolean#TRUE} and {@link Boolean#FALSE}.
* @since 4.3
*/ */
public static final String ACTIVATE_LISTENER = Conventions.getQualifiedAttributeName( public static final String ACTIVATE_LISTENER = Conventions.getQualifiedAttributeName(
ServletTestExecutionListener.class, "webApplicationConfiguration"); ServletTestExecutionListener.class, "activateListener");
private static final Log logger = LogFactory.getLog(ServletTestExecutionListener.class); private static final Log logger = LogFactory.getLog(ServletTestExecutionListener.class);
......
...@@ -38,11 +38,12 @@ import static org.springframework.test.context.web.ServletTestExecutionListener. ...@@ -38,11 +38,12 @@ import static org.springframework.test.context.web.ServletTestExecutionListener.
* Unit tests for {@link ServletTestExecutionListener}. * Unit tests for {@link ServletTestExecutionListener}.
* *
* @author Sam Brannen * @author Sam Brannen
* @author Phillip Webb
* @since 3.2.6 * @since 3.2.6
*/ */
public class ServletTestExecutionListenerTests { public class ServletTestExecutionListenerTests {
private static final String SET_UP_OUTSIDE_OF_STEL = "SET_UP_OUTSIDE_OF_STEL"; private static final String SET_UP_OUTSIDE_OF_STEL = "setUpOutsideOfStel";
private final WebApplicationContext wac = mock(WebApplicationContext.class); private final WebApplicationContext wac = mock(WebApplicationContext.class);
private final MockServletContext mockServletContext = new MockServletContext(); private final MockServletContext mockServletContext = new MockServletContext();
...@@ -50,30 +51,6 @@ public class ServletTestExecutionListenerTests { ...@@ -50,30 +51,6 @@ public class ServletTestExecutionListenerTests {
private final ServletTestExecutionListener listener = new ServletTestExecutionListener(); private final ServletTestExecutionListener listener = new ServletTestExecutionListener();
private void assertAttributesAvailable() {
assertNotNull("request attributes should be available", RequestContextHolder.getRequestAttributes());
}
private void assertAttributesNotAvailable() {
assertNull("request attributes should not be available", RequestContextHolder.getRequestAttributes());
}
private void assertAttributeExists() {
RequestAttributes requestAttributes = RequestContextHolder.getRequestAttributes();
assertNotNull("request attributes should exist", requestAttributes);
Object setUpOutsideOfStel = requestAttributes.getAttribute(SET_UP_OUTSIDE_OF_STEL,
RequestAttributes.SCOPE_REQUEST);
assertNotNull(SET_UP_OUTSIDE_OF_STEL + " should exist as a request attribute", setUpOutsideOfStel);
}
private void assertAttributeDoesNotExist() {
RequestAttributes requestAttributes = RequestContextHolder.getRequestAttributes();
assertNotNull("request attributes should exist", requestAttributes);
Object setUpOutsideOfStel = requestAttributes.getAttribute(SET_UP_OUTSIDE_OF_STEL,
RequestAttributes.SCOPE_REQUEST);
assertNull(SET_UP_OUTSIDE_OF_STEL + " should NOT exist as a request attribute", setUpOutsideOfStel);
}
@Before @Before
public void setUp() { public void setUp() {
given(wac.getServletContext()).willReturn(mockServletContext); given(wac.getServletContext()).willReturn(mockServletContext);
...@@ -86,7 +63,7 @@ public class ServletTestExecutionListenerTests { ...@@ -86,7 +63,7 @@ public class ServletTestExecutionListenerTests {
request.setAttribute(SET_UP_OUTSIDE_OF_STEL, "true"); request.setAttribute(SET_UP_OUTSIDE_OF_STEL, "true");
RequestContextHolder.setRequestAttributes(servletWebRequest); RequestContextHolder.setRequestAttributes(servletWebRequest);
assertAttributeExists(); assertSetUpOutsideOfStelAttributeExists();
} }
@Test @Test
...@@ -95,16 +72,16 @@ public class ServletTestExecutionListenerTests { ...@@ -95,16 +72,16 @@ public class ServletTestExecutionListenerTests {
given(testContext.getApplicationContext()).willReturn(mock(ApplicationContext.class)); given(testContext.getApplicationContext()).willReturn(mock(ApplicationContext.class));
listener.beforeTestClass(testContext); listener.beforeTestClass(testContext);
assertAttributeExists(); assertSetUpOutsideOfStelAttributeExists();
listener.prepareTestInstance(testContext); listener.prepareTestInstance(testContext);
assertAttributeExists(); assertSetUpOutsideOfStelAttributeExists();
listener.beforeTestMethod(testContext); listener.beforeTestMethod(testContext);
assertAttributeExists(); assertSetUpOutsideOfStelAttributeExists();
listener.afterTestMethod(testContext); listener.afterTestMethod(testContext);
assertAttributeExists(); assertSetUpOutsideOfStelAttributeExists();
} }
@Test @Test
...@@ -112,22 +89,22 @@ public class ServletTestExecutionListenerTests { ...@@ -112,22 +89,22 @@ public class ServletTestExecutionListenerTests {
BDDMockito.<Class<?>> given(testContext.getTestClass()).willReturn(LegacyWebTestCase.class); BDDMockito.<Class<?>> given(testContext.getTestClass()).willReturn(LegacyWebTestCase.class);
RequestContextHolder.resetRequestAttributes(); RequestContextHolder.resetRequestAttributes();
assertAttributesNotAvailable(); assertRequestAttributesDoNotExist();
listener.beforeTestClass(testContext); listener.beforeTestClass(testContext);
listener.prepareTestInstance(testContext); listener.prepareTestInstance(testContext);
assertAttributesNotAvailable(); assertRequestAttributesDoNotExist();
verify(testContext, times(0)).setAttribute(RESET_REQUEST_CONTEXT_HOLDER_ATTRIBUTE, Boolean.TRUE); verify(testContext, times(0)).setAttribute(RESET_REQUEST_CONTEXT_HOLDER_ATTRIBUTE, Boolean.TRUE);
given(testContext.getAttribute(RESET_REQUEST_CONTEXT_HOLDER_ATTRIBUTE)).willReturn(null); given(testContext.getAttribute(RESET_REQUEST_CONTEXT_HOLDER_ATTRIBUTE)).willReturn(null);
listener.beforeTestMethod(testContext); listener.beforeTestMethod(testContext);
assertAttributesNotAvailable(); assertRequestAttributesDoNotExist();
verify(testContext, times(0)).setAttribute(RESET_REQUEST_CONTEXT_HOLDER_ATTRIBUTE, Boolean.TRUE); verify(testContext, times(0)).setAttribute(RESET_REQUEST_CONTEXT_HOLDER_ATTRIBUTE, Boolean.TRUE);
listener.afterTestMethod(testContext); listener.afterTestMethod(testContext);
verify(testContext, times(1)).removeAttribute(RESET_REQUEST_CONTEXT_HOLDER_ATTRIBUTE); verify(testContext, times(1)).removeAttribute(RESET_REQUEST_CONTEXT_HOLDER_ATTRIBUTE);
assertAttributesNotAvailable(); assertRequestAttributesDoNotExist();
} }
@Test @Test
...@@ -135,21 +112,21 @@ public class ServletTestExecutionListenerTests { ...@@ -135,21 +112,21 @@ public class ServletTestExecutionListenerTests {
BDDMockito.<Class<?>> given(testContext.getTestClass()).willReturn(LegacyWebTestCase.class); BDDMockito.<Class<?>> given(testContext.getTestClass()).willReturn(LegacyWebTestCase.class);
listener.beforeTestClass(testContext); listener.beforeTestClass(testContext);
assertAttributeExists(); assertSetUpOutsideOfStelAttributeExists();
listener.prepareTestInstance(testContext); listener.prepareTestInstance(testContext);
assertAttributeExists(); assertSetUpOutsideOfStelAttributeExists();
verify(testContext, times(0)).setAttribute(RESET_REQUEST_CONTEXT_HOLDER_ATTRIBUTE, Boolean.TRUE); verify(testContext, times(0)).setAttribute(RESET_REQUEST_CONTEXT_HOLDER_ATTRIBUTE, Boolean.TRUE);
given(testContext.getAttribute(RESET_REQUEST_CONTEXT_HOLDER_ATTRIBUTE)).willReturn(null); given(testContext.getAttribute(RESET_REQUEST_CONTEXT_HOLDER_ATTRIBUTE)).willReturn(null);
listener.beforeTestMethod(testContext); listener.beforeTestMethod(testContext);
assertAttributeExists(); assertSetUpOutsideOfStelAttributeExists();
verify(testContext, times(0)).setAttribute(RESET_REQUEST_CONTEXT_HOLDER_ATTRIBUTE, Boolean.TRUE); verify(testContext, times(0)).setAttribute(RESET_REQUEST_CONTEXT_HOLDER_ATTRIBUTE, Boolean.TRUE);
given(testContext.getAttribute(RESET_REQUEST_CONTEXT_HOLDER_ATTRIBUTE)).willReturn(null); given(testContext.getAttribute(RESET_REQUEST_CONTEXT_HOLDER_ATTRIBUTE)).willReturn(null);
listener.afterTestMethod(testContext); listener.afterTestMethod(testContext);
verify(testContext, times(1)).removeAttribute(RESET_REQUEST_CONTEXT_HOLDER_ATTRIBUTE); verify(testContext, times(1)).removeAttribute(RESET_REQUEST_CONTEXT_HOLDER_ATTRIBUTE);
assertAttributeExists(); assertSetUpOutsideOfStelAttributeExists();
} }
@Test @Test
...@@ -158,7 +135,7 @@ public class ServletTestExecutionListenerTests { ...@@ -158,7 +135,7 @@ public class ServletTestExecutionListenerTests {
RequestContextHolder.resetRequestAttributes(); RequestContextHolder.resetRequestAttributes();
listener.beforeTestClass(testContext); listener.beforeTestClass(testContext);
assertAttributesNotAvailable(); assertRequestAttributesDoNotExist();
assertWebAppConfigTestCase(); assertWebAppConfigTestCase();
} }
...@@ -168,40 +145,70 @@ public class ServletTestExecutionListenerTests { ...@@ -168,40 +145,70 @@ public class ServletTestExecutionListenerTests {
BDDMockito.<Class<?>> given(testContext.getTestClass()).willReturn(AtWebAppConfigWebTestCase.class); BDDMockito.<Class<?>> given(testContext.getTestClass()).willReturn(AtWebAppConfigWebTestCase.class);
listener.beforeTestClass(testContext); listener.beforeTestClass(testContext);
assertAttributesAvailable(); assertRequestAttributesExist();
assertWebAppConfigTestCase(); assertWebAppConfigTestCase();
} }
/**
* @since 4.3
*/
@Test @Test
public void activateAttributeAppConfigTestCaseWithoutExistingRequestAttributes() throws Exception { public void activateListenerWithoutExistingRequestAttributes() throws Exception {
BDDMockito.<Class<?>> given(testContext.getTestClass()).willReturn(NoAtWebAppConfigWebTestCase.class); BDDMockito.<Class<?>> given(testContext.getTestClass()).willReturn(NoAtWebAppConfigWebTestCase.class);
given(testContext.getAttribute(ServletTestExecutionListener.ACTIVATE_LISTENER)).willReturn(true); given(testContext.getAttribute(ServletTestExecutionListener.ACTIVATE_LISTENER)).willReturn(true);
RequestContextHolder.resetRequestAttributes(); RequestContextHolder.resetRequestAttributes();
listener.beforeTestClass(testContext); listener.beforeTestClass(testContext);
assertAttributesNotAvailable(); assertRequestAttributesDoNotExist();
assertWebAppConfigTestCase(); assertWebAppConfigTestCase();
} }
private RequestAttributes assertRequestAttributesExist() {
RequestAttributes requestAttributes = RequestContextHolder.getRequestAttributes();
assertNotNull("request attributes should exist", requestAttributes);
return requestAttributes;
}
private void assertRequestAttributesDoNotExist() {
assertNull("request attributes should not not exist", RequestContextHolder.getRequestAttributes());
}
private void assertSetUpOutsideOfStelAttributeExists() {
RequestAttributes requestAttributes = assertRequestAttributesExist();
Object setUpOutsideOfStel = requestAttributes.getAttribute(SET_UP_OUTSIDE_OF_STEL,
RequestAttributes.SCOPE_REQUEST);
assertNotNull(SET_UP_OUTSIDE_OF_STEL + " should exist as a request attribute", setUpOutsideOfStel);
}
private void assertSetUpOutsideOfStelAttributeDoesNotExist() {
RequestAttributes requestAttributes = assertRequestAttributesExist();
Object setUpOutsideOfStel = requestAttributes.getAttribute(SET_UP_OUTSIDE_OF_STEL,
RequestAttributes.SCOPE_REQUEST);
assertNull(SET_UP_OUTSIDE_OF_STEL + " should NOT exist as a request attribute", setUpOutsideOfStel);
}
private void assertWebAppConfigTestCase() throws Exception { private void assertWebAppConfigTestCase() throws Exception {
listener.prepareTestInstance(testContext); listener.prepareTestInstance(testContext);
assertAttributeDoesNotExist(); assertRequestAttributesExist();
assertSetUpOutsideOfStelAttributeDoesNotExist();
verify(testContext, times(1)).setAttribute(POPULATED_REQUEST_CONTEXT_HOLDER_ATTRIBUTE, Boolean.TRUE); verify(testContext, times(1)).setAttribute(POPULATED_REQUEST_CONTEXT_HOLDER_ATTRIBUTE, Boolean.TRUE);
verify(testContext, times(1)).setAttribute(RESET_REQUEST_CONTEXT_HOLDER_ATTRIBUTE, Boolean.TRUE); verify(testContext, times(1)).setAttribute(RESET_REQUEST_CONTEXT_HOLDER_ATTRIBUTE, Boolean.TRUE);
given(testContext.getAttribute(POPULATED_REQUEST_CONTEXT_HOLDER_ATTRIBUTE)).willReturn(Boolean.TRUE); given(testContext.getAttribute(POPULATED_REQUEST_CONTEXT_HOLDER_ATTRIBUTE)).willReturn(Boolean.TRUE);
given(testContext.getAttribute(RESET_REQUEST_CONTEXT_HOLDER_ATTRIBUTE)).willReturn(Boolean.TRUE); given(testContext.getAttribute(RESET_REQUEST_CONTEXT_HOLDER_ATTRIBUTE)).willReturn(Boolean.TRUE);
listener.beforeTestMethod(testContext); listener.beforeTestMethod(testContext);
assertAttributeDoesNotExist(); assertRequestAttributesExist();
assertSetUpOutsideOfStelAttributeDoesNotExist();
verify(testContext, times(1)).setAttribute(POPULATED_REQUEST_CONTEXT_HOLDER_ATTRIBUTE, Boolean.TRUE); verify(testContext, times(1)).setAttribute(POPULATED_REQUEST_CONTEXT_HOLDER_ATTRIBUTE, Boolean.TRUE);
verify(testContext, times(1)).setAttribute(RESET_REQUEST_CONTEXT_HOLDER_ATTRIBUTE, Boolean.TRUE); verify(testContext, times(1)).setAttribute(RESET_REQUEST_CONTEXT_HOLDER_ATTRIBUTE, Boolean.TRUE);
listener.afterTestMethod(testContext); listener.afterTestMethod(testContext);
verify(testContext).removeAttribute(POPULATED_REQUEST_CONTEXT_HOLDER_ATTRIBUTE); verify(testContext).removeAttribute(POPULATED_REQUEST_CONTEXT_HOLDER_ATTRIBUTE);
verify(testContext).removeAttribute(RESET_REQUEST_CONTEXT_HOLDER_ATTRIBUTE); verify(testContext).removeAttribute(RESET_REQUEST_CONTEXT_HOLDER_ATTRIBUTE);
assertAttributesNotAvailable(); assertRequestAttributesDoNotExist();
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册