Skip to content

Commit

Permalink
Fix Windows test
Browse files Browse the repository at this point in the history
  • Loading branch information
ehmicky committed Oct 28, 2024
1 parent 3ca7b38 commit 802b4c5
Showing 1 changed file with 4 additions and 19 deletions.
23 changes: 4 additions & 19 deletions test/terminate/kill-signal.js
Original file line number Diff line number Diff line change
@@ -1,16 +1,12 @@
import {once} from 'node:events';
import {platform} from 'node:process';
import {constants} from 'node:os';
import {setImmediate} from 'node:timers/promises';
import test from 'ava';
import {execa, execaSync} from '../../index.js';
import {setFixtureDirectory} from '../helpers/fixtures-directory.js';
import {majorNodeVersion} from '../helpers/node-version.js';

setFixtureDirectory();

const isWindows = platform === 'win32';

const testKillSignal = async (t, killSignal) => {
const {isTerminated, signal} = await t.throwsAsync(execa('forever.js', {killSignal, timeout: 1}));
t.true(isTerminated);
Expand Down Expand Up @@ -61,21 +57,10 @@ test('Can call `.kill()` multiple times', async t => {
subprocess.kill();

const {exitCode, isTerminated, signal, code} = await t.throwsAsync(subprocess);

// On Windows, calling `subprocess.kill()` twice emits an `error` event on the subprocess.
// This does not happen when passing an `error` argument, nor when passing a non-terminating signal.
// There is no easy way to make this cross-platform, so we document the difference here.
if (isWindows && majorNodeVersion >= 22) {
t.is(exitCode, undefined);
t.false(isTerminated);
t.is(signal, undefined);
t.is(code, 'EPERM');
} else {
t.is(exitCode, undefined);
t.true(isTerminated);
t.is(signal, 'SIGTERM');
t.is(code, undefined);
}
t.is(exitCode, undefined);
t.true(isTerminated);
t.is(signal, 'SIGTERM');
t.is(code, undefined);
});

test('execa() returns a promise with kill()', async t => {
Expand Down

0 comments on commit 802b4c5

Please sign in to comment.