test: reduce flakiness of test-assert-esm-cjs-message-verify

PR-URL: https://github.com/nodejs/node/pull/53967
Fixes: https://github.com/nodejs/node/issues/53962
Reviewed-By: Rafael Gonzaga <rafael.nunu@hotmail.com>
Reviewed-By: Geoffrey Booth <webadmin@geoffreybooth.com>
Reviewed-By: Marco Ippolito <marcoippolito54@gmail.com>
Reviewed-By: Yagiz Nizipli <yagiz@nizipli.com>
This commit is contained in:
Antoine du Hamel 2024-07-21 19:34:38 +02:00 committed by GitHub
parent d0a6b605fb
commit 036ff03691
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -1,51 +1,31 @@
'use strict';
const { spawnPromisified } = require('../common');
const tmpdir = require('../common/tmpdir');
const assert = require('assert');
const { writeFileSync, unlink } = require('fs');
const { describe, after, it } = require('node:test');
tmpdir.refresh();
const assert = require('node:assert');
const { describe, it } = require('node:test');
const fileImports = {
cjs: 'const assert = require("assert");',
mjs: 'import assert from "assert";',
commonjs: 'const assert = require("assert");',
module: 'import assert from "assert";',
};
const fileNames = [];
for (const [ext, header] of Object.entries(fileImports)) {
const fileName = `test-file.${ext}`;
// Store the generated filesnames in an array
fileNames.push(`${tmpdir.path}/${fileName}`);
writeFileSync(tmpdir.resolve(fileName), `${header}\nassert.ok(0 === 2);`);
}
describe('ensure the assert.ok throwing similar error messages for esm and cjs files', () => {
const nodejsPath = `${process.execPath}`;
const errorsMessages = [];
it('should return code 1 for each command', async () => {
for (const fileName of fileNames) {
const { stderr, code } = await spawnPromisified(nodejsPath, [fileName]);
const errorsMessages = [];
for (const [inputType, header] of Object.entries(fileImports)) {
const { stderr, code } = await spawnPromisified(process.execPath, [
'--input-type',
inputType,
'--eval',
`${header}\nassert.ok(0 === 2);\n`,
]);
assert.strictEqual(code, 1);
// For each error message, filter the lines which will starts with AssertionError
errorsMessages.push(
stderr.split('\n').find((s) => s.startsWith('AssertionError'))
);
}
});
after(() => {
assert.strictEqual(errorsMessages.length, 2);
assert.deepStrictEqual(errorsMessages[0], errorsMessages[1]);
for (const fileName of fileNames) {
unlink(fileName, () => {});
}
tmpdir.refresh();
});
});