forked from junit-team/junit4
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMethodRulesTest.java
408 lines (335 loc) · 11 KB
/
MethodRulesTest.java
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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
package org.junit.tests.experimental.rules;
import static org.hamcrest.CoreMatchers.containsString;
import static org.hamcrest.CoreMatchers.is;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertThat;
import static org.junit.Assert.assertTrue;
import static org.junit.Assert.fail;
import static org.junit.experimental.results.PrintableResult.testResult;
import static org.junit.experimental.results.ResultMatchers.hasSingleFailureContaining;
import static org.junit.experimental.results.ResultMatchers.isSuccessful;
import org.junit.After;
import org.junit.Before;
import org.junit.Rule;
import org.junit.Test;
import org.junit.rules.MethodRule;
import org.junit.rules.TestName;
import org.junit.rules.TestRule;
import org.junit.rules.TestWatchman;
import org.junit.runner.Description;
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runners.model.FrameworkMethod;
import org.junit.runners.model.Statement;
@SuppressWarnings("deprecation")
public class MethodRulesTest {
private static boolean wasRun;
public static class ExampleTest {
@Rule
public MethodRule example = new MethodRule() {
public Statement apply(final Statement base,
FrameworkMethod method, Object target) {
return new Statement() {
@Override
public void evaluate() throws Throwable {
wasRun = true;
base.evaluate();
}
;
};
}
};
@Test
public void nothing() {
}
}
@Test
public void ruleIsIntroducedAndEvaluated() {
wasRun = false;
JUnitCore.runClasses(ExampleTest.class);
assertTrue(wasRun);
}
public static class SonOfExampleTest extends ExampleTest {
}
@Test
public void ruleIsIntroducedAndEvaluatedOnSubclass() {
wasRun = false;
JUnitCore.runClasses(SonOfExampleTest.class);
assertTrue(wasRun);
}
private static int runCount;
private static class Increment implements MethodRule {
public Statement apply(final Statement base,
FrameworkMethod method, Object target) {
return new Statement() {
@Override
public void evaluate() throws Throwable {
runCount++;
base.evaluate();
}
};
}
}
public static class MultipleRuleTest {
@Rule
public MethodRule incrementor1 = new Increment();
@Rule
public MethodRule incrementor2 = new Increment();
@Test
public void nothing() {
}
}
@Test
public void multipleRulesAreRun() {
runCount = 0;
JUnitCore.runClasses(MultipleRuleTest.class);
assertEquals(2, runCount);
}
public static class NoRulesTest {
public int x;
@Test
public void nothing() {
}
}
@Test
public void ignoreNonRules() {
Result result = JUnitCore.runClasses(NoRulesTest.class);
assertEquals(0, result.getFailureCount());
}
private static String log;
public static class OnFailureTest {
@Rule
public MethodRule watchman = new TestWatchman() {
@Override
public void failed(Throwable e, FrameworkMethod method) {
log += method.getName() + " " + e.getClass().getSimpleName();
}
};
@Test
public void nothing() {
fail();
}
}
@Test
public void onFailure() {
log = "";
Result result = JUnitCore.runClasses(OnFailureTest.class);
assertEquals("nothing AssertionError", log);
assertEquals(1, result.getFailureCount());
}
public static class WatchmanTest {
private static String watchedLog;
@Rule
public MethodRule watchman = new TestWatchman() {
@Override
public void failed(Throwable e, FrameworkMethod method) {
watchedLog += method.getName() + " "
+ e.getClass().getSimpleName() + "\n";
}
@Override
public void succeeded(FrameworkMethod method) {
watchedLog += method.getName() + " " + "success!\n";
}
};
@Test
public void fails() {
fail();
}
@Test
public void succeeds() {
}
}
@Test
public void succeeded() {
WatchmanTest.watchedLog = "";
JUnitCore.runClasses(WatchmanTest.class);
assertThat(WatchmanTest.watchedLog, containsString("fails AssertionError"));
assertThat(WatchmanTest.watchedLog, containsString("succeeds success!"));
}
public static class BeforesAndAfters {
private static String watchedLog;
@Before
public void before() {
watchedLog += "before ";
}
@Rule
public MethodRule watchman = new TestWatchman() {
@Override
public void starting(FrameworkMethod method) {
watchedLog += "starting ";
}
@Override
public void finished(FrameworkMethod method) {
watchedLog += "finished ";
}
@Override
public void succeeded(FrameworkMethod method) {
watchedLog += "succeeded ";
}
};
@After
public void after() {
watchedLog += "after ";
}
@Test
public void succeeds() {
watchedLog += "test ";
}
}
@Test
public void beforesAndAfters() {
BeforesAndAfters.watchedLog = "";
JUnitCore.runClasses(BeforesAndAfters.class);
assertThat(BeforesAndAfters.watchedLog, is("starting before test after succeeded finished "));
}
public static class WrongTypedField {
@Rule
public int x = 5;
@Test
public void foo() {
}
}
@Test
public void validateWrongTypedField() {
assertThat(testResult(WrongTypedField.class),
hasSingleFailureContaining("must implement MethodRule"));
}
public static class SonOfWrongTypedField extends WrongTypedField {
}
@Test
public void validateWrongTypedFieldInSuperclass() {
assertThat(testResult(SonOfWrongTypedField.class),
hasSingleFailureContaining("must implement MethodRule"));
}
public static class PrivateRule {
@Rule
private TestRule rule = new TestName();
@Test
public void foo() {
}
}
@Test
public void validatePrivateRule() {
assertThat(testResult(PrivateRule.class),
hasSingleFailureContaining("must be public"));
}
public static class CustomTestName implements TestRule {
public String name = null;
public Statement apply(final Statement base, final Description description) {
return new Statement() {
@Override
public void evaluate() throws Throwable {
name = description.getMethodName();
base.evaluate();
}
};
}
}
public static class UsesCustomMethodRule {
@Rule
public CustomTestName counter = new CustomTestName();
@Test
public void foo() {
assertEquals("foo", counter.name);
}
}
@Test
public void useCustomMethodRule() {
assertThat(testResult(UsesCustomMethodRule.class), isSuccessful());
}
public static class HasMethodReturningMethodRule {
private MethodRule methodRule = new MethodRule() {
public Statement apply(final Statement base, FrameworkMethod method, Object target) {
return new Statement() {
@Override
public void evaluate() throws Throwable {
wasRun = true;
base.evaluate();
}
};
}
};
@Rule
public MethodRule methodRule() {
return methodRule;
}
@Test
public void doNothing() {
}
}
/**
* If there are any public methods annotated with @Rule returning a {@link MethodRule}
* then it should also be run.
*
* <p>This case has been added with
* <a href="https://github.com/junit-team/junit/issues/589">Issue #589</a> -
* Support @Rule for methods works only for TestRule but not for MethodRule
*/
@Test
public void runsMethodRuleThatIsReturnedByMethod() {
wasRun = false;
JUnitCore.runClasses(HasMethodReturningMethodRule.class);
assertTrue(wasRun);
}
public static class HasMultipleMethodsReturningMethodRule {
@Rule
public Increment methodRule1() {
return new Increment();
}
@Rule
public Increment methodRule2() {
return new Increment();
}
@Test
public void doNothing() {
}
}
/**
* If there are multiple public methods annotated with @Rule returning a {@link MethodRule}
* then all the rules returned should be run.
*
* <p>This case has been added with
* <a href="https://github.com/junit-team/junit/issues/589">Issue #589</a> -
* Support @Rule for methods works only for TestRule but not for MethodRule
*/
@Test
public void runsAllMethodRulesThatAreReturnedByMethods() {
runCount = 0;
JUnitCore.runClasses(HasMultipleMethodsReturningMethodRule.class);
assertEquals(2, runCount);
}
public static class CallsMethodReturningRuleOnlyOnce {
int callCount = 0;
private static class Dummy implements MethodRule {
public Statement apply(final Statement base, FrameworkMethod method, Object target) {
return new Statement() {
@Override
public void evaluate() throws Throwable {
base.evaluate();
}
};
}
};
@Rule
public MethodRule methodRule() {
callCount++;
return new Dummy();
}
@Test
public void doNothing() {
assertEquals(1, callCount);
}
}
/**
* If there are any public methods annotated with @Rule returning a {@link MethodRule}
* then method should be called only once.
*
* <p>This case has been added with
* <a href="https://github.com/junit-team/junit/issues/589">Issue #589</a> -
* Support @Rule for methods works only for TestRule but not for MethodRule
*/
@Test
public void callsMethodReturningRuleOnlyOnce() {
assertTrue(JUnitCore.runClasses(CallsMethodReturningRuleOnlyOnce.class).wasSuccessful());
}
}