GitHub Action
zola-action
Builds zola static site generator's site and pushes to gh-pages, or installs and runs individual zola commands
-
If you want to push this content to GH Pages, make sure that workflows have read and write permissions in the repos Settings > Actions > General > in Workflow permissions
-
Also, after a push as been made to the gh-pages branch (or manually create the branch first and avoid having to push twice) Settings > General > Pages > Build and deployment should be set to "deploy from a branch" and the branch you using for pages (gh-pages). GH's internal action will then handle pushing the artifact up and publishing if you set it in the above step.
The logic for the actual zola commands is in subaction via uses: owner/repo@ref
calls. Deploy is handled via JamesIves/github-pages-deploy-action with default arguments. Call that action separately if you need different deploy settings. See examples below.
Matches the flags and usage in the Zola CLI as closely as makes sense for a GH Action (there is no serve or init)
Main branch for running full builds/deploys
inputs:
root:
description: Directory to use as root of project. Deploy does not like this and requires an addition checkout in root
required: false
default: '.'
type: string
config:
description: Path to a config file other than config.toml in the root of project
required: false
default: 'config.toml'
type: string
base-url:
description: Force the base URL to be that value (defaults to the one in config)
required: false
default: ''
type: string
drafts:
description: Include drafts when loading the site
required: false
default: false
type: boolean
output-dir:
description: Outputs the generated site in the given path (by default 'public' dir in project root)
required: false
default: 'public'
type: string
force:
description: Force building the site even if output directory is non-empty
required: false
default: false
type: boolean
deploy:
description: Push to GitHub-Pages using JamesIves/github-pages-deploy-action defaults
required: false
default: true
type: boolean
check:
description: Check external links with `zola check`
required: false
default: true
type: boolean
Command/subaction that just installs and runs zola build
inputs:
root:
description: Directory to use as root of project
required: false
default: '.'
type: string
config:
description: Path to a config file other than config.toml in the root of project
required: false
default: 'config.toml'
type: string
base-url:
description: Force the base URL to be that value (defaults to the one in config)
required: false
default: ''
type: string
drafts:
description: Include drafts when loading the site
required: false
default: false
type: boolean
output-dir:
description: Outputs the generated site in the given path (by default 'public' dir in project root)
required: false
default: 'public'
type: string
force:
description: Force building the site even if output directory is non-empty
required: false
default: false
type: boolean
Command/subaction that just installs and runs zola check
inputs:
root:
description: Directory to use as root of project
required: false
default: '.'
type: string
config:
description: Path to a config file other than config.toml in the root of project
required: false
default: 'config.toml'
type: string
drafts:
description: Include drafts when loading the site
required: false
default: false
type: boolean
Check out the repo (with submodules for themes), build and push to gh-pages on after push to the main branch. The default GH Pages action will then deploy it, if set.
name: Deploy Zola to GH Pages
on: push
jobs:
test:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@master
with:
submodules: true
- uses: zolacti/on@main
If you want more flexibility, like not running check, or different deploy options, etc, add an explicit JamesIves/github-pages-deploy-action with options.
Checks out out a different branch for the content, without submodules; skips the check by only running build; includes drafts; and passes some additional flags to the deploy (erasing history on the non standard branch it deploys to). This still depends on the default GH action to publish, unless you include an action to push the artifacts yourself.
name: Deploy Zola to GH Pages
on: push
jobs:
test:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@master
with:
ref: docs-site #has the content in a docs folder
- uses: zolacti/on@main
with:
check: false
deploy: false
drafts: true
root: docs
- name: Deploy 🚀
uses: JamesIves/github-pages-deploy-action@v4
with:
folder: public
single-commit: true
branch: not-gh-pages
Deploy to gh-pages branch on a push to the main branch and it will just build (and check links) on pull requests
name: Deploy Zola to GH Pages
on:
push:
branches:
- main
pull_request:
jobs:
build:
runs-on: ubuntu-latest
if: github.ref != 'refs/heads/main'
steps:
-uses: zolacti/on@main
with:
deploy: false
build_and_deploy:
runs-on: ubuntu-latest
if: github.ref == 'refs/heads/main'
steps:
- uses: zolacti/on@main
If you want to be able to run commands seperately for more flexibility then call this action with the appropriate @ref
Checks out out a different branch for the content, without submodules; skips the check by only running build; includes drafts; and passes some additional flags to the deploy (erasing history on the non standard branch it deploys to). This still depends on the default GH action to publish, unless you include an action to push the artifacts yourself.
name: Deploy Zola to GH Pages
on: push
jobs:
test:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@master
with:
ref: site
- uses: zolacti/on@build
with:
drafts: true
root: docs
output-dir: not-public
- name: Deploy 🚀
uses: JamesIves/github-pages-deploy-action@v4
with:
folder: not-public
single-commit: true
branch: not-gh-pages
The test site lives in the site
branch. There's a workflow in main that triggers on push to deploy the test site.
The commands/subactions with the logic are in their respective branches.
This project was a simplification of my earlier version removing the GH Pages deploy logic to use more robust existing actions for that. My earlier version was a itself a port of Shaleen Jain's Dockerfile based Zola Deploy Action over to a composite action. Mostly I wanted the option of maintaining history on the gh-pages branch and James Ives' action does that and more.