From 6bcbfcd7bc005d2f52f66eddbffad5b6a0dc8db1 Mon Sep 17 00:00:00 2001 From: sungpaks <122661764+sungpaks@users.noreply.github.com> Date: Tue, 6 Aug 2024 15:47:52 +0000 Subject: [PATCH] test: add subtests to test-node-run Added two subtests to test-node-run. First one is about unparsable package.json file, and the second one is about there is no "script" fields in package.json PR-URL: https://github.com/nodejs/node/pull/54204 Reviewed-By: Yagiz Nizipli Reviewed-By: Benjamin Gruenbaum Reviewed-By: Luigi Pinca Reviewed-By: Trivikram Kamat --- .../cannot-find-script/package.json | 3 +++ .../run-script/cannot-parse/package.json | 1 + test/parallel/test-node-run.js | 22 +++++++++++++++++++ 3 files changed, 26 insertions(+) create mode 100644 test/fixtures/run-script/cannot-find-script/package.json create mode 100644 test/fixtures/run-script/cannot-parse/package.json diff --git a/test/fixtures/run-script/cannot-find-script/package.json b/test/fixtures/run-script/cannot-find-script/package.json new file mode 100644 index 00000000000000..73ddbdfc179e2e --- /dev/null +++ b/test/fixtures/run-script/cannot-find-script/package.json @@ -0,0 +1,3 @@ +{ + "types" : "" +} diff --git a/test/fixtures/run-script/cannot-parse/package.json b/test/fixtures/run-script/cannot-parse/package.json new file mode 100644 index 00000000000000..53ef3e3a3e4099 --- /dev/null +++ b/test/fixtures/run-script/cannot-parse/package.json @@ -0,0 +1 @@ +{ "non-parsable package.json" diff --git a/test/parallel/test-node-run.js b/test/parallel/test-node-run.js index 75f9343c2aa716..5f9b95d2ef9148 100644 --- a/test/parallel/test-node-run.js +++ b/test/parallel/test-node-run.js @@ -113,4 +113,26 @@ describe('node --run [command]', () => { assert.strictEqual(child.stderr, ''); assert.strictEqual(child.code, 0); }); + + it('returns error on unparsable file', async () => { + const child = await common.spawnPromisified( + process.execPath, + [ '--no-warnings', '--run', 'test'], + { cwd: fixtures.path('run-script/cannot-parse') }, + ); + assert.match(child.stderr, /Can't parse package\.json/); + assert.strictEqual(child.stdout, ''); + assert.strictEqual(child.code, 1); + }); + + it('returns error when there is no "scripts" field file', async () => { + const child = await common.spawnPromisified( + process.execPath, + [ '--no-warnings', '--run', 'test'], + { cwd: fixtures.path('run-script/cannot-find-script') }, + ); + assert.match(child.stderr, /Can't find "scripts" field in package\.json/); + assert.strictEqual(child.stdout, ''); + assert.strictEqual(child.code, 1); + }); });