public class SpringMethodRule extends Object implements org.junit.rules.MethodRule
SpringMethodRule
is a custom JUnit 4 MethodRule
that
supports instance-level and method-level features of the
Spring TestContext Framework in standard JUnit tests by means
of the TestContextManager
and associated support classes and
annotations.
In contrast to the SpringJUnit4ClassRunner
, Spring's rule-based JUnit support has the advantage
that it is independent of any Runner
and
can therefore be combined with existing alternative runners like JUnit's
Parameterized
or third-party runners such as the MockitoJUnitRunner
.
In order to achieve the same functionality as the SpringJUnit4ClassRunner
,
however, a SpringMethodRule
must be combined with a SpringClassRule
,
since SpringMethodRule
only supports the instance-level and method-level
features of the SpringJUnit4ClassRunner
.
public class ExampleSpringIntegrationTest {
@ClassRule
public static final SpringClassRule springClassRule = new SpringClassRule();
@Rule
public final SpringMethodRule springMethodRule = new SpringMethodRule();
// ...
}
The following list constitutes all annotations currently supported directly
or indirectly by SpringMethodRule
. (Note that additional annotations
may be supported by various
TestExecutionListener
or
TestContextBootstrapper
implementations.)
NOTE: As of Spring Framework 4.3, this class requires JUnit 4.12 or higher.
WARNING: Due to the shortcomings of JUnit rules, the
SpringMethodRule
does not support the
beforeTestExecution()
and afterTestExecution()
callbacks of the
TestExecutionListener
API.
apply(Statement, FrameworkMethod, Object)
,
SpringClassRule
,
TestContextManager
,
SpringJUnit4ClassRunner
Constructor and Description |
---|
SpringMethodRule() |
Modifier and Type | Method and Description |
---|---|
org.junit.runners.model.Statement |
apply(org.junit.runners.model.Statement base,
org.junit.runners.model.FrameworkMethod frameworkMethod,
Object testInstance)
Apply instance-level and method-level features of
the Spring TestContext Framework to the supplied
base
statement. |
public org.junit.runners.model.Statement apply(org.junit.runners.model.Statement base, org.junit.runners.model.FrameworkMethod frameworkMethod, Object testInstance)
base
statement.
Specifically, this method invokes the
prepareTestInstance()
,
beforeTestMethod()
, and
afterTestMethod()
methods
on the TestContextManager
, potentially with Spring timeouts
and repetitions.
In addition, this method checks whether the test is enabled in
the current execution environment. This prevents methods with a
non-matching @IfProfileValue
annotation from running altogether,
even skipping the execution of prepareTestInstance()
methods
in TestExecutionListeners
.
apply
in interface org.junit.rules.MethodRule
base
- the base Statement
that this rule should be applied toframeworkMethod
- the method which is about to be invoked on the test instancetestInstance
- the current test instancebase
with instance-level
and method-level features of the Spring TestContext FrameworkwithBeforeTestMethodCallbacks(org.junit.runners.model.Statement, java.lang.reflect.Method, java.lang.Object, org.springframework.test.context.TestContextManager)
,
withAfterTestMethodCallbacks(org.junit.runners.model.Statement, java.lang.reflect.Method, java.lang.Object, org.springframework.test.context.TestContextManager)
,
withPotentialRepeat(org.junit.runners.model.Statement, java.lang.reflect.Method, java.lang.Object)
,
withPotentialTimeout(org.junit.runners.model.Statement, java.lang.reflect.Method, java.lang.Object)
,
withTestInstancePreparation(org.junit.runners.model.Statement, java.lang.Object, org.springframework.test.context.TestContextManager)
,
withProfileValueCheck(org.junit.runners.model.Statement, java.lang.reflect.Method, java.lang.Object)