node-jest/e2e/__tests__/forceExit.test.ts

51 lines
1.3 KiB
TypeScript

/**
* Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
*
* 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/);
});