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