Skip to content

Commit

Permalink
build,tools: check freshness of doc addons
Browse files Browse the repository at this point in the history
Add a `--check` flag to `tools/doc/addon-verify.js` and use that in the
`make test` target to determine if the generated files in `test/addons`
are fresh or stale.

PR-URL: #17407
Reviewed-By: Richard Lau <[email protected]>
  • Loading branch information
bnoordhuis authored and BridgeAR committed Jan 21, 2018
1 parent d9b59de commit 2cb9e2a
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 10 deletions.
6 changes: 5 additions & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -225,7 +225,7 @@ v8:

.PHONY: test
# This does not run tests of third-party libraries inside deps.
test: all build-addons ## Runs default tests, linters, and builds docs.
test: all check-doc-addons build-addons ## Runs default tests, linters, and builds docs.
$(MAKE) -s doc-only
$(MAKE) -s lint
$(MAKE) -s cctest
Expand All @@ -234,6 +234,10 @@ test: all build-addons ## Runs default tests, linters, and builds docs.
$(CI_NATIVE_SUITES) \
$(CI_DOC)

.PHONY: check-doc-addons
check-doc-addons: $(NODE)
$(NODE) tools/doc/addon-verify.js --check

.PHONY: test-only
test-only: all build-addons ## For a quick test, does not run linter or build docs.
$(MAKE) cctest
Expand Down
31 changes: 22 additions & 9 deletions tools/doc/addon-verify.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,9 @@ const rootDir = path.resolve(__dirname, '..', '..');
const doc = path.resolve(rootDir, 'doc', 'api', 'addons.md');
const verifyDir = path.resolve(rootDir, 'test', 'addons');

const changed = [];
const checkOnly = process.argv.includes('--check');

let id = 0;
let currentHeader;

Expand Down Expand Up @@ -76,12 +79,6 @@ for (const header in addons) {
})
});

try {
fs.mkdirSync(dir);
} catch (e) {
strictEqual(e.code, 'EEXIST');
}

for (const file of files) {
let content;
try {
Expand All @@ -91,13 +88,29 @@ for (const header in addons) {
}

// Only update when file content has changed to prevent unneeded rebuilds.
if (content !== file.content) {
fs.writeFileSync(file.path, file.content);
console.log('wrote', file.path);
if (content === file.content) continue;
changed.push(file);

if (checkOnly) continue;

try {
fs.mkdirSync(dir);
} catch (e) {
strictEqual(e.code, 'EEXIST');
}

fs.writeFileSync(file.path, file.content);
console.log('wrote', file.path);
}
}

if (checkOnly && changed.length > 0) {
console.error('The following files are out of date:');
for (const { path } of changed) console.error(' ', path);
console.error('Run `node tools/doc/addon-verify.js` to update.');
process.exit(1);
}

function boilerplate(name, content) {
return `'use strict';
const common = require('../../common');
Expand Down

0 comments on commit 2cb9e2a

Please sign in to comment.