mirror of
https://github.com/nodejs/node.git
synced 2025-05-19 20:06:58 +00:00

This allows for option syntax similar to V8’s one, e.g. `--no_warnings` has the same effect as `--no-warnings`. PR-URL: https://github.com/nodejs/node/pull/23020 Reviewed-By: Michaël Zasso <targos@protonmail.com> Reviewed-By: Gus Caplan <me@gus.host> Reviewed-By: Refael Ackermann <refack@gmail.com> Reviewed-By: Colin Ihrig <cjihrig@gmail.com> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de> Reviewed-By: Richard Lau <riclau@uk.ibm.com> Reviewed-By: Daniel Bevenius <daniel.bevenius@gmail.com> Reviewed-By: Trivikram Kamat <trivikr.dev@gmail.com>
76 lines
1.9 KiB
JavaScript
76 lines
1.9 KiB
JavaScript
'use strict';
|
|
|
|
const assert = require('assert');
|
|
require('../common');
|
|
|
|
// assert legit flags are allowed, and bogus flags are disallowed
|
|
{
|
|
const goodFlags = [
|
|
'--perf_basic_prof',
|
|
'--perf-basic-prof',
|
|
'perf-basic-prof',
|
|
'--perf_basic-prof',
|
|
'perf_basic-prof',
|
|
'perf_basic_prof',
|
|
'-r',
|
|
'r',
|
|
'--stack-trace-limit=100',
|
|
'--stack-trace-limit=-=xX_nodejs_Xx=-',
|
|
].concat(process.config.variables.v8_enable_inspector ? [
|
|
'--inspect-brk',
|
|
'inspect-brk',
|
|
'--inspect_brk',
|
|
] : []);
|
|
|
|
const badFlags = [
|
|
'INSPECT-BRK',
|
|
'--INSPECT-BRK',
|
|
'--r',
|
|
'-R',
|
|
'---inspect-brk',
|
|
'--cheeseburgers'
|
|
];
|
|
|
|
goodFlags.forEach((flag) => {
|
|
assert.strictEqual(
|
|
process.allowedNodeEnvironmentFlags.has(flag),
|
|
true,
|
|
`flag should be in set: ${flag}`
|
|
);
|
|
});
|
|
|
|
badFlags.forEach((flag) => {
|
|
assert.strictEqual(
|
|
process.allowedNodeEnvironmentFlags.has(flag),
|
|
false,
|
|
`flag should not be in set: ${flag}`
|
|
);
|
|
});
|
|
}
|
|
|
|
// assert all "canonical" flags begin with dash(es)
|
|
{
|
|
process.allowedNodeEnvironmentFlags.forEach((flag) => {
|
|
assert(/^--?[a-z8_-]+$/.test(flag), `Unexpected format for flag ${flag}`);
|
|
});
|
|
}
|
|
|
|
// assert immutability of process.allowedNodeEnvironmentFlags
|
|
{
|
|
assert.strictEqual(Object.isFrozen(process.allowedNodeEnvironmentFlags),
|
|
true);
|
|
|
|
process.allowedNodeEnvironmentFlags.add('foo');
|
|
assert.strictEqual(process.allowedNodeEnvironmentFlags.has('foo'), false);
|
|
process.allowedNodeEnvironmentFlags.forEach((flag) => {
|
|
assert.strictEqual(flag === 'foo', false);
|
|
});
|
|
|
|
process.allowedNodeEnvironmentFlags.clear();
|
|
assert.strictEqual(process.allowedNodeEnvironmentFlags.size > 0, true);
|
|
|
|
const size = process.allowedNodeEnvironmentFlags.size;
|
|
process.allowedNodeEnvironmentFlags.delete('-r');
|
|
assert.strictEqual(process.allowedNodeEnvironmentFlags.size, size);
|
|
}
|