From 5cea7ed706521f7b6cd4924ee0646c29c0e1f050 Mon Sep 17 00:00:00 2001 From: Antoine du Hamel Date: Sun, 21 Jul 2024 19:34:38 +0200 Subject: [PATCH] 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 Reviewed-By: Geoffrey Booth Reviewed-By: Marco Ippolito Reviewed-By: Yagiz Nizipli --- .../test-assert-esm-cjs-message-verify.js | 44 +++++-------------- 1 file changed, 12 insertions(+), 32 deletions(-) diff --git a/test/parallel/test-assert-esm-cjs-message-verify.js b/test/parallel/test-assert-esm-cjs-message-verify.js index 9a66d83abd9c4b..23c48800923e87 100644 --- a/test/parallel/test-assert-esm-cjs-message-verify.js +++ b/test/parallel/test-assert-esm-cjs-message-verify.js @@ -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(); }); });