Skip to content

Commit

Permalink
test: use node:test in test-cli-syntax.bad
Browse files Browse the repository at this point in the history
PR-URL: #54513
Reviewed-By: Benjamin Gruenbaum <benjamingr@gmail.com>
Reviewed-By: Moshe Atlow <moshe@atlow.co.il>
Reviewed-By: James M Snell <jasnell@gmail.com>
  • Loading branch information
RedYetiDev authored and jasnell committed Sep 10, 2024
1 parent 22ea302 commit 5de919b
Showing 1 changed file with 34 additions and 21 deletions.
55 changes: 34 additions & 21 deletions test/sequential/test-cli-syntax-bad.js
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
'use strict';

const common = require('../common');
const assert = require('assert');
require('../common');
const { exec } = require('child_process');
const { test } = require('node:test');
const fixtures = require('../common/fixtures');

const node = process.execPath;
Expand All @@ -23,26 +23,39 @@ const syntaxErrorRE = /^SyntaxError: \b/m;
'syntax/bad_syntax',
'syntax/bad_syntax_shebang.js',
'syntax/bad_syntax_shebang',
].forEach(function(file) {
file = fixtures.path(file);
].forEach((file) => {
const path = fixtures.path(file);

// Loop each possible option, `-c` or `--check`
syntaxArgs.forEach(function(args) {
const _args = args.concat(file);
const cmd = [node, ..._args].join(' ');
exec(cmd, common.mustCall((err, stdout, stderr) => {
assert.strictEqual(err instanceof Error, true);
assert.strictEqual(err.code, 1,
`code ${err.code} !== 1 for error:\n\n${err}`);

// No stdout should be produced
assert.strictEqual(stdout, '');

// Stderr should have a syntax error message
assert.match(stderr, syntaxErrorRE);

// stderr should include the filename
assert(stderr.startsWith(file), `${stderr} starts with ${file}`);
}));
syntaxArgs.forEach((args) => {
test(`Checking syntax for ${file} with ${args.join(' ')}`, async (t) => {
const _args = args.concat(path);
const cmd = [node, ..._args].join(' ');

try {
const { stdout, stderr } = await execPromise(cmd);

// No stdout should be produced
t.assert.strictEqual(stdout, '');

// Stderr should have a syntax error message
t.assert.match(stderr, syntaxErrorRE);

// stderr should include the filename
t.assert.ok(stderr.startsWith(path));
} catch (err) {
t.assert.strictEqual(err.code, 1);
}
});
});
});

// Helper function to promisify exec
function execPromise(cmd) {
const { promise, resolve, reject } = Promise.withResolvers();
exec(cmd, (err, stdout, stderr) => {
if (err) return reject({ ...err, stdout, stderr });
resolve({ stdout, stderr });
});
return promise;
}

0 comments on commit 5de919b

Please sign in to comment.