-
Notifications
You must be signed in to change notification settings - Fork 30.3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
doc,test: test documentation consistency for NODE_OPTIONS
Add a test that checks that the documented allowed options for the `NODE_OPTIONS` environment variable are consistent with the actually allowed options.
- Loading branch information
1 parent
310d148
commit 6bfc840
Showing
2 changed files
with
88 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
84 changes: 84 additions & 0 deletions
84
test/parallel/test-process-env-allowed-flags-are-documented.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,84 @@ | ||
'use strict'; | ||
|
||
const common = require('../common'); | ||
|
||
const assert = require('assert'); | ||
const fs = require('fs'); | ||
const path = require('path'); | ||
|
||
const rootDir = path.resolve(__dirname, '..', '..'); | ||
const cliMd = path.join(rootDir, 'doc', 'api', 'cli.md'); | ||
const cliText = fs.readFileSync(cliMd, { encoding: 'utf8' }); | ||
|
||
const parseSection = (text, startMarker, endMarker) => { | ||
const regExp = new RegExp(`${startMarker}\r?\n([^]*)\r?\n${endMarker}`); | ||
const match = text.match(regExp); | ||
assert(match, | ||
`Unable to locate text between '${startMarker}' and '${endMarker}'.`); | ||
return match[1].split(/\r?\n/); | ||
}; | ||
|
||
const nodeOptionsLines = parseSection(cliText, | ||
'<!-- node-options-node start -->', | ||
'<!-- node-options-node end -->'); | ||
const v8OptionsLines = parseSection(cliText, | ||
'<!-- node-options-v8 start -->', | ||
'<!-- node-options-v8 end -->'); | ||
// Check the options are documented in alphabetical order. | ||
assert.deepStrictEqual(nodeOptionsLines, [...nodeOptionsLines].sort()); | ||
assert.deepStrictEqual(v8OptionsLines, [...v8OptionsLines].sort()); | ||
|
||
const documented = new Set(); | ||
for (const line of [...nodeOptionsLines, ...v8OptionsLines]) { | ||
for (const match of line.matchAll(/`(-[^`]+)`/g)) { | ||
const option = match[1]; | ||
assert(!documented.has(option), | ||
`Option '${option}' was documented more than once as an ` + | ||
`allowed option for NODE_OPTIONS in ${cliMd}.`); | ||
documented.add(option); | ||
} | ||
} | ||
|
||
// Filter out options that are conditionally present. | ||
const conditionalOpts = [ | ||
{ include: common.hasCrypto, | ||
filter: (opt) => { | ||
return ['--openssl-config', '--tls-cipher-list', '--use-bundled-ca', | ||
'--use-openssl-ca' ].includes(opt); | ||
} }, | ||
{ include: common.hasFipsCrypto, | ||
filter: (opt) => opt.includes('-fips') }, | ||
{ include: common.hasIntl, | ||
filter: (opt) => opt === '--icu-data-dir' }, | ||
{ include: process.features.inspector, | ||
filter: (opt) => opt.startsWith('--inspect') || opt === '--debug-port' }, | ||
{ include: process.config.variables.node_report, | ||
filter: (opt) => opt.includes('-report') }, | ||
]; | ||
documented.forEach((opt) => { | ||
conditionalOpts.forEach(({ include, filter }) => { | ||
if (!include && filter(opt)) { | ||
documented.delete(opt); | ||
} | ||
}); | ||
}); | ||
|
||
const difference = (setA, setB) => { | ||
return new Set([...setA].filter((x) => !setB.has(x))); | ||
}; | ||
|
||
const overdocumented = difference(documented, | ||
process.allowedNodeEnvironmentFlags); | ||
assert.strictEqual(overdocumented.size, 0, | ||
'The following options are documented as allowed in ' + | ||
`NODE_OPTIONS in ${cliMd}: ` + | ||
`${[...overdocumented].join(' ')} ` + | ||
'but are not in process.allowedNodeEnvironmentFlags'); | ||
const undocumented = difference(process.allowedNodeEnvironmentFlags, | ||
documented); | ||
// Remove intentionally undocumented options. | ||
assert(undocumented.delete('--debug-arraybuffer-allocations')); | ||
assert(undocumented.delete('--experimental-worker')); | ||
assert.strictEqual(undocumented.size, 0, | ||
'The following options are not documented as allowed in ' + | ||
`NODE_OPTIONS in ${cliMd}: ${[...undocumented].join(' ')}`); |