CI #2194
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: CI | |
on: | |
schedule: | |
- cron: '30 5 * * *' | |
push: | |
branches: | |
- master | |
pull_request: | |
branches: | |
- '*' | |
jobs: | |
changes: | |
# Disable the filter on scheduled runs because we don't want to skip those | |
if: github.event_name != 'schedule' | |
continue-on-error: true # Makes sure errors won't stop us | |
runs-on: ubuntu-latest | |
outputs: | |
src: ${{ steps.filter.outputs.src }} | |
steps: | |
# For PRs the path filter check with Github API, so no need to checkout | |
# for them. | |
- if: github.event_name != 'pull_request' | |
name: Checkout (if not PR) | |
uses: actions/checkout@v4 | |
- uses: dorny/paths-filter@v2 | |
id: filter | |
with: | |
filters: | | |
src: | |
- '**.cfg' | |
- '**.nims' | |
- '**.nim' | |
- '**.nimble' | |
- 'tests/**' | |
- '.github/workflows/ci.yml' | |
build: | |
# Build if the files we care about are changed. | |
needs: changes | |
# Make sure to always run regardless of whether the filter success or not. | |
# When the filter fails there won't be an output, so checking for `false` | |
# state is better than checking for `true`. | |
# | |
# The always() function here is required for the job to always run despite | |
# what Github docs said, see: https://github.com/actions/runner/issues/491 | |
if: always() && !cancelled() && needs.changes.outputs.src != 'false' | |
strategy: | |
fail-fast: false | |
matrix: | |
os: [ubuntu-latest] | |
nim: [devel] | |
name: '${{ matrix.os }} (${{ matrix.nim }})' | |
runs-on: ${{ matrix.os }} | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
with: | |
path: project | |
- name: Setup Nim | |
uses: alaviss/[email protected] | |
with: | |
path: nim | |
version: ${{ matrix.nim }} | |
- name: Run examples | |
shell: bash | |
run: | | |
sudo apt-get update | |
sudo apt install --fix-missing valgrind | |
cd project | |
nimble --accept develop | |
nimble --accept install "https://github.com/disruptek/balls" | |
cd examples | |
balls --path=".." --panics:on --exceptions:goto --backend:c --mm:arc --mm:orc --threads:on | |
- name: Run tests | |
shell: bash | |
run: | | |
cd project | |
nimble --accept develop | |
balls --path="." --panics:on --exceptions:goto --backend:c --mm:arc --mm:orc --threads:on | |
- name: Build docs | |
if: ${{ matrix.docs }} == 'true' | |
shell: bash | |
run: | | |
cd project | |
branch=${{ github.ref }} | |
branch=${branch##*/} | |
nimble doc --project --outdir:docs --path="." \ | |
'--git.url:https://github.com/${{ github.repository }}' \ | |
'--git.commit:${{ github.sha }}' \ | |
"--git.devel:$branch" \ | |
cps.nim | |
# Ignore failures for older Nim | |
cp docs/{the,}index.html || true | |
- name: Publish docs | |
if: > | |
github.event_name == 'push' && github.ref == 'refs/heads/master' && | |
matrix.os == 'ubuntu-latest' && matrix.nim == 'devel' | |
uses: crazy-max/[email protected] | |
with: | |
build_dir: project/docs | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
# Set check-required on this | |
success: | |
needs: build | |
if: always() | |
runs-on: ubuntu-latest | |
name: 'All check passes' | |
steps: | |
- if: contains(needs.*.result, 'failure') || contains(needs.*.result, 'cancelled') | |
name: 'Fail when previous jobs fails' | |
run: | | |
echo "::error::One of the previous jobs failed" | |
exit 1 |