From e620c40a1451316f6d3fbac86466fb9dc6aeb800 Mon Sep 17 00:00:00 2001 From: CrazyMax Date: Tue, 2 Aug 2022 21:22:00 +0200 Subject: [PATCH] ci: upstream docs conformance validation Signed-off-by: CrazyMax --- .github/workflows/docs-upstream.yml | 118 ++++++++++++++++++++++++++++ .github/workflows/validate.yml | 20 ----- 2 files changed, 118 insertions(+), 20 deletions(-) create mode 100644 .github/workflows/docs-upstream.yml diff --git a/.github/workflows/docs-upstream.yml b/.github/workflows/docs-upstream.yml new file mode 100644 index 00000000..eb803105 --- /dev/null +++ b/.github/workflows/docs-upstream.yml @@ -0,0 +1,118 @@ +# this workflow runs the remote validate bake target from docker/docker.github.io +# to check if yaml reference docs and markdown files used in this repo are still valid +# https://github.com/docker/docker.github.io/blob/98c7c9535063ae4cd2cd0a31478a21d16d2f07a3/docker-bake.hcl#L34-L36 +name: docs-upstream + +concurrency: + group: ${{ github.workflow }}-${{ github.ref }} + cancel-in-progress: true + +on: + push: + branches: + - 'master' + - 'v[0-9]*' + paths: + - '.github/workflows/docs-upstream.yml' + - 'docs/**' + pull_request: + paths: + - '.github/workflows/docs-upstream.yml' + - 'docs/**' + +jobs: + docs-yaml: + runs-on: ubuntu-latest + steps: + - + name: Checkout + uses: actions/checkout@v3 + - + name: Set up Docker Buildx + uses: docker/setup-buildx-action@v2 + with: + version: latest + - + name: Build reference YAML docs + uses: docker/bake-action@v2 + with: + targets: update-docs + set: | + *.output=/tmp/buildx-docs + *.cache-from=type=gha,scope=docs-yaml + *.cache-to=type=gha,scope=docs-yaml,mode=max + env: + DOCS_FORMATS: yaml + - + name: Upload reference YAML docs + uses: actions/upload-artifact@v3 + with: + name: docs-yaml + path: /tmp/buildx-docs/out/reference + retention-days: 1 + + validate: + runs-on: ubuntu-latest + needs: + - docs-yaml + steps: + - + name: Checkout + uses: actions/checkout@v3 + with: + repository: docker/docker.github.io + - + name: Install js-yaml + run: npm install js-yaml + - + # use the actual buildx ref that triggers this workflow, so we make + # sure pages fetched by docs repo are still valid + # https://github.com/docker/docker.github.io/blob/98c7c9535063ae4cd2cd0a31478a21d16d2f07a3/_config.yml#L164-L173 + name: Set correct ref to fetch remote resources + uses: actions/github-script@v6 + with: + script: | + const fs = require('fs'); + const yaml = require('js-yaml'); + + const configFile = '_config.yml' + const config = yaml.load(fs.readFileSync(configFile, 'utf8')); + for (const remote of config['fetch-remote']) { + if (remote['repo'] != 'https://github.com/docker/buildx') { + continue; + } + remote['ref'] = "${{ github.ref }}"; + } + + try { + fs.writeFileSync(configFile, yaml.dump(config), 'utf8') + } catch (err) { + console.error(err.message) + process.exit(1) + } + - + name: Prepare + run: | + # print docs jekyll config updated in previous step + yq _config.yml + # cleanup reference yaml docs and js-yaml module + rm -rf ./_data/buildx/* ./node_modules + - + name: Download built reference YAML docs + uses: actions/download-artifact@v3 + with: + name: docs-yaml + path: ./_data/buildx/ + - + name: Set up Docker Buildx + uses: docker/setup-buildx-action@v2 + with: + version: latest + - + name: Validate + uses: docker/bake-action@v2 + with: + targets: validate + set: | + *.cache-from=type=gha,scope=docs-upstream + *.cache-to=type=gha,scope=docs-upstream,mode=max diff --git a/.github/workflows/validate.yml b/.github/workflows/validate.yml index 708e76c6..e4f6da78 100644 --- a/.github/workflows/validate.yml +++ b/.github/workflows/validate.yml @@ -40,23 +40,3 @@ jobs: name: Run run: | make ${{ matrix.target }} - - validate-docs-yaml: - runs-on: ubuntu-latest - needs: - - validate - steps: - - - name: Checkout - uses: actions/checkout@v3 - - - name: Set up Docker Buildx - uses: docker/setup-buildx-action@v2 - with: - version: latest - - - name: Run - run: | - make docs - env: - FORMATS: yaml