@@ -17,13 +17,18 @@ ruleTester.run('no-done-callback', rule, {
17
17
'test("something", function() {})' ,
18
18
'test("something", async function () {})' ,
19
19
'test("something", someArg)' ,
20
+ 'beforeEach(() => {})' ,
21
+ 'beforeAll(async () => {})' ,
22
+ 'afterAll(() => {})' ,
23
+ 'afterAll(async function () {})' ,
24
+ 'afterAll(async function () {}, 5)' ,
20
25
] ,
21
26
invalid : [
22
27
{
23
28
code : 'test("something", (...args) => {args[0]();})' ,
24
29
errors : [
25
30
{
26
- messageId : 'illegalTestCallback ' ,
31
+ messageId : 'noDoneCallback ' ,
27
32
line : 1 ,
28
33
column : 20 ,
29
34
} ,
@@ -33,7 +38,7 @@ ruleTester.run('no-done-callback', rule, {
33
38
code : 'test("something", done => {done();})' ,
34
39
errors : [
35
40
{
36
- messageId : 'illegalTestCallback ' ,
41
+ messageId : 'noDoneCallback ' ,
37
42
line : 1 ,
38
43
column : 19 ,
39
44
suggestions : [
@@ -51,7 +56,7 @@ ruleTester.run('no-done-callback', rule, {
51
56
code : 'test("something", finished => {finished();})' ,
52
57
errors : [
53
58
{
54
- messageId : 'illegalTestCallback ' ,
59
+ messageId : 'noDoneCallback ' ,
55
60
line : 1 ,
56
61
column : 19 ,
57
62
suggestions : [
@@ -69,7 +74,7 @@ ruleTester.run('no-done-callback', rule, {
69
74
code : 'test("something", (done) => {done();})' ,
70
75
errors : [
71
76
{
72
- messageId : 'illegalTestCallback ' ,
77
+ messageId : 'noDoneCallback ' ,
73
78
line : 1 ,
74
79
column : 20 ,
75
80
suggestions : [
@@ -87,7 +92,7 @@ ruleTester.run('no-done-callback', rule, {
87
92
code : 'test("something", done => done())' ,
88
93
errors : [
89
94
{
90
- messageId : 'illegalTestCallback ' ,
95
+ messageId : 'noDoneCallback ' ,
91
96
line : 1 ,
92
97
column : 19 ,
93
98
suggestions : [
@@ -104,7 +109,7 @@ ruleTester.run('no-done-callback', rule, {
104
109
code : 'test("something", (done) => done())' ,
105
110
errors : [
106
111
{
107
- messageId : 'illegalTestCallback ' ,
112
+ messageId : 'noDoneCallback ' ,
108
113
line : 1 ,
109
114
column : 20 ,
110
115
suggestions : [
@@ -121,7 +126,7 @@ ruleTester.run('no-done-callback', rule, {
121
126
code : 'test("something", function(done) {done();})' ,
122
127
errors : [
123
128
{
124
- messageId : 'illegalTestCallback ' ,
129
+ messageId : 'noDoneCallback ' ,
125
130
line : 1 ,
126
131
column : 28 ,
127
132
suggestions : [
@@ -139,7 +144,7 @@ ruleTester.run('no-done-callback', rule, {
139
144
code : 'test("something", function (done) {done();})' ,
140
145
errors : [
141
146
{
142
- messageId : 'illegalTestCallback ' ,
147
+ messageId : 'noDoneCallback ' ,
143
148
line : 1 ,
144
149
column : 29 ,
145
150
suggestions : [
@@ -183,7 +188,7 @@ ruleTester.run('no-done-callback', rule, {
183
188
` ,
184
189
errors : [
185
190
{
186
- messageId : 'illegalTestCallback ' ,
191
+ messageId : 'noDoneCallback ' ,
187
192
line : 1 ,
188
193
column : 20 ,
189
194
suggestions : [
@@ -200,5 +205,185 @@ ruleTester.run('no-done-callback', rule, {
200
205
} ,
201
206
] ,
202
207
} ,
208
+ {
209
+ code : 'afterEach((...args) => {args[0]();})' ,
210
+ errors : [
211
+ {
212
+ messageId : 'noDoneCallback' ,
213
+ line : 1 ,
214
+ column : 12 ,
215
+ } ,
216
+ ] ,
217
+ } ,
218
+ {
219
+ code : 'beforeAll(done => {done();})' ,
220
+ errors : [
221
+ {
222
+ messageId : 'noDoneCallback' ,
223
+ line : 1 ,
224
+ column : 11 ,
225
+ suggestions : [
226
+ {
227
+ messageId : 'suggestWrappingInPromise' ,
228
+ data : { callback : 'done' } ,
229
+ output :
230
+ 'beforeAll(() => {return new Promise(done => {done();})})' ,
231
+ } ,
232
+ ] ,
233
+ } ,
234
+ ] ,
235
+ } ,
236
+ {
237
+ code : 'beforeAll(finished => {finished();})' ,
238
+ errors : [
239
+ {
240
+ messageId : 'noDoneCallback' ,
241
+ line : 1 ,
242
+ column : 11 ,
243
+ suggestions : [
244
+ {
245
+ messageId : 'suggestWrappingInPromise' ,
246
+ data : { callback : 'finished' } ,
247
+ output :
248
+ 'beforeAll(() => {return new Promise(finished => {finished();})})' ,
249
+ } ,
250
+ ] ,
251
+ } ,
252
+ ] ,
253
+ } ,
254
+ {
255
+ code : 'beforeEach((done) => {done();})' ,
256
+ errors : [
257
+ {
258
+ messageId : 'noDoneCallback' ,
259
+ line : 1 ,
260
+ column : 13 ,
261
+ suggestions : [
262
+ {
263
+ messageId : 'suggestWrappingInPromise' ,
264
+ data : { callback : 'done' } ,
265
+ output :
266
+ 'beforeEach(() => {return new Promise((done) => {done();})})' ,
267
+ } ,
268
+ ] ,
269
+ } ,
270
+ ] ,
271
+ } ,
272
+ {
273
+ code : 'afterAll(done => done())' ,
274
+ errors : [
275
+ {
276
+ messageId : 'noDoneCallback' ,
277
+ line : 1 ,
278
+ column : 10 ,
279
+ suggestions : [
280
+ {
281
+ messageId : 'suggestWrappingInPromise' ,
282
+ data : { callback : 'done' } ,
283
+ output : 'afterAll(() => new Promise(done => done()))' ,
284
+ } ,
285
+ ] ,
286
+ } ,
287
+ ] ,
288
+ } ,
289
+ {
290
+ code : 'afterEach((done) => done())' ,
291
+ errors : [
292
+ {
293
+ messageId : 'noDoneCallback' ,
294
+ line : 1 ,
295
+ column : 12 ,
296
+ suggestions : [
297
+ {
298
+ messageId : 'suggestWrappingInPromise' ,
299
+ data : { callback : 'done' } ,
300
+ output : 'afterEach(() => new Promise((done) => done()))' ,
301
+ } ,
302
+ ] ,
303
+ } ,
304
+ ] ,
305
+ } ,
306
+ {
307
+ code : 'beforeAll(function(done) {done();})' ,
308
+ errors : [
309
+ {
310
+ messageId : 'noDoneCallback' ,
311
+ line : 1 ,
312
+ column : 20 ,
313
+ suggestions : [
314
+ {
315
+ messageId : 'suggestWrappingInPromise' ,
316
+ data : { callback : 'done' } ,
317
+ output :
318
+ 'beforeAll(function() {return new Promise((done) => {done();})})' ,
319
+ } ,
320
+ ] ,
321
+ } ,
322
+ ] ,
323
+ } ,
324
+ {
325
+ code : 'afterEach(function (done) {done();})' ,
326
+ errors : [
327
+ {
328
+ messageId : 'noDoneCallback' ,
329
+ line : 1 ,
330
+ column : 21 ,
331
+ suggestions : [
332
+ {
333
+ messageId : 'suggestWrappingInPromise' ,
334
+ data : { callback : 'done' } ,
335
+ output :
336
+ 'afterEach(function () {return new Promise((done) => {done();})})' ,
337
+ } ,
338
+ ] ,
339
+ } ,
340
+ ] ,
341
+ } ,
342
+ {
343
+ code : 'beforeAll(async done => {done();})' ,
344
+ errors : [ { messageId : 'useAwaitInsteadOfCallback' , line : 1 , column : 17 } ] ,
345
+ } ,
346
+ {
347
+ code : 'beforeAll(async done => done())' ,
348
+ errors : [ { messageId : 'useAwaitInsteadOfCallback' , line : 1 , column : 17 } ] ,
349
+ } ,
350
+ {
351
+ code : 'beforeAll(async function (done) {done();})' ,
352
+ errors : [ { messageId : 'useAwaitInsteadOfCallback' , line : 1 , column : 27 } ] ,
353
+ } ,
354
+ {
355
+ code : dedent `
356
+ afterAll(async (done) => {
357
+ await myAsyncTask();
358
+ done();
359
+ });
360
+ ` ,
361
+ errors : [ { messageId : 'useAwaitInsteadOfCallback' , line : 1 , column : 17 } ] ,
362
+ } ,
363
+ {
364
+ code : dedent `
365
+ beforeEach((done) => {
366
+ done();
367
+ });
368
+ ` ,
369
+ errors : [
370
+ {
371
+ messageId : 'noDoneCallback' ,
372
+ line : 1 ,
373
+ column : 13 ,
374
+ suggestions : [
375
+ {
376
+ messageId : 'suggestWrappingInPromise' ,
377
+ data : { callback : 'done' } ,
378
+ output : dedent `
379
+ beforeEach(() => {return new Promise((done) => {
380
+ done();
381
+ })});
382
+ ` ,
383
+ } ,
384
+ ] ,
385
+ } ,
386
+ ] ,
387
+ } ,
203
388
] ,
204
389
} ) ;
0 commit comments