Documenting shape-to-template process and adding some QoL improvements #371
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: continuous deployment | |
on: | |
pull_request: | |
branches: | |
- develop | |
- main | |
push: | |
branches: | |
- develop | |
- main | |
release: | |
jobs: | |
# deploy docs for develop and main branches | |
deploy-docs: | |
runs-on: ubuntu-latest | |
steps: | |
# setup, checkout pull_request.head.ref for repo-vis | |
- name: checkout | |
uses: actions/checkout@v4 | |
with: | |
ref: ${{github.event.pull_request.head.ref}} | |
- name: setup-python | |
uses: actions/setup-python@v4 | |
with: | |
python-version: '3.11' | |
# # update repo visualization for docs | |
# - name: repo-visualizer | |
# uses: githubocto/[email protected] | |
# with: | |
# output_file: docs/reference/apidoc/code_visualization.svg | |
# excluded_paths: ".github" | |
# commit_message: "repo-visualizer [skip actions]" | |
# install project, which is required for autodoc of code | |
- name: install-poetry | |
uses: snok/install-poetry@v1 | |
with: | |
version: 1.4.0 | |
virtualenvs-create: false | |
- name: install buildingmotif | |
run: poetry install --all-extras | |
# install jupyter-book, which for some reason isn't available with poetry install | |
- name: install jupyter book | |
run: pip install jupyter-book | |
# build docs, which are deployed by repo settings | |
- name: build docs | |
run: | | |
jupyter-book config sphinx ./docs/ | |
sphinx-build ./docs/ docs/_build/html -b html | |
# TODO can we use an official GitHub Action? https://github.com/actions/deploy-pages | |
- name: deploy docs | |
uses: peaceiris/actions-gh-pages@v3 | |
with: | |
github_token: ${{ secrets.GITHUB_TOKEN }} | |
publish_dir: ./docs/_build/html | |
# deploy distribution if a new release and tag are created | |
deploy-dist: | |
needs: deploy-docs | |
if: startsWith(github.ref, 'refs/tags') | |
runs-on: ubuntu-latest | |
steps: | |
# setup | |
- name: checkout | |
uses: actions/checkout@v4 | |
- name: setup-python | |
uses: actions/setup-python@v4 | |
# install poetry and build dist | |
- name: install-poetry | |
uses: snok/install-poetry@v1 | |
with: | |
version: 1.4.0 | |
virtualenvs-in-project: false | |
virtualenvs-path: ~/.virtualenvs | |
- name: build dist | |
run: poetry build | |
- name: publish distribution to Test PyPI | |
id: test-pypi | |
uses: pypa/gh-action-pypi-publish@release/v1 | |
with: | |
password: ${{ secrets.TEST_PYPI_API_TOKEN }} | |
repository_url: https://test.pypi.org/legacy/ | |
skip_existing: true | |
- name: publish distribution to PyPI | |
if: steps.test-pypi.outcome == 'success' | |
uses: pypa/gh-action-pypi-publish@release/v1 | |
with: | |
password: ${{ secrets.PYPI_API_TOKEN }} |