GitHub Action
Hugo Build and Deploy
An action for building Hugo websites. Build your site from a source branch and deploy on a release branch.
This action supports deploying to the same repository or pushing build data to a submodule. It's great for automating Hugo site builds and maintaining a separate release branch.
v2.1 Fix: Build process no longer throws an error when there are no changes to commit. Safe exit instead. This was mainly done to prevent the whole workflow from failing.
See wiki for more info on these changes.)
- New release pattern - v1 pushed changes to the source branch, v2 pushes changes to a release branch
- Added test mode - runs key checks on your input values to help you verify your action configuration before running live!
- Fixed git configuration - config now set only if empty to avoid conflicts with other job steps
- Cleanup - the main deploy script was separated into multiple scripts for better maintainability
Add a workflow to your repo that includes this action (sample below). Please note that scheduled workflows only run on the default branch of a repo.
For git checkout, I use actions/checkout.(A token or SSH is needed for checking out private submodule repos.) For installing Hugo on the runner, I use peaceiris/actions-hugo.
Note: For clarity reasons, some variable names have been changed a bit between v1 and v2. Please check your workflows for the correct input.
Name | Required? | Default | Example |
---|---|---|---|
hugo_publish_directory | ✅ | 'public' | 'documents' |
source_branch | ✅ | 'main' | |
release_branch | ✅ | 'release' | |
submodule_release_branch | 'main' |
Advanced Use (see wiki for further details)
Name | Default | Example |
---|---|---|
hugo_build_options | '-D --minify --ignoreCache' | |
merge_args | '-s recursive -Xtheirs' | '-X Ours' |
full_rebuild | 'false' | |
full_rebuild_verbose | 'false' | |
do_not_delete_regex | '\.txt|^posts$|static.css' | |
commit_message | 'I like big builds, and I cannot lie.' | |
git_config_user | 'Action - Hugo Deploy' | 'aormsby' |
git_config_email | '[email protected]' | '[email protected]' |
strict_build_mode | 'true' | |
tag_release | 'false' | |
test_mode | 'false' |
Some basic git config settings must be in place to pull and push data during the action. As seen above, these inputs are required and have default values. They are reset when this action step is finished.
Name | Output | Description |
---|---|---|
was_new_build_created | true/false | Outputs true if a new build was made, false if repo is up-to-date and build was skipped. |
Want more output variables? Open an issue and let me know.
on:
schedule:
- cron: '0 7 * * 1,4'
# scheduled at 07:00 every Monday and Thursday
workflow_dispatch:
# to run manual builds
jobs:
build_and_deploy_hugo_site:
runs-on: ubuntu-latest
name: Build and deploy Hugo site
steps:
- name: Setup Hugo
uses: peaceiris/actions-hugo@v2
with:
hugo-version: '0.88.1'
- name: Checkout repo on source_branch
uses: actions/checkout@v2
with:
submodules: 'recursive'
# <<recommended if project uses git submodules for any purpose>>
# <<required if deploying to git submodule directory>>
token: ${{ secrets.MY_SECRET }} # <<if needed for private repos>>
fetch-depth: '0'
# <<fetch-depth: '0' currently required until shallow clone problems are solved>>
- name: Build site and push to release branch
uses: aormsby/[email protected]
id: build_step # <<for outputs>>
with:
source_branch: 'main'
release_branch: 'bon-voyage'
# submodule_release_branch: 'subbed' <<only provide if you are publishing to directory with git submodule>>
# full_rebuild: true
# hugo_publish_directory: 'documents' <<publish to another directory if needed>>
# hugo_build_options: '-D --minify --ignoreCache' <<hugo build cis customizable>>
# commit_message: "I love this action."
# test_mode: true <<enable to run a few verification tests before your first live run>>
# <<lots of other options!>>
- name: Check if new build was made
if: steps.build.outputs.was_new_build_created == 'true'
run: echo "YAAASSSS new build."
if: steps.build.outputs.was_new_build_created == 'false'
run: echo "NOOOOOOO new build."