-
-
Notifications
You must be signed in to change notification settings - Fork 6.5k
/
forceExit.test.ts
50 lines (40 loc) · 1.3 KB
/
forceExit.test.ts
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
/**
* Copyright (c) Meta Platforms, Inc. and affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
import {tmpdir} from 'os';
import * as path from 'path';
import {cleanup, writeFiles} from '../Utils';
import runJest from '../runJest';
const DIR = path.resolve(tmpdir(), 'force-exit-test');
beforeEach(() => cleanup(DIR));
afterEach(() => cleanup(DIR));
test('exits the process after test are done but before timers complete', () => {
writeFiles(DIR, {
'.watchmanconfig': '',
'__tests__/test.test.js': `
test('finishes before the timer is complete', () => {
setTimeout(() => console.log('TIMER_DONE'), 500);
});
`,
'package.json': JSON.stringify({jest: {testEnvironment: 'node'}}),
});
let output;
let stdout;
let stderr;
({stdout, stderr} = runJest(DIR));
output = `${stdout}\n${stderr}`;
expect(output).toMatch(/PASS.*test\.test\.js/);
expect(output).toMatch(/TIMER_DONE/);
writeFiles(DIR, {
'package.json': JSON.stringify({
jest: {forceExit: true, testEnvironment: 'node'},
}),
});
({stdout, stderr} = runJest(DIR));
output = `${stdout}\n${stderr}`;
expect(output).toMatch(/PASS.*test\.test\.js/);
expect(output).not.toMatch(/TIMER_DONE/);
});