Home | History | Annotate | Download | only in junitparams
      1 package junitparams;
      2 
      3 import java.lang.annotation.Retention;
      4 import java.lang.annotation.RetentionPolicy;
      5 
      6 /**
      7  * THE annotation for the test parameters. Use it to say that a method takes
      8  * some parameters and define how to obtain them.
      9  *
     10  * @author Pawel Lipinski
     11  */
     12 @Retention(RetentionPolicy.RUNTIME)
     13 public @interface Parameters {
     14     /**
     15      * Parameter values defined as a String array. Each element in the array is
     16      * a full parameter set, comma-separated or pipe-separated ('|').
     17      * The values must match the method parameters in order and type.
     18      * Whitespace characters are trimmed (use source class or method if You need to provide such parameters)
     19      *
     20      * Example: <code>@Parameters({
     21      *                    "1, joe, 26.4, true",
     22      *                    "2, angie, 37.2, false"})</code>
     23      */
     24     String[] value() default {};
     25 
     26     /**
     27      * Parameter values defined externally. The specified class must have at
     28      * least one public static method starting with <code>provide</code>
     29      * returning <code>Object[]</code>. All such methods are used, so you can
     30      * group your examples. The resulting array should contain parameter sets in
     31      * its elements. Each parameter set must be another Object[] array, which
     32      * contains parameter values in its elements.
     33      * Example: <code>@Parameters(source = PeopleProvider.class)</code>
     34      */
     35     Class<?> source() default Void.class;
     36 
     37     /**
     38      * Parameter values returned by a method within the test class. This way you
     39      * don't need additional classes and the test code may be a bit cleaner. The
     40      * format of the data returned by the method is the same as for the source
     41      * annotation class.
     42      * Example: <code>@Parameters(method = "examplaryPeople")</code>
     43      *
     44      * You can use multiple methods to provide parameters - use comma to do it:
     45      * Example: <code>@Parameters(method = "womenParams, menParams")</code>
     46      */
     47     String method() default "";
     48 }
     49