mirror of https://github.com/lukechilds/node.git
Browse Source
Remove use of arguments in normalizeExecArgs() and normalizeSpawnArguments(). Refs: https://github.com/nodejs/node/issues/10323 PR-URL: https://github.com/nodejs/node/pull/11535 Backport-PR-URL: https://github.com/nodejs/node/pull/13752 Reviewed-By: Colin Ihrig <cjihrig@gmail.com> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Michaël Zasso <targos@protonmail.com>v6.x
committed by
Myles Borins
2 changed files with 155 additions and 18 deletions
@ -0,0 +1,146 @@ |
|||
'use strict'; |
|||
|
|||
const common = require('../common.js'); |
|||
const cp = require('child_process'); |
|||
|
|||
const command = 'echo'; |
|||
const args = ['hello']; |
|||
const options = {}; |
|||
const cb = () => {}; |
|||
|
|||
const configs = { |
|||
n: [1e3], |
|||
methodName: [ |
|||
'exec', 'execSync', |
|||
'execFile', 'execFileSync', |
|||
'spawn', 'spawnSync', |
|||
], |
|||
params: [1, 2, 3, 4], |
|||
}; |
|||
|
|||
const bench = common.createBenchmark(main, configs); |
|||
|
|||
function main(conf) { |
|||
const n = +conf.n; |
|||
const methodName = conf.methodName; |
|||
const params = +conf.params; |
|||
|
|||
const method = cp[methodName]; |
|||
|
|||
switch (methodName) { |
|||
case 'exec': |
|||
switch (params) { |
|||
case 1: |
|||
bench.start(); |
|||
for (let i = 0; i < n; i++) method(command).kill(); |
|||
bench.end(n); |
|||
break; |
|||
case 2: |
|||
bench.start(); |
|||
for (let i = 0; i < n; i++) method(command, options).kill(); |
|||
bench.end(n); |
|||
break; |
|||
case 3: |
|||
bench.start(); |
|||
for (let i = 0; i < n; i++) method(command, options, cb).kill(); |
|||
bench.end(n); |
|||
break; |
|||
} |
|||
break; |
|||
case 'execSync': |
|||
switch (params) { |
|||
case 1: |
|||
bench.start(); |
|||
for (let i = 0; i < n; i++) method(command); |
|||
bench.end(n); |
|||
break; |
|||
case 2: |
|||
bench.start(); |
|||
for (let i = 0; i < n; i++) method(command, options); |
|||
bench.end(n); |
|||
break; |
|||
} |
|||
break; |
|||
case 'execFile': |
|||
switch (params) { |
|||
case 1: |
|||
bench.start(); |
|||
for (let i = 0; i < n; i++) method(command).kill(); |
|||
bench.end(n); |
|||
break; |
|||
case 2: |
|||
bench.start(); |
|||
for (let i = 0; i < n; i++) method(command, args).kill(); |
|||
bench.end(n); |
|||
break; |
|||
case 3: |
|||
bench.start(); |
|||
for (let i = 0; i < n; i++) method(command, args, options).kill(); |
|||
bench.end(n); |
|||
break; |
|||
case 4: |
|||
bench.start(); |
|||
for (let i = 0; i < n; i++) method(command, args, options, cb).kill(); |
|||
bench.end(n); |
|||
break; |
|||
} |
|||
break; |
|||
case 'execFileSync': |
|||
switch (params) { |
|||
case 1: |
|||
bench.start(); |
|||
for (let i = 0; i < n; i++) method(command); |
|||
bench.end(n); |
|||
break; |
|||
case 2: |
|||
bench.start(); |
|||
for (let i = 0; i < n; i++) method(command, args); |
|||
bench.end(n); |
|||
break; |
|||
case 3: |
|||
bench.start(); |
|||
for (let i = 0; i < n; i++) method(command, args, options); |
|||
bench.end(n); |
|||
break; |
|||
} |
|||
break; |
|||
case 'spawn': |
|||
switch (params) { |
|||
case 1: |
|||
bench.start(); |
|||
for (let i = 0; i < n; i++) method(command).kill(); |
|||
bench.end(n); |
|||
break; |
|||
case 2: |
|||
bench.start(); |
|||
for (let i = 0; i < n; i++) method(command, args).kill(); |
|||
bench.end(n); |
|||
break; |
|||
case 3: |
|||
bench.start(); |
|||
for (let i = 0; i < n; i++) method(command, args, options).kill(); |
|||
bench.end(n); |
|||
break; |
|||
} |
|||
break; |
|||
case 'spawnSync': |
|||
switch (params) { |
|||
case 1: |
|||
bench.start(); |
|||
for (let i = 0; i < n; i++) method(command); |
|||
bench.end(n); |
|||
break; |
|||
case 2: |
|||
bench.start(); |
|||
for (let i = 0; i < n; i++) method(command, args); |
|||
bench.end(n); |
|||
break; |
|||
case 3: |
|||
bench.start(); |
|||
for (let i = 0; i < n; i++) method(command, args, options); |
|||
bench.end(n); |
|||
break; |
|||
} |
|||
break; |
|||
} |
|||
} |
Loading…
Reference in new issue