Lint (Docs) #86706
Workflow file for this run
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
name: Lint (Docs) | |
run-name: Lint (Docs) | |
on: | |
pull_request: | |
merge_group: | |
jobs: | |
changes: | |
name: Check for relevant changes | |
runs-on: ubuntu-latest | |
permissions: | |
pull-requests: read | |
outputs: | |
changed: ${{ steps.changes.outputs.changed }} | |
changed_files: ${{ steps.changes.outputs.changed_files }} | |
steps: | |
- name: Checkout | |
if: ${{ github.event_name == 'merge_group' }} | |
uses: actions/checkout@v4 | |
- uses: dorny/paths-filter@de90cc6fb38fc0963ad72b210f1f284cd68cea36 # v3.0.2 | |
id: changes | |
with: | |
base: ${{ github.event.pull_request.base.ref || github.event.merge_group.base_ref }} | |
ref: ${{ github.event.pull_request.head.ref || github.event.merge_group.head_ref }} | |
list-files: csv | |
filters: | | |
changed: | |
- '.github/workflows/doc-tests.yaml' | |
- 'CHANGELOG.md' | |
- 'docs/**' | |
- 'examples/**' | |
doc-tests: | |
name: Lint (Docs) | |
needs: changes | |
if: ${{ !startsWith(github.head_ref, 'dependabot/') && needs.changes.outputs.changed == 'true' }} | |
runs-on: ubuntu-latest | |
permissions: | |
contents: read | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
with: | |
repository: 'gravitational/teleport' | |
path: 'teleport' | |
- name: Checkout | |
uses: actions/checkout@v4 | |
with: | |
repository: 'gravitational/docs-website' | |
path: 'docs' | |
# Cache node_modules. Unlike the example in the actions/cache repo, this | |
# caches the node_modules directory instead of the yarn cache. This is | |
# because yarn needs to build fresh packages even when it copies files | |
# from the yarn cache into node_modules. | |
# See: | |
# https://github.com/actions/cache/blob/main/examples.md#node---yarn | |
- uses: actions/cache@v4 | |
id: yarn-cache # use this to check for `cache-hit` (`steps.yarn-cache.outputs.cache-hit != 'true'`) | |
with: | |
path: '${{ github.workspace }}/docs/node_modules' | |
key: ${{ runner.os }}-yarn-${{ hashFiles(format('{0}/docs/yarn.lock', github.workspace)) }} | |
restore-keys: | | |
${{ runner.os }}-yarn- | |
- name: Install docs site dependencies | |
working-directory: docs | |
if: ${{ steps.yarn-cache.outputs.cache-hit != 'true' }} | |
# Prevent occasional `yarn install` executions that run indefinitely | |
timeout-minutes: 10 | |
run: yarn install | |
- name: Prepare docs site configuration | |
# The environment we use for linting the docs differs from the one we | |
# use for the live docs site in that we only test a single version of | |
# the content. | |
# | |
# To do this, we delete the three submodules we use for building the | |
# live docs site and copy a gravitational/teleport clone into the | |
# content directory. | |
# | |
# The docs engine expects a config.json file at the root of the | |
# gravitational/docs clone that associates directories with git | |
# submodules. By default, these directories represent versioned branches | |
# of gravitational/teleport. We override this in order to build only a | |
# single version of the docs. | |
# | |
# We also replace data fetched from Sanity CMS with hardcoded JSON | |
# objects to remove the need to authenticate with Sanity. Each includes | |
# the minimal set of data required for docs builds to succeed. | |
run: | | |
if [ $GITHUB_EVENT_NAME = "pull_request" ]; then | |
BRANCH=$GITHUB_HEAD_REF; | |
elif [ $GITHUB_EVENT_NAME = "merge_group" ]; then | |
# GitHub populates $GITHUB_REF with: | |
# refs/heads/gh-readonly-queue/<base branch>/pr-<PR number>-<SHA> | |
# | |
# We strip the "refs/heads/" prefix so we can check out the branch. | |
BRANCH=$(echo $GITHUB_REF | sed -E "s|refs/heads/(.*)|\1|") | |
else | |
echo "Unexpected event name: $GITHUB_EVENT_NAME"; | |
exit 1; | |
fi | |
cd $GITHUB_WORKSPACE/docs | |
echo "" > .gitmodules | |
rm -rf content/* | |
# Rather than using a submodule, copy the teleport source into the | |
# content directory. | |
cp -r "$GITHUB_WORKSPACE/teleport" "$GITHUB_WORKSPACE/docs/content/current" | |
jq -nr --arg version "current" '{"versions": [{"name": $version,"branch": $version,"deprecated": false,"isDefault": true}]}' > config.json | |
NEW_PACKAGE_JSON=$(jq '.scripts."git-update" = "echo Skipping submodule update"' package.json); | |
NEW_PACKAGE_JSON=$(jq '.scripts."prepare-sanity-data" = "echo Using pre-populated Sanity data"' <<< "$NEW_PACKAGE_JSON"); | |
echo "$NEW_PACKAGE_JSON" > package.json; | |
echo "{}" > data/events.json | |
echo '{"bannerButtons":{"second":{"title":"LOG IN","url":"https://teleport.sh"},"first":{"title":"Support","url":"https://goteleport.com/support/"}},"navbarData":{"rightSide":{},"logo":"/favicon.svg","menu":[]}}' > data/navbar.json | |
- name: Check spelling | |
working-directory: 'docs' | |
run: yarn spellcheck content/current | |
- name: Lint the docs | |
run: cd $GITHUB_WORKSPACE/docs && yarn markdown-lint | |
- name: Test the docs build | |
run: cd $GITHUB_WORKSPACE/docs && yarn install && yarn build | |
stylecheck: | |
name: Lint docs prose style | |
runs-on: ubuntu-latest | |
needs: changes | |
if: ${{ !startsWith(github.head_ref, 'dependabot/') && needs.changes.outputs.changed == 'true' && github.event_name == 'pull_request' }} | |
permissions: | |
pull-requests: read | |
steps: | |
- name: Check out the teleport repo | |
uses: actions/checkout@v4 | |
with: | |
repository: "gravitational/teleport" | |
- name: Run the linter | |
uses: errata-ai/vale-action@38bf078c328061f59879b347ca344a718a736018 # v2.1.0 | |
with: | |
version: 2.30.0 | |
# Take the comma-separated list of files returned by the "Check for | |
# relevant changes" job. | |
separator: "," | |
files: ${{ needs.changes.outputs.changed_files }} | |
# Restrict the linter to lines modified/added by a PR, not entire | |
# changed files. | |
filter_mode: added | |
fail_on_error: true | |
vale_flags: "--config=docs/.vale.ini" | |