chore: ensure new-docs are up to date (#5994)

* chore: ensure new-docs are up to date

This adds a Travis check that if we re-generate the docs we get the
exact output (by checking if the Git tree is dirty).

We do the dirty check by using `git status --porcelain`, seeing how many
lines that outputs, and using that as the exit code (taking only the
first 255 lines to avoid invalid exit codes). `--porcelain` makes the
output be empty if the repo is not dirty in anyway which translates into
an exit code of 0.

We can't use `git diff-index --quiet HEAD` as it exits with 0 if there are
untracked files in the repo but we want that to cause a failure.
This commit is contained in:
Jack Franklin 2020-06-11 09:48:37 +01:00 committed by GitHub
parent b86ff21b64
commit 91eb74519c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 3 additions and 1 deletions

View File

@ -67,6 +67,7 @@ jobs:
- npm run test-install - npm run test-install
- npm run lint - npm run lint
- npm run test-doclint - npm run test-doclint
- npm run ensure-new-docs-up-to-date
# Runs unit tests on Linux + Firefox # Runs unit tests on Linux + Firefox
- node_js: "10.19.0" - node_js: "10.19.0"

View File

@ -33,7 +33,8 @@
"update-protocol-d-ts": "node utils/protocol-types-generator update", "update-protocol-d-ts": "node utils/protocol-types-generator update",
"compare-protocol-d-ts": "node utils/protocol-types-generator compare", "compare-protocol-d-ts": "node utils/protocol-types-generator compare",
"test-install": "scripts/test-install.sh", "test-install": "scripts/test-install.sh",
"generate-docs": "npm run tsc && api-extractor run --local --verbose && api-documenter markdown -i temp -o new-docs" "generate-docs": "npm run tsc && api-extractor run --local --verbose && api-documenter markdown -i temp -o new-docs",
"ensure-new-docs-up-to-date": "npm run generate-docs && exit `git status --porcelain | head -255 | wc -l`"
}, },
"files": [ "files": [
"lib/", "lib/",