From 945f20808143d954fea73e4ac3a0d71cf73c9b2c Mon Sep 17 00:00:00 2001 From: Vse Mozhet Byt Date: Thu, 11 May 2017 15:10:00 +0300 Subject: [PATCH] test: make the rest of tests path-independent Permit spaces in paths to a Node.js executable and test scripts. PR-URL: https://github.com/nodejs/node/pull/12972 Fixes: https://github.com/nodejs/node/issues/12773 Reviewed-By: Rich Trott Reviewed-By: Colin Ihrig --- test/common/index.js | 4 ++-- .../test-stdout-buffer-flush-on-exit.js | 3 ++- test/parallel/test-child-process-bad-stdio.js | 2 +- .../test-child-process-exec-encoding.js | 2 +- .../test-child-process-exec-kill-throws.js | 2 +- .../test-child-process-exec-timeout.js | 2 +- test/parallel/test-cli-eval.js | 2 +- ...n-throw-from-uncaught-exception-handler.js | 4 ++-- ...domain-with-abort-on-uncaught-exception.js | 4 ++-- test/parallel/test-env-var-no-warnings.js | 2 +- test/parallel/test-http-chunk-problem.js | 8 +++---- test/parallel/test-preload.js | 22 +++++++++---------- .../test-domain-abort-on-uncaught.js | 4 ++-- test/sequential/test-module-loading.js | 2 +- 14 files changed, 32 insertions(+), 31 deletions(-) diff --git a/test/common/index.js b/test/common/index.js index 7e8e6d5e9782b5..cb8d333a289799 100644 --- a/test/common/index.js +++ b/test/common/index.js @@ -285,8 +285,8 @@ exports.childShouldThrowAndAbort = function() { // continuous testing and developers' machines testCmd += 'ulimit -c 0 && '; } - testCmd += `${process.argv[0]} --abort-on-uncaught-exception `; - testCmd += `${process.argv[1]} child`; + testCmd += `"${process.argv[0]}" --abort-on-uncaught-exception `; + testCmd += `"${process.argv[1]}" child`; const child = child_process.exec(testCmd); child.on('exit', function onExit(exitCode, signal) { const errMsg = 'Test should have aborted ' + diff --git a/test/known_issues/test-stdout-buffer-flush-on-exit.js b/test/known_issues/test-stdout-buffer-flush-on-exit.js index e966d02e324ba7..931f1026cfa9c6 100644 --- a/test/known_issues/test-stdout-buffer-flush-on-exit.js +++ b/test/known_issues/test-stdout-buffer-flush-on-exit.js @@ -18,7 +18,8 @@ if (process.argv[2] === 'child') { [22, 21, 20, 19, 18, 17, 16, 16, 17, 18, 19, 20, 21, 22].forEach((exponent) => { const bigNum = Math.pow(2, exponent); const longLine = lineSeed.repeat(bigNum); - const cmd = `${process.execPath} ${__filename} child ${exponent} ${bigNum}`; + const cmd = + `"${process.execPath}" "${__filename}" child ${exponent} ${bigNum}`; const stdout = execSync(cmd).toString().trim(); assert.strictEqual(stdout, longLine, `failed with exponent ${exponent}`); diff --git a/test/parallel/test-child-process-bad-stdio.js b/test/parallel/test-child-process-bad-stdio.js index 8b3ad6db0fd635..2e06f4e2b12176 100644 --- a/test/parallel/test-child-process-bad-stdio.js +++ b/test/parallel/test-child-process-bad-stdio.js @@ -27,7 +27,7 @@ ChildProcess.prototype.spawn = function() { }; function createChild(options, callback) { - const cmd = `${process.execPath} ${__filename} child`; + const cmd = `"${process.execPath}" "${__filename}" child`; return cp.exec(cmd, options, common.mustCall(callback)); } diff --git a/test/parallel/test-child-process-exec-encoding.js b/test/parallel/test-child-process-exec-encoding.js index ba80ccda8c6aee..781ee51d96dcb2 100644 --- a/test/parallel/test-child-process-exec-encoding.js +++ b/test/parallel/test-child-process-exec-encoding.js @@ -13,7 +13,7 @@ if (process.argv[2] === 'child') { console.error(stderrData); } else { function run(options, callback) { - const cmd = `${process.execPath} ${__filename} child`; + const cmd = `"${process.execPath}" "${__filename}" child`; cp.exec(cmd, options, common.mustCall((err, stdout, stderr) => { assert.ifError(err); diff --git a/test/parallel/test-child-process-exec-kill-throws.js b/test/parallel/test-child-process-exec-kill-throws.js index d5bc5305847107..35e5ff8b7bce0f 100644 --- a/test/parallel/test-child-process-exec-kill-throws.js +++ b/test/parallel/test-child-process-exec-kill-throws.js @@ -18,7 +18,7 @@ if (process.argv[2] === 'child') { throw new Error('mock error'); }; - const cmd = `${process.execPath} ${__filename} child`; + const cmd = `"${process.execPath}" "${__filename}" child`; const options = { maxBuffer: 0 }; const child = cp.exec(cmd, options, common.mustCall((err, stdout, stderr) => { // Verify that if ChildProcess#kill() throws, the error is reported. diff --git a/test/parallel/test-child-process-exec-timeout.js b/test/parallel/test-child-process-exec-timeout.js index 63534d8cbc3e01..ed25d9bff825a9 100644 --- a/test/parallel/test-child-process-exec-timeout.js +++ b/test/parallel/test-child-process-exec-timeout.js @@ -12,7 +12,7 @@ if (process.argv[2] === 'child') { return; } -const cmd = `${process.execPath} ${__filename} child`; +const cmd = `"${process.execPath}" "${__filename}" child`; // Test the case where a timeout is set, and it expires. cp.exec(cmd, { timeout: 1 }, common.mustCall((err, stdout, stderr) => { diff --git a/test/parallel/test-cli-eval.js b/test/parallel/test-cli-eval.js index 0ec561ff0da45d..7c7ced62fd51f0 100644 --- a/test/parallel/test-cli-eval.js +++ b/test/parallel/test-cli-eval.js @@ -220,7 +220,7 @@ child.exec(`${nodejs} --use-strict -p process.execArgv`, // Ensure that arguments are successfully passed to a script. // The first argument after '--' should be interpreted as a script // filename. - const filecmd = `${nodejs} -- ${__filename} ${args}`; + const filecmd = `${nodejs} -- "${__filename}" ${args}`; child.exec(filecmd, common.mustCall(function(err, stdout, stderr) { assert.strictEqual(stdout, `${args}\n`); assert.strictEqual(stderr, ''); diff --git a/test/parallel/test-domain-throw-error-then-throw-from-uncaught-exception-handler.js b/test/parallel/test-domain-throw-error-then-throw-from-uncaught-exception-handler.js index cce6af84a22dde..089300bc481c10 100644 --- a/test/parallel/test-domain-throw-error-then-throw-from-uncaught-exception-handler.js +++ b/test/parallel/test-domain-throw-error-then-throw-from-uncaught-exception-handler.js @@ -90,13 +90,13 @@ function createTestCmdLine(options) { testCmd += 'ulimit -c 0 && '; } - testCmd += process.argv[0]; + testCmd += `"${process.argv[0]}"`; if (options && options.withAbortOnUncaughtException) { testCmd += ' --abort-on-uncaught-exception'; } - testCmd += ` ${process.argv[1]} child`; + testCmd += ` "${process.argv[1]}" child`; return testCmd; } diff --git a/test/parallel/test-domain-with-abort-on-uncaught-exception.js b/test/parallel/test-domain-with-abort-on-uncaught-exception.js index 5b455f6f915605..03ab39dbfc05d2 100644 --- a/test/parallel/test-domain-with-abort-on-uncaught-exception.js +++ b/test/parallel/test-domain-with-abort-on-uncaught-exception.js @@ -103,8 +103,8 @@ if (process.argv[2] === 'child') { if (options.useTryCatch) useTryCatchOpt = 'useTryCatch'; - cmdToExec += `${process.argv[0]} ${cmdLineOption ? cmdLineOption : ''} ${ - process.argv[1]} child ${throwInDomainErrHandlerOpt} ${useTryCatchOpt}`; + cmdToExec += `"${process.argv[0]}" ${cmdLineOption ? cmdLineOption : ''} "${ + process.argv[1]}" child ${throwInDomainErrHandlerOpt} ${useTryCatchOpt}`; const child = exec(cmdToExec); diff --git a/test/parallel/test-env-var-no-warnings.js b/test/parallel/test-env-var-no-warnings.js index 5b61e4163af633..3a99cbc112d8b9 100644 --- a/test/parallel/test-env-var-no-warnings.js +++ b/test/parallel/test-env-var-no-warnings.js @@ -7,7 +7,7 @@ if (process.argv[2] === 'child') { process.emitWarning('foo'); } else { function test(env) { - const cmd = `${process.execPath} ${__filename} child`; + const cmd = `"${process.execPath}" "${__filename}" child`; cp.exec(cmd, { env }, common.mustCall((err, stdout, stderr) => { assert.strictEqual(err, null); diff --git a/test/parallel/test-http-chunk-problem.js b/test/parallel/test-http-chunk-problem.js index 5127075f4fd1d0..822aab804f036d 100644 --- a/test/parallel/test-http-chunk-problem.js +++ b/test/parallel/test-http-chunk-problem.js @@ -42,13 +42,13 @@ const filename = require('path').join(common.tmpDir, 'big'); let server; function executeRequest(cb) { - cp.exec([process.execPath, - __filename, + cp.exec([`"${process.execPath}"`, + `"${__filename}"`, 'request', server.address().port, '|', - process.execPath, - __filename, + `"${process.execPath}"`, + `"${__filename}"`, 'shasum' ].join(' '), (err, stdout, stderr) => { assert.ifError(err); diff --git a/test/parallel/test-preload.js b/test/parallel/test-preload.js index b0326c47b11c35..9d24fbb3652fa6 100644 --- a/test/parallel/test-preload.js +++ b/test/parallel/test-preload.js @@ -16,7 +16,7 @@ const nodeBinary = process.argv[0]; const preloadOption = (preloads) => { let option = ''; preloads.forEach(function(preload, index) { - option += `-r ${preload} `; + option += `-r "${preload}" `; }); return option; }; @@ -30,7 +30,7 @@ const fixtureD = fixture('define-global.js'); const fixtureThrows = fixture('throws_error4.js'); // test preloading a single module works -childProcess.exec(`${nodeBinary} ${preloadOption([fixtureA])} ${fixtureB}`, +childProcess.exec(`"${nodeBinary}" ${preloadOption([fixtureA])} "${fixtureB}"`, function(err, stdout, stderr) { assert.ifError(err); assert.strictEqual(stdout, 'A\nB\n'); @@ -38,7 +38,7 @@ childProcess.exec(`${nodeBinary} ${preloadOption([fixtureA])} ${fixtureB}`, // test preloading multiple modules works childProcess.exec( - `${nodeBinary} ${preloadOption([fixtureA, fixtureB])} ${fixtureC}`, + `"${nodeBinary}" ${preloadOption([fixtureA, fixtureB])} "${fixtureC}"`, function(err, stdout, stderr) { assert.ifError(err); assert.strictEqual(stdout, 'A\nB\nC\n'); @@ -47,7 +47,7 @@ childProcess.exec( // test that preloading a throwing module aborts childProcess.exec( - `${nodeBinary} ${preloadOption([fixtureA, fixtureThrows])} ${fixtureB}`, + `"${nodeBinary}" ${preloadOption([fixtureA, fixtureThrows])} "${fixtureB}"`, function(err, stdout, stderr) { if (err) { assert.strictEqual(stdout, 'A\n'); @@ -59,7 +59,7 @@ childProcess.exec( // test that preload can be used with --eval childProcess.exec( - `${nodeBinary} ${preloadOption([fixtureA])}-e "console.log('hello');"`, + `"${nodeBinary}" ${preloadOption([fixtureA])}-e "console.log('hello');"`, function(err, stdout, stderr) { assert.ifError(err); assert.strictEqual(stdout, 'A\nhello\n'); @@ -105,7 +105,7 @@ replProc.on('close', function(code) { // test that preload placement at other points in the cmdline // also test that duplicated preload only gets loaded once childProcess.exec( - `${nodeBinary} ${preloadOption([fixtureA])}-e "console.log('hello');" ${ + `"${nodeBinary}" ${preloadOption([fixtureA])}-e "console.log('hello');" ${ preloadOption([fixtureA, fixtureB])}`, function(err, stdout, stderr) { assert.ifError(err); @@ -115,7 +115,7 @@ childProcess.exec( // test that preload works with -i const interactive = childProcess.exec( - `${nodeBinary} ${preloadOption([fixtureD])}-i`, + `"${nodeBinary}" ${preloadOption([fixtureD])}-i`, common.mustCall(function(err, stdout, stderr) { assert.ifError(err); assert.strictEqual(stdout, "> 'test'\n> "); @@ -126,8 +126,8 @@ interactive.stdin.write('a\n'); interactive.stdin.write('process.exit()\n'); childProcess.exec( - `${nodeBinary} --require ${fixture('cluster-preload.js')} ${ - fixture('cluster-preload-test.js')}`, + `"${nodeBinary}" --require "${fixture('cluster-preload.js')}" "${ + fixture('cluster-preload-test.js')}"`, function(err, stdout, stderr) { assert.ifError(err); assert.ok(/worker terminated with code 43/.test(stdout)); @@ -137,8 +137,8 @@ childProcess.exec( // https://github.com/nodejs/node/issues/1691 process.chdir(common.fixturesDir); childProcess.exec( - `${nodeBinary} --expose_natives_as=v8natives --require ` + - `${fixture('cluster-preload.js')} cluster-preload-test.js`, + `"${nodeBinary}" --expose_natives_as=v8natives --require ` + + `"${fixture('cluster-preload.js')}" cluster-preload-test.js`, function(err, stdout, stderr) { assert.ifError(err); assert.ok(/worker terminated with code 43/.test(stdout)); diff --git a/test/sequential/test-domain-abort-on-uncaught.js b/test/sequential/test-domain-abort-on-uncaught.js index 1ee48666e1a3c9..dfac371afcddff 100644 --- a/test/sequential/test-domain-abort-on-uncaught.js +++ b/test/sequential/test-domain-abort-on-uncaught.js @@ -239,8 +239,8 @@ if (process.argv[2] === 'child') { testCmd += 'ulimit -c 0 && '; } - testCmd += `${process.argv[0]} --abort-on-uncaught-exception ` + - `${process.argv[1]} child ${testIndex}`; + testCmd += `"${process.argv[0]}" --abort-on-uncaught-exception ` + + `"${process.argv[1]}" child ${testIndex}`; const child = child_process.exec(testCmd); diff --git a/test/sequential/test-module-loading.js b/test/sequential/test-module-loading.js index 9d3a1f772c8b35..c55c03279edde1 100644 --- a/test/sequential/test-module-loading.js +++ b/test/sequential/test-module-loading.js @@ -103,7 +103,7 @@ assert.throws( function() { require('../fixtures/packages/invalid'); }, - /^SyntaxError: Error parsing \S+: Unexpected token , in JSON at position 1$/ + /^SyntaxError: Error parsing .+: Unexpected token , in JSON at position 1$/ ); assert.strictEqual(require('../fixtures/packages/index').ok, 'ok',