Annotation Type ASTTest


  • @Documented
    @Retention(RUNTIME)
    @Target({PACKAGE,TYPE,ANNOTATION_TYPE,CONSTRUCTOR,METHOD,FIELD,PARAMETER,LOCAL_VARIABLE})
    public @interface ASTTest
    This AST transformation aims at helping in debugging other AST transformations. It provides a basic infrastructure for performing tests on AST nodes. You can place this annotation on any node which accepts an annotation (types, methods, annotations, constructors, fields, local variables, packages or parameters), then use a script which is run against this AST node at a specific phase. For example, you could test the Field AST transformation this way:
     import groovy.transform.*
    
     @ASTTest(value = {
        def owner = node.declaringClass
        assert owner.fields.any { it.name == 'x' }
      })
     @Field int x
     
    The closure code is executed after the specified phase has completed. If no phase is provided, then the code is executed after the semantic analysis phase and each subsequent phase.

    The node variable refers to the AST node where the AST test annotation is put. In the previous example, it means that node refers to the declaration "int x".

    Since:
    2.0.0
    • Required Element Summary

      Required Elements 
      Modifier and Type Required Element Description
      Class value
      A closure which is executed against the annotated node after the specified phase has completed.
    • Optional Element Summary

      Optional Elements 
      Modifier and Type Optional Element Description
      CompilePhase phase
      The compile phase after which the test code should run.
    • Element Detail

      • value

        Class value
        A closure which is executed against the annotated node after the specified phase has completed.
      • phase

        CompilePhase phase
        The compile phase after which the test code should run.
        Default:
        org.codehaus.groovy.control.CompilePhase.SEMANTIC_ANALYSIS