aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/org/junit/Rule.java
blob: 711235c5a7f3b34f541e17bffec5594011a0eaba (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
package org.junit;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
 * Annotates fields that reference rules or methods that return a rule. A field must be public, not
 * static, and a subtype of {@link org.junit.rules.TestRule} (preferred) or
 * {@link org.junit.rules.MethodRule}. A method must be public, not static,
 * and must return a subtype of {@link org.junit.rules.TestRule} (preferred) or
 * {@link org.junit.rules.MethodRule}.
 * <p>
 * The {@link org.junit.runners.model.Statement} passed
 * to the {@link org.junit.rules.TestRule} will run any {@link Before} methods,
 * then the {@link Test} method, and finally any {@link After} methods,
 * throwing an exception if any of these fail.  If there are multiple
 * annotated {@link Rule}s on a class, they will be applied in order of fields first, then methods.
 * However, if there are multiple fields (or methods) they will be applied in an order
 * that depends on your JVM's implementation of the reflection API, which is
 * undefined, in general. Rules defined by fields will always be applied
 * before Rules defined by methods. You can use a {@link org.junit.rules.RuleChain} if you want
 * to have control over the order in which the Rules are applied.
 * <p>
 * For example, here is a test class that creates a temporary folder before
 * each test method, and deletes it after each:
 * <pre>
 * public static class HasTempFolder {
 *     &#064;Rule
 *     public TemporaryFolder folder= new TemporaryFolder();
 *
 *     &#064;Test
 *     public void testUsingTempFolder() throws IOException {
 *         File createdFile= folder.newFile(&quot;myfile.txt&quot;);
 *         File createdFolder= folder.newFolder(&quot;subfolder&quot;);
 *         // ...
 *     }
 * }
 * </pre>
 * <p>
 * And the same using a method.
 * <pre>
 * public static class HasTempFolder {
 *     private TemporaryFolder folder= new TemporaryFolder();
 *
 *     &#064;Rule
 *     public TemporaryFolder getFolder() {
 *         return folder;
 *     }
 *
 *     &#064;Test
 *     public void testUsingTempFolder() throws IOException {
 *         File createdFile= folder.newFile(&quot;myfile.txt&quot;);
 *         File createdFolder= folder.newFolder(&quot;subfolder&quot;);
 *         // ...
 *     }
 * }
 * </pre>
 * <p>
 * For more information and more examples, see
 * {@link org.junit.rules.TestRule}.
 *
 * @since 4.7
 */
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.FIELD, ElementType.METHOD})
public @interface Rule {

}