Browse Source
🚀 Preview docs for external PRs (#1738)
* 🍱 Save docs zip when building docs
* 🙈 Add docs.zip artifact to .gitignore
* 🚀 Update deploy artifact name
* ♻️ Upload artifact directory
* ✨ Add WIP trigger docs preview
* ♻️ Update trigger docs preview
* 👷 Update env vars for docs preview
* 👷 Update PR extraction
* 👷 Try to show GitHub event
* 💚 Try to see if GitHub context templates is causing the problem
* 💚 Try to debug context GitHub event
* 🔊 Debug GitHub event context
* 👷 Update debugging action
* 👷 Update debug
* 👷 Update Action
* ♻️ Update script to trigger docs preview
* ⚡️ Try to use Zip again to improve speed
* 🔧 Update zip scripts
* ✨ Add preview docs on event
* 🚀 Trigger deploy preview on PRs
* 🐛 Fix trigger script env vars
pull/1739/head
Sebastián Ramírez
5 years ago
committed by
GitHub
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with
103 additions and
1 deletions
-
.github/workflows/build-docs.yml
-
.github/workflows/preview-docs.yml
-
.gitignore
-
scripts/docs-comment-deploy.sh
-
scripts/trigger-docs-preview.sh
-
scripts/unzip-docs.sh
-
scripts/zip-docs.sh
|
|
@ -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/[email protected] |
|
|
|
with: |
|
|
@ -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/[email protected] |
|
|
|
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 }}" |
|
|
@ -17,6 +17,7 @@ env3.* |
|
|
|
env |
|
|
|
docs_build |
|
|
|
venv |
|
|
|
docs.zip |
|
|
|
|
|
|
|
# vim temporary files |
|
|
|
*~ |
|
|
|
|
|
@ -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}"'"}' |
|
|
@ -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}"'"}}' |
|
|
@ -0,0 +1,9 @@ |
|
|
|
#! /usr/bin/env bash |
|
|
|
|
|
|
|
set -x |
|
|
|
set -e |
|
|
|
|
|
|
|
if [ -d ./site/ ]; then |
|
|
|
rm -rf ./site/ |
|
|
|
fi |
|
|
|
unzip docs.zip |
|
|
@ -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 |