docswithmkdoc #4
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: docswithmkdoc | |
on: | |
push: | |
branches: | |
- master | |
workflow_dispatch: | |
jobs: | |
generate-files: | |
runs-on: ubuntu-20.04 | |
# https://docs.github.com/en/actions/creating-actions/creating-a-composite-action | |
steps: | |
- name: Clone splink repository | |
run: | | |
git clone --depth 1 --branch master https://github.com/moj-analytical-services/splink.git splink_temp | |
cp -r splink_temp/* . | |
rm -rf splink_temp | |
#---------------------------------------------- | |
# -- save a few section by caching poetry -- | |
#---------------------------------------------- | |
- name: Load cached Poetry installation | |
uses: actions/cache@v2 | |
with: | |
path: ~/.local # the path depends on the OS | |
key: poetry-0 # increment to reset cache | |
#---------------------------------------------- | |
# ----- install & configure poetry ----- | |
#---------------------------------------------- | |
- name: Install Poetry | |
uses: snok/install-poetry@v1 | |
with: | |
version: "1.7.0" | |
virtualenvs-create: true | |
virtualenvs-in-project: true | |
installer-parallel: true | |
#---------------------------------------------- | |
# load cached venv if cache exists | |
#---------------------------------------------- | |
- name: Load cached venv | |
id: cached-poetry-dependencies | |
uses: actions/cache@v2 | |
with: | |
path: .venv | |
key: venv-${{ runner.os }}-${{ steps.setup-python.outputs.python-version }}-${{ hashFiles('**/poetry.lock') }}-00 | |
#---------------------------------------------- | |
# install dependencies if cache does not exist | |
#---------------------------------------------- | |
- name: Install dependencies | |
if: steps.cached-poetry-dependencies.outputs.cache-hit != 'true' | |
run: poetry install --no-interaction --no-root | |
#---------------------------------------------- | |
# install your root project, if required | |
#---------------------------------------------- | |
- name: Install library | |
run: poetry install --no-interaction | |
- name: Generate comparison/level library dialect + dataset tables | |
run: | | |
source .venv/bin/activate | |
mv scripts/generate_dialect_comparison_docs.py generate_dialect_comparison_docs.py | |
mv scripts/generate_dataset_docs.py generate_dataset_docs.py | |
tree . | |
python generate_dialect_comparison_docs.py | |
python generate_dataset_docs.py | |
- name: Upload generated docs files | |
uses: actions/upload-artifact@v3 | |
with: | |
name: generated_files | |
path: docs/includes/generated_files | |
build: | |
runs-on: ubuntu-latest | |
needs: generate-files | |
steps: | |
- uses: actions/setup-python@v4 | |
with: | |
python-version: 3.9 | |
- uses: actions/checkout@v3 | |
with: | |
token: ${{ secrets.GITHUB_TOKEN }} | |
- uses: actions/download-artifact@v3 | |
with: | |
name: generated_files | |
path: docs/includes/generated_files | |
- run: tree docs/ | |
- name: Clone splink repository | |
run: | | |
git clone --depth 1 --branch master https://github.com/moj-analytical-services/splink.git splink_temp | |
cp -r splink_temp/* . | |
rm -rf splink_temp | |
- name: install docs dependencies | |
run: | | |
pip install --upgrade pip | |
pip install -r scripts/docs-requirements.txt | |
- name: build documentation | |
run: mkdocs build | |
- name: check links | |
uses: lycheeverse/[email protected] | |
with: | |
fail: true | |
args: --offline site/ --verbose './**/*.html' | |
- name: Upload built site | |
uses: actions/upload-artifact@v3 | |
with: | |
name: built_site | |
path: site | |
# some environment info: | |
- run: pip freeze | |
- run: mkdocs --version | |
deploy: | |
runs-on: ubuntu-latest | |
needs: build | |
# we only deplot on push to master | |
# this job doesn't run if this is triggered by a PR | |
if: github.event_name == 'push' | |
steps: | |
- uses: actions/setup-python@v4 | |
with: | |
python-version: 3.9 | |
- uses: actions/checkout@v3 | |
with: | |
token: ${{ secrets.GITHUB_TOKEN }} | |
- uses: actions/download-artifact@v3 | |
with: | |
name: built_site | |
path: site | |
- name: commit and force-push to gh-pages branch | |
run: | | |
pip install ghp-import==2.1.0 | |
git config --global user.email "41898282+github-actions[bot]@users.noreply.github.com" | |
git config --global user.name "github-actions[bot]" | |
ghp-import -opfm "Update docs from commit ${{ github.sha }}" site |