注释类型 DisabledIf


  • @Target({TYPE,METHOD})
    @Retention(RUNTIME)
    @Documented
    @ExtendWith(DisabledIfCondition.class)
    public @interface DisabledIf
    @DisabledIf is used to signal that the annotated test class or test method is disabled and should not be executed if the supplied expression() evaluates to true.

    When applied at the class level, all test methods within that class are automatically disabled 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 @DisabledOnMac annotation can be created as follows.

     @Target({ElementType.TYPE, ElementType.METHOD})
     @Retention(RetentionPolicy.RUNTIME)
     @DisabledIf(
         expression = "#{systemProperties['os.name'].toLowerCase().contains('mac')}",
         reason = "Disabled on Mac OS"
     )
     public @interface DisabledOnMac {}
     
    从以下版本开始:
    5.0
    作者:
    Sam Brannen, Tadaya Tsuyukubo
    另请参阅:
    SpringExtension, EnabledIf, Disabled
    • 可选元素概要

      可选元素 
      修饰符和类型可选元素说明
      Stringexpression
      The expression that will be evaluated to determine if the annotated test class or test method is disabled.
      booleanloadContext
      Whether the ApplicationContext associated with the current test should be eagerly loaded in order to evaluate the expression().
      Stringreason
      The reason this test is disabled.
      Stringvalue
      Alias for expression(); only intended to be used if reason() and loadContext() are not specified.
      • expression

        @AliasFor("value")
        String expression
        The expression that will be evaluated to determine if the annotated test class or test method is disabled.

        If the expression evaluates to Boolean.TRUE or a String equal to "true" (ignoring case), the test will be disabled.

        Expressions can be any of the following.

        • Spring Expression Language (SpEL) expression — for example:
          @DisabledIf("#{systemProperties['os.name'].toLowerCase().contains('mac')}")
        • Placeholder for a property available in the Spring Environment — for example:
          @DisabledIf("${smoke.tests.disabled}")
        • Text literal — for example:
          @DisabledIf("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 @DisabledIf("true") is equivalent to @Disabled and @DisabledIf("false") is logically meaningless.

        另请参阅:
        reason(), loadContext(), value()
        默认值:
        ""
      • loadContext

        boolean loadContext
        Whether the 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()
        默认值:
        false