diff --git a/.github/workflows/deploy-docs.yml b/.github/workflows/build-docs.yml similarity index 65% rename from .github/workflows/deploy-docs.yml rename to .github/workflows/build-docs.yml index 60f8e4b4a..2b90c54b4 100644 --- a/.github/workflows/deploy-docs.yml +++ b/.github/workflows/build-docs.yml @@ -1,4 +1,4 @@ -name: Build and Deploy to Netlify +name: Build Docs on: push: pull_request: @@ -18,6 +18,18 @@ jobs: run: python3.7 -m flit install --extras doc - name: Build Docs run: python3.7 ./scripts/docs.py build-all + - name: Zip docs + run: bash ./scripts/zip-docs.sh + - uses: actions/upload-artifact@v2 + with: + name: docs-zip-${{ github.sha }} + path: ./docs.zip + - name: Trigger Docs Preview + env: + PR: "${{ github.event.number }}" + NAME: "docs-zip-${{ github.sha }}" + GITHUB_TOKEN: "${{ secrets.GITHUB_TOKEN }}" + run: bash ./scripts/trigger-docs-preview.sh - name: Deploy to Netlify uses: nwtgck/actions-netlify@v1.0.3 with: diff --git a/.github/workflows/preview-docs.yml b/.github/workflows/preview-docs.yml new file mode 100644 index 000000000..17a03b448 --- /dev/null +++ b/.github/workflows/preview-docs.yml @@ -0,0 +1,37 @@ +name: Deploy Docs +on: + workflow_dispatch: + inputs: + pr: + description: Pull Request number + required: true + name: + description: Artifact name for zip file with docs + required: true + +jobs: + deploy: + runs-on: ubuntu-18.04 + steps: + - uses: actions/download-artifact@v2 + with: + name: ${{ github.event.inputs.name }} + path: ./docs.zip + - name: Unzip docs + run: bash ./scripts/unzip-docs.sh + - name: Deploy to Netlify + id: netlify + uses: nwtgck/actions-netlify@v1.0.3 + with: + publish-dir: './site' + production-deploy: false + github-token: ${{ secrets.GITHUB_TOKEN }} + env: + NETLIFY_AUTH_TOKEN: ${{ secrets.NETLIFY_AUTH_TOKEN }} + NETLIFY_SITE_ID: ${{ secrets.NETLIFY_SITE_ID }} + - name: Comment Deploy + run: bash ./scripts/docs-comment-deploy.sh + env: + PR: "${{ github.event.inputs.pr }}" + DEPLOY_URL: "${{ steps.netlify.outputs.deploy-url }}" + GITHUB_TOKEN: "${{ secrets.GITHUB_TOKEN }}" diff --git a/.gitignore b/.gitignore index 930416586..186c432f3 100644 --- a/.gitignore +++ b/.gitignore @@ -17,6 +17,7 @@ env3.* env docs_build venv +docs.zip # vim temporary files *~ diff --git a/scripts/docs-comment-deploy.sh b/scripts/docs-comment-deploy.sh new file mode 100644 index 000000000..fa4214b8a --- /dev/null +++ b/scripts/docs-comment-deploy.sh @@ -0,0 +1,13 @@ +#! /usr/bin/env bash + +set -x +set -e + +PR=${PR:?Variable not set} +DEPLOY_URL=${DEPLOY_URL:?Variable not set} +GITHUB_TOKEN=${GITHUB_TOKEN:?Variable not set} + +curl \ + -H "Authorization: token ${GITHUB_TOKEN}" \ + https://api.github.com/repos/tiangolo/fastapi/issues/${PR}/comments \ + -d '{"body": "📝 Docs preview: '"${DEPLOY_URL}"'"}' diff --git a/scripts/trigger-docs-preview.sh b/scripts/trigger-docs-preview.sh new file mode 100644 index 000000000..7dbb8063d --- /dev/null +++ b/scripts/trigger-docs-preview.sh @@ -0,0 +1,21 @@ +#! /usr/bin/env bash + +set -x +set -e + +PR=${PR} + +if [ -z "$PR" ]; then + echo "Not a PR build, skip trigger docs preview" + exit 0 +fi + +NAME=${NAME:?Variable not set} +GITHUB_TOKEN=${GITHUB_TOKEN:?Variable not set} + +curl \ + -X POST \ + -H "Authorization: token ${GITHUB_TOKEN}" \ + -H "Accept: application/vnd.github.v3+json" \ + https://api.github.com/repos/tiangolo/fastapi/actions/workflows/preview-docs.yml/dispatches \ + -d '{"ref":"master", "inputs": {"pr": "'"${PR}"'", "name": "'"${NAME}"'"}}' diff --git a/scripts/unzip-docs.sh b/scripts/unzip-docs.sh new file mode 100644 index 000000000..f022b7deb --- /dev/null +++ b/scripts/unzip-docs.sh @@ -0,0 +1,9 @@ +#! /usr/bin/env bash + +set -x +set -e + +if [ -d ./site/ ]; then + rm -rf ./site/ +fi +unzip docs.zip diff --git a/scripts/zip-docs.sh b/scripts/zip-docs.sh new file mode 100644 index 000000000..f2b7ba3be --- /dev/null +++ b/scripts/zip-docs.sh @@ -0,0 +1,9 @@ +#! /usr/bin/env bash + +set -x +set -e + +if [ -f docs.zip ]; then + rm -rf docs.zip +fi +zip -r docs.zip ./site