@Target(value={TYPE,METHOD}) @Retention(value=RUNTIME) @Documented @ExtendWith(value=EnabledIfCondition.class) public @interface EnabledIf
@EnabledIf
is used to signal that the annotated test class or test
method is enabled and should be executed if the supplied
expression()
evaluates to true
.
When applied at the class level, all test methods within that class are automatically enabled by default as well.
For basic examples, see the Javadoc for expression()
.
This annotation may be used as a meta-annotation to create
custom composed annotations. For example, a custom
@EnabledOnMac
annotation can be created as follows.
@Target({ElementType.TYPE, ElementType.METHOD}) @Retention(RetentionPolicy.RUNTIME) @EnabledIf( expression = "#{systemProperties['os.name'].toLowerCase().contains('mac')}", reason = "Enabled on Mac OS" ) public @interface EnabledOnMac {}
Please note that @EnabledOnMac
is meant only as an example of what
is possible. If you have that exact use case, please use the built-in
@EnabledOnOs(MAC)
support
in JUnit Jupiter.
Since JUnit 5.7, JUnit Jupiter also has a condition annotation named
@EnabledIf
. Thus, if you
wish to use Spring's @EnabledIf
support make sure you import the
annotation type from the correct package.
SpringExtension
,
DisabledIf
,
Disabled
,
EnabledIf
Modifier and Type | Optional Element and Description |
---|---|
String |
expression
The expression that will be evaluated to determine if the annotated test
class or test method is enabled.
|
boolean |
loadContext
Whether the
ApplicationContext associated with the current test
should be eagerly loaded in order to evaluate the expression() . |
String |
reason
The reason this test is enabled.
|
String |
value
|
@AliasFor(value="expression") public abstract String value
expression()
@AliasFor(value="value") public abstract String expression
If the expression evaluates to Boolean.TRUE
or a String
equal to "true"
(ignoring case), the test will be enabled.
Expressions can be any of the following.
@EnabledIf("#{systemProperties['os.name'].toLowerCase().contains('mac')}")
Environment
— for example:
@EnabledIf("${smoke.tests.enabled}")
@EnabledIf("true")
Note, however, that a text literal which is not the result of
dynamic resolution of a property placeholder is of zero practical value
since @EnabledIf("false")
is equivalent to @Disabled
and @EnabledIf("true")
is logically meaningless.
reason()
,
loadContext()
,
value()
public abstract String reason
expression()
public abstract boolean loadContext
ApplicationContext
associated with the current test
should be eagerly loaded in order to evaluate the expression()
.
Defaults to false
so that test application contexts are not
eagerly loaded unnecessarily. If an expression is based solely on system
properties or environment variables or does not interact with beans in
the test's application context, there is no need to load the context
prematurely since doing so would be a waste of time if the test ends up
being disabled.
expression()