From f97e8732e30a2c048f1ba2ea914d59510e7b07f5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andr=C3=A9s?= Date: Fri, 29 Nov 2019 13:06:12 +0100 Subject: [PATCH 1/6] Add pre-commit hook for API docs --- .github/CODEOWNERS | 2 +- bin/api-docs/are-readmes-unstaged.js | 39 ++++++++++++++++ bin/api-docs/packages.js | 44 +++++++++++++++++ bin/api-docs/update-readmes.js | 35 ++++++++++++++ bin/update-readmes.js | 70 ---------------------------- package.json | 7 +-- 6 files changed, 123 insertions(+), 74 deletions(-) create mode 100644 bin/api-docs/are-readmes-unstaged.js create mode 100644 bin/api-docs/packages.js create mode 100755 bin/api-docs/update-readmes.js delete mode 100755 bin/update-readmes.js diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS index c6d9694eae9b6..d1dc33c9b08ed 100644 --- a/.github/CODEOWNERS +++ b/.github/CODEOWNERS @@ -31,7 +31,7 @@ # Tooling /bin @ntwb @nerrad @ajitbohra -/bin/update-readmes.js @ntwb @nerrad @ajitbohra @nosolosw +/bin/api-docs @ntwb @nerrad @ajitbohra @nosolosw /docs/tool @youknowriad @chrisvanpatten @ajitbohra @nosolosw /packages/babel-plugin-import-jsx-pragma @gziolo @ntwb @nerrad @ajitbohra /packages/babel-plugin-makepot @ntwb @nerrad @ajitbohra diff --git a/bin/api-docs/are-readmes-unstaged.js b/bin/api-docs/are-readmes-unstaged.js new file mode 100644 index 0000000000000..507a379be808f --- /dev/null +++ b/bin/api-docs/are-readmes-unstaged.js @@ -0,0 +1,39 @@ +#!/usr/bin/env node + +/** + * Node dependencies. + */ +const { join } = require( 'path' ); +const chalk = require( 'chalk' ); +const execSync = require( 'child_process' ).execSync; + +/** + * Local dependencies. + */ +const getPackages = require( './packages' ); + +const getUnstagedFiles = () => execSync( 'git diff --name-only', { encoding: 'utf8' } ).split( '\n' ).filter( ( element ) => '' !== element ); + +const readmeFiles = getPackages().map( ( [ packageName ] ) => join( 'packages', packageName, 'README.md' ) ); +const unstagedFiles = getUnstagedFiles(); + +const unstagedReadmes = []; +unstagedFiles.forEach( ( element ) => { + if ( readmeFiles.includes( element ) ) { + unstagedReadmes.push( element ); + } +} ); + +let exitCode = 0; +if ( unstagedReadmes.length > 0 ) { + exitCode = 1; + process.stdout.write( chalk.red( + '\n', + 'Some API docs may be out of date:', + unstagedReadmes.toString(), + 'Either staged them or continue with --no-verify.', + '\n' + ) ); +} + +process.exit( exitCode ); diff --git a/bin/api-docs/packages.js b/bin/api-docs/packages.js new file mode 100644 index 0000000000000..0fcc19400bf11 --- /dev/null +++ b/bin/api-docs/packages.js @@ -0,0 +1,44 @@ +const packages = [ + 'a11y', + 'autop', + 'blob', + 'block-editor', + 'block-library', + 'block-serialization-default-parser', + 'blocks', + 'compose', + [ 'core-data', { + 'Autogenerated actions': 'src/actions.js', + 'Autogenerated selectors': 'src/selectors.js', + } ], + 'data', + 'data-controls', + 'date', + 'deprecated', + 'dom', + 'dom-ready', + 'e2e-test-utils', + 'edit-post', + 'element', + 'escape-html', + 'html-entities', + 'i18n', + 'keycodes', + 'plugins', + 'priority-queue', + 'redux-routine', + 'rich-text', + 'shortcode', + 'url', + 'viewport', + 'wordcount', +]; + +module.exports = function() { + return packages.map( ( entry ) => { + if ( ! Array.isArray( entry ) ) { + entry = [ entry, { 'Autogenerated API docs': 'src/index.js' } ]; + } + return entry; + } ); +}; diff --git a/bin/api-docs/update-readmes.js b/bin/api-docs/update-readmes.js new file mode 100755 index 0000000000000..fd66e6cbf39d0 --- /dev/null +++ b/bin/api-docs/update-readmes.js @@ -0,0 +1,35 @@ +/** + * Node dependencies. + */ +const { join } = require( 'path' ); +const spawnSync = require( 'child_process' ).spawnSync; + +/** + * Local dependencies. + */ +const getPackages = require( './packages' ); + +getPackages().forEach( ( entry ) => { + const [ packageName, targetFiles ] = entry; + + Object.entries( targetFiles ).forEach( ( [ token, path ] ) => { + // Each target operates over the same file, so it needs to be processed synchronously, + // as to make sure the processes don't overwrite each other. + const { status, stderr } = spawnSync( + join( __dirname, '..', '..', 'node_modules', '.bin', 'docgen' ).replace( / /g, '\\ ' ), + [ + join( 'packages', packageName, path ), + `--output packages/${ packageName }/README.md`, + '--to-token', + `--use-token "${ token }"`, + '--ignore "/unstable|experimental/i"', + ], + { shell: true }, + ); + + if ( status !== 0 ) { + process.stderr.write( `${ packageName } ${ stderr.toString() }\n` ); + process.exit( 1 ); + } + } ); +} ); diff --git a/bin/update-readmes.js b/bin/update-readmes.js deleted file mode 100755 index 4fb85e423b556..0000000000000 --- a/bin/update-readmes.js +++ /dev/null @@ -1,70 +0,0 @@ -/** - * Node dependencies. - */ -const { join } = require( 'path' ); -const spawnSync = require( 'child_process' ).spawnSync; - -const packages = [ - 'a11y', - 'autop', - 'blob', - 'block-editor', - 'block-library', - 'block-serialization-default-parser', - 'blocks', - 'compose', - [ 'core-data', { - 'Autogenerated actions': 'src/actions.js', - 'Autogenerated selectors': 'src/selectors.js', - } ], - 'data', - 'data-controls', - 'date', - 'deprecated', - 'dom', - 'dom-ready', - 'e2e-test-utils', - 'edit-post', - 'element', - 'escape-html', - 'html-entities', - 'i18n', - 'keycodes', - 'plugins', - 'priority-queue', - 'redux-routine', - 'rich-text', - 'shortcode', - 'url', - 'viewport', - 'wordcount', -]; - -packages.forEach( ( entry ) => { - if ( ! Array.isArray( entry ) ) { - entry = [ entry, { 'Autogenerated API docs': 'src/index.js' } ]; - } - - const [ packageName, targets ] = entry; - - Object.entries( targets ).forEach( ( [ token, path ] ) => { - // Each target operates over the same file, so it needs to be processed synchronously, - // as to make sure the processes don't overwrite each other. - const { status, stderr } = spawnSync( - join( __dirname, '..', 'node_modules', '.bin', 'docgen' ).replace( / /g, '\\ ' ), - [ - join( 'packages', packageName, path ), - `--output packages/${ packageName }/README.md`, - '--to-token', - `--use-token "${ token }"`, - '--ignore "/unstable|experimental/i"', - ], - { shell: true }, - ); - - if ( status !== 0 ) { - process.stderr.write( `${ packageName } ${ stderr.toString() }\n` ); - process.exit( 1 ); - } - } ); -} ); diff --git a/package.json b/package.json index 74ba34bb8877f..be3ea7e20cbe6 100644 --- a/package.json +++ b/package.json @@ -120,7 +120,7 @@ "fast-glob": "2.2.7", "fbjs": "0.8.17", "glob": "7.1.2", - "husky": "3.0.5", + "husky": "2.7.0", "inquirer": "6.3.1", "is-equal-shallow": "0.1.3", "jest-junit": "6.4.0", @@ -171,7 +171,7 @@ "predev": "npm run check-engines", "dev": "npm run build:packages && concurrently \"wp-scripts start\" \"npm run dev:packages\"", "dev:packages": "node ./bin/packages/watch.js", - "docs:build": "node ./docs/tool/index.js && node ./bin/update-readmes.js", + "docs:build": "node ./docs/tool/index.js && node ./bin/api-docs/update-readmes.js", "fixtures:clean": "rimraf \"packages/e2e-tests/fixtures/blocks/*.+(json|serialized.html)\"", "fixtures:server-registered": "wp-scripts env docker-run php ./bin/get-server-blocks.php > test/integration/full-content/server-registered.json", "fixtures:generate": "npm run fixtures:server-registered && cross-env GENERATE_MISSING_FIXTURES=y npm run test-unit", @@ -231,7 +231,8 @@ "node ./docs/tool/index.js" ], "packages/**/*.js": [ - "node ./bin/update-readmes.js" + "node ./bin/api-docs/update-readmes.js", + "node ./bin/api-docs/are-readmes-unstaged.js" ] }, "wp-env": { From ba132964db2b53817427675e7bc6a8a6f11ebc7f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andr=C3=A9s?= Date: Tue, 3 Dec 2019 10:39:55 +0100 Subject: [PATCH 2/6] Fix typo in message --- bin/api-docs/are-readmes-unstaged.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/bin/api-docs/are-readmes-unstaged.js b/bin/api-docs/are-readmes-unstaged.js index 507a379be808f..995be973992b7 100644 --- a/bin/api-docs/are-readmes-unstaged.js +++ b/bin/api-docs/are-readmes-unstaged.js @@ -31,7 +31,7 @@ if ( unstagedReadmes.length > 0 ) { '\n', 'Some API docs may be out of date:', unstagedReadmes.toString(), - 'Either staged them or continue with --no-verify.', + 'Either stage them or continue with --no-verify.', '\n' ) ); } From 14f3a3bdeb67428537323be5753ec0565c5a2b29 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andr=C3=A9s?= Date: Mon, 9 Dec 2019 14:58:33 +0100 Subject: [PATCH 3/6] Add pre-commit hook for handbook data docs --- docs/tool/are-data-files-unstaged.js | 38 ++++++++++++++++++++++++++++ docs/tool/packages.js | 26 +++++++++++++++++++ docs/tool/update-data.js | 35 ++++++++----------------- package.json | 3 ++- 4 files changed, 76 insertions(+), 26 deletions(-) create mode 100644 docs/tool/are-data-files-unstaged.js create mode 100644 docs/tool/packages.js diff --git a/docs/tool/are-data-files-unstaged.js b/docs/tool/are-data-files-unstaged.js new file mode 100644 index 0000000000000..7717de82a6b3d --- /dev/null +++ b/docs/tool/are-data-files-unstaged.js @@ -0,0 +1,38 @@ +#!/usr/bin/env node + +/** + * Node dependencies. + */ +const chalk = require( 'chalk' ); +const execSync = require( 'child_process' ).execSync; + +/** + * Local dependencies. + */ +const getPackages = require( './packages' ); + +const getUnstagedFiles = () => execSync( 'git diff --name-only', { encoding: 'utf8' } ).split( '\n' ).filter( ( element ) => '' !== element ); + +const readmeFiles = getPackages().map( ( [ packageName ] ) => `docs/designers-developers/developers/data/data-${ packageName.replace( '/', '-' ) }.md` ); +const unstagedFiles = getUnstagedFiles(); + +const unstagedReadmes = []; +unstagedFiles.forEach( ( element ) => { + if ( readmeFiles.includes( element ) ) { + unstagedReadmes.push( element ); + } +} ); + +let exitCode = 0; +if ( unstagedReadmes.length > 0 ) { + exitCode = 1; + process.stdout.write( chalk.red( + '\n', + 'Some API docs may be out of date:', + unstagedReadmes.toString(), + 'Either stage them or continue with --no-verify.', + '\n' + ) ); +} + +process.exit( exitCode ); diff --git a/docs/tool/packages.js b/docs/tool/packages.js new file mode 100644 index 0000000000000..5caf4d258e156 --- /dev/null +++ b/docs/tool/packages.js @@ -0,0 +1,26 @@ +const packages = [ + [ 'core', { + 'Autogenerated actions': 'packages/core-data/src/actions.js', + 'Autogenerated selectors': 'packages/core-data/src/selectors.js', + } ], + 'core/annotations', + 'core/blocks', + 'core/block-editor', + 'core/editor', + 'core/edit-post', + 'core/notices', + 'core/nux', + 'core/viewport', +]; + +module.exports = function() { + return packages.map( ( entry ) => { + if ( ! Array.isArray( entry ) ) { + entry = [ entry, { + 'Autogenerated actions': `packages/${ entry.replace( 'core/', '' ) }/src/store/actions.js`, + 'Autogenerated selectors': `packages/${ entry.replace( 'core/', '' ) }/src/store/selectors.js`, + } ]; + } + return entry; + } ); +}; diff --git a/docs/tool/update-data.js b/docs/tool/update-data.js index 46263e788dfe0..4a5d231e3c601 100644 --- a/docs/tool/update-data.js +++ b/docs/tool/update-data.js @@ -4,31 +4,15 @@ const { join } = require( 'path' ); const spawnSync = require( 'child_process' ).spawnSync; -const modules = [ - [ 'core', { - 'Autogenerated actions': 'packages/core-data/src/actions.js', - 'Autogenerated selectors': 'packages/core-data/src/selectors.js', - } ], - 'core/annotations', - 'core/blocks', - 'core/block-editor', - 'core/editor', - 'core/edit-post', - 'core/notices', - 'core/nux', - 'core/viewport', -]; +/** + * Local dependencies. + */ +const getPackages = require( './packages' ); -modules.forEach( ( entry ) => { - if ( ! Array.isArray( entry ) ) { - entry = [ entry, { - 'Autogenerated actions': `packages/${ entry.replace( 'core/', '' ) }/src/store/actions.js`, - 'Autogenerated selectors': `packages/${ entry.replace( 'core/', '' ) }/src/store/selectors.js`, - } ]; - } - const [ namespace, targets ] = entry; +getPackages().forEach( ( entry ) => { + const [ packageName, targetFiles ] = entry; - Object.entries( targets ).forEach( ( [ token, target ] ) => { + Object.entries( targetFiles ).forEach( ( [ token, target ] ) => { // Note that this needs to be a sync process for each output file that is updated: // until docgen provides a way to update many tokens at once, we need to make sure // the output file is updated before starting the second pass for the next token. @@ -36,7 +20,7 @@ modules.forEach( ( entry ) => { join( __dirname, '..', '..', 'node_modules', '.bin', 'docgen' ).replace( / /g, '\\ ' ), [ target, - `--output docs/designers-developers/developers/data/data-${ namespace.replace( '/', '-' ) }.md`, + `--output docs/designers-developers/developers/data/data-${ packageName.replace( '/', '-' ) }.md`, '--to-token', `--use-token "${ token }"`, '--ignore "/unstable|experimental/i"', @@ -45,7 +29,8 @@ modules.forEach( ( entry ) => { ); if ( status !== 0 ) { - throw stderr.toString(); + process.stderr.write( `${ packageName } ${ stderr.toString() }\n` ); + process.exit( 1 ); } } ); } ); diff --git a/package.json b/package.json index be3ea7e20cbe6..627cffb126e01 100644 --- a/package.json +++ b/package.json @@ -228,7 +228,8 @@ "wp-scripts lint-js" ], "{docs/{toc.json,tool/*.js},packages/{*/README.md,*/src/{actions,selectors}.js,components/src/*/**/README.md}}": [ - "node ./docs/tool/index.js" + "node ./docs/tool/index.js", + "node ./docs/tool/are-data-files-unstaged.js" ], "packages/**/*.js": [ "node ./bin/api-docs/update-readmes.js", From 31378db72466001ea2843f1e13c5d194fcc50afd Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andr=C3=A9s?= Date: Mon, 16 Dec 2019 15:58:48 +0100 Subject: [PATCH 4/6] Revert husky change --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index 627cffb126e01..f6605e2e2b965 100644 --- a/package.json +++ b/package.json @@ -120,7 +120,7 @@ "fast-glob": "2.2.7", "fbjs": "0.8.17", "glob": "7.1.2", - "husky": "2.7.0", + "husky": "3.0.5", "inquirer": "6.3.1", "is-equal-shallow": "0.1.3", "jest-junit": "6.4.0", From f4aa5ff9bf6ddaae7929e7a1169184dfb31b0382 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andr=C3=A9s?= Date: Thu, 19 Dec 2019 11:42:53 +0100 Subject: [PATCH 5/6] Simplify code --- bin/api-docs/are-readmes-unstaged.js | 15 ++------------- 1 file changed, 2 insertions(+), 13 deletions(-) diff --git a/bin/api-docs/are-readmes-unstaged.js b/bin/api-docs/are-readmes-unstaged.js index 995be973992b7..19c7eeba8d162 100644 --- a/bin/api-docs/are-readmes-unstaged.js +++ b/bin/api-docs/are-readmes-unstaged.js @@ -13,20 +13,11 @@ const execSync = require( 'child_process' ).execSync; const getPackages = require( './packages' ); const getUnstagedFiles = () => execSync( 'git diff --name-only', { encoding: 'utf8' } ).split( '\n' ).filter( ( element ) => '' !== element ); - const readmeFiles = getPackages().map( ( [ packageName ] ) => join( 'packages', packageName, 'README.md' ) ); -const unstagedFiles = getUnstagedFiles(); - -const unstagedReadmes = []; -unstagedFiles.forEach( ( element ) => { - if ( readmeFiles.includes( element ) ) { - unstagedReadmes.push( element ); - } -} ); +const unstagedReadmes = getUnstagedFiles().filter( ( element ) => readmeFiles.includes( element ) ); -let exitCode = 0; if ( unstagedReadmes.length > 0 ) { - exitCode = 1; + process.exitCode = 1; process.stdout.write( chalk.red( '\n', 'Some API docs may be out of date:', @@ -35,5 +26,3 @@ if ( unstagedReadmes.length > 0 ) { '\n' ) ); } - -process.exit( exitCode ); From 7790978ad303388abe790c69ad3005b5699aca24 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andr=C3=A9s?= Date: Thu, 19 Dec 2019 12:04:18 +0100 Subject: [PATCH 6/6] Replicate changes from are-readmes-unstaged --- docs/tool/are-data-files-unstaged.js | 15 ++------------- 1 file changed, 2 insertions(+), 13 deletions(-) diff --git a/docs/tool/are-data-files-unstaged.js b/docs/tool/are-data-files-unstaged.js index 7717de82a6b3d..5591de0ae6d62 100644 --- a/docs/tool/are-data-files-unstaged.js +++ b/docs/tool/are-data-files-unstaged.js @@ -12,20 +12,11 @@ const execSync = require( 'child_process' ).execSync; const getPackages = require( './packages' ); const getUnstagedFiles = () => execSync( 'git diff --name-only', { encoding: 'utf8' } ).split( '\n' ).filter( ( element ) => '' !== element ); - const readmeFiles = getPackages().map( ( [ packageName ] ) => `docs/designers-developers/developers/data/data-${ packageName.replace( '/', '-' ) }.md` ); -const unstagedFiles = getUnstagedFiles(); - -const unstagedReadmes = []; -unstagedFiles.forEach( ( element ) => { - if ( readmeFiles.includes( element ) ) { - unstagedReadmes.push( element ); - } -} ); +const unstagedReadmes = getUnstagedFiles().filter( ( element ) => readmeFiles.includes( element ) ); -let exitCode = 0; if ( unstagedReadmes.length > 0 ) { - exitCode = 1; + process.exitCode = 1; process.stdout.write( chalk.red( '\n', 'Some API docs may be out of date:', @@ -34,5 +25,3 @@ if ( unstagedReadmes.length > 0 ) { '\n' ) ); } - -process.exit( exitCode );