Workflow Automation

13. Workflow Automation#

A GitHub Action associated with this repository can be used to automatically:

  • build and publish an HTML version of this book from the source markdown (HTML book available here)

  • build and publish the OU-XML from the source markdown (OU-XML document available here ; a zip archive file of the OU-XML and associated media assets are available as an automatically generated GitHub Action artefact attached to the deploy-book action reports here )

13.1. Example GitHub Action automation script#

The following GitHub Action automation script is used to:

  • checkout the contents of the repository;

  • install requirements;

  • build an HTML version of using Jupyter Book

  • generate a Sphinx XML version;

  • convert the Sphinx XML to OU-XML;

  • publish the HTML version of the book to GitHub Pages;

  • zip the OU-XML files and publish them as a workflow artifact in the GitHub Actions report for the job;

TO DO - validate the generated OU-XML.

name: deploy-book

on:
  release:
    types: [published]
  workflow_dispatch:

# This job installs dependencies, builds the book, and pushes it to `gh-pages`
jobs:
  deploy-book:
    runs-on: ubuntu-latest
    steps:
    - uses: actions/checkout@v2

    # Install dependencies
    - name: Set up Python 3.11
      uses: actions/setup-python@v1
      with:
        python-version: 3.11

    - name: Install dependencies
      run: |
        pip install -r requirements.txt
    # Build the book
    - name: Build the book
      run: |
        jupyter-book build .
        touch ./_build/html/.nojekyll
    - uses: actions/setup-node@v3
      with:
        node-version: 18
    - name: Build the OU-XML
      run: |
        jb build --builder custom --custom-builder xml .
        ouseful_obt .
        mkdir -p /var/tmp/dist
        cp -rf _build/ouxml /var/tmp/dist/
        cp -rf _build/ouxml ./_build/html
    # Push the book's HTML to github-pages
    - name: GitHub Pages action
      uses: peaceiris/actions-gh-pages@v3.6.1
      with:
        github_token: ${{ secrets.GITHUB_TOKEN }}
        publish_dir: ./_build/html
    - name: Upload docs bundle
      if: always()
      uses: actions/upload-artifact@v3
      with:
        name: ${{github.event.inputs.module}}_docs_bundle
        path: /var/tmp/dist