Skip to content

dependabot: group GitHub Actions updates (#100) #499

dependabot: group GitHub Actions updates (#100)

dependabot: group GitHub Actions updates (#100) #499

Workflow file for this run

name: CI
on:
push:
branches:
- master
pull_request:
concurrency:
group: ci-${{ github.ref }}
cancel-in-progress: true
jobs:
context:
name: Obtain run context
runs-on: ubuntu-latest
outputs:
should-skip: ${{ steps.skip.outputs.should_skip }}
skip-reason: ${{ steps.skip.outputs.reason }}
skipped-by: ${{ steps.skip.outputs.skipped_by }}
permissions:
actions: read
steps:
- name: Skip duplicate actions
id: skip
uses: fkirc/[email protected]
with:
paths_ignore: '["**/readme.md"]'
build:
needs: context
if: needs.context.outputs.should-skip != 'true' && !cancelled()
strategy:
fail-fast: false
matrix:
compiler:
- name: nim
version: version-2-0
- name: nimskull
version: "*"
target: [linux, macos, windows]
arch: [i386, amd64]
include:
- target: linux
builder: ubuntu-20.04
- target: macos
builder: macos-12
- target: windows
builder: windows-2019
- target: windows
arch: i386
winlib_arch: i686
- target: windows
arch: amd64
winlib_arch: x86_64
- target: linux
arch: amd64
compiler:
name: nim
version: version-2-0
uploaddocs: true
exclude:
- target: macos
arch: i386
# TODO: a handful of problems with SSL must be solved before this
- target: windows
compiler:
name: nimskull
name:
${{ matrix.target }} on ${{ matrix.arch }} (${{ matrix.compiler.name }}
${{ matrix.compiler.version }})
runs-on: ${{ matrix.builder }}
defaults:
run:
shell: bash
working-directory: nim-sys
steps:
- name: Checkout
uses: actions/[email protected]
with:
path: nim-sys
- name: Configure Nim for 32 bit GCC (Linux-only)
if: matrix.arch == 'i386' && runner.os == 'Linux'
run: |
sudo dpkg --add-architecture i386
sudo apt-fast update -qq
sudo DEBIAN_FRONTEND='noninteractive' apt-fast install \
--no-install-recommends -yq \
gcc-10-i686-linux-gnu \
g++-10-i686-linux-gnu \
libc6-dev-i386-cross \
libstdc++-10-dev-i386-cross \
libssl1.1:i386
mkdir -p ~/.config/nim
cat << EOF > ~/.config/nim/nim.cfg
cpu = "i386"
gcc.exe = "i686-linux-gnu-gcc-10"
gcc.cpp.exe = "i686-linux-gnu-g++-10"
gcc.linkerexe = "i686-linux-gnu-gcc-10"
gcc.cpp.linkerexe = "i686-linux-gnu-g++-10"
EOF
- name: Configure target architecture for Windows (i386)
if: matrix.arch == 'i386' && runner.os == 'Windows'
run: |
mkdir -p "$APPDATA/nim"
echo 'cpu = "i386"' >> "$APPDATA/nim/nim.cfg"
- name: Setup GCC (Windows-only)
if: runner.os == 'Windows'
uses: bwoodsend/[email protected]
with:
architecture: ${{ matrix.winlib_arch }}
- name: Setup Nim
if: matrix.compiler.name == 'nim'
uses: alaviss/[email protected]
with:
path: nim
version: ${{ matrix.compiler.version }}
architecture: ${{ matrix.arch }}
- name: Setup nimskull
id: nimskull
if: matrix.compiler.name == 'nimskull'
uses: nim-works/[email protected]
with:
nimskull-version: ${{ matrix.compiler.version }}
- name: Fetch nimble source for nimskull
if: matrix.compiler.name == 'nimskull'
uses: actions/[email protected]
with:
path: nimble
repository: alaviss/nimble
ref: nimskull
- name: Install nimble for nimskull
if: matrix.compiler.name == 'nimskull'
run: |
nim c -d:release -o:"$NIMSKULL_BIN/nimble" src/nimble.nim
# Add nimble binary folder to PATH
echo "$HOME/.nimble/bin" >> "$GITHUB_PATH"
working-directory: nimble
env:
NIMSKULL_BIN: ${{ steps.nimskull.outputs.bin-path }}
- name: Install dependencies
run: |
nimble install -y --depsOnly
nimble install -y "https://github.com/disruptek/balls@>= 3.9.11 & < 4.0.0"
- name: Run tests
run: balls
- name: Build docs
shell: bash
run: |
branch=$GITHUB_REF
branch=${branch##*/}
for i in src/sys/*.nim src/sys/ioqueue/*.nim; do
nim doc --project --outdir:htmldocs \
"--git.url:https://github.com/$GITHUB_REPOSITORY" \
"--git.commit:$GITHUB_SHA" \
"--git.devel:$branch" \
"$i"
done
# Ignore failures for older Nim
cp htmldocs/{the,}index.html || true
- name: Upload GitHub Pages artifact
if: matrix.uploaddocs
uses: actions/[email protected]
with:
path: nim-sys/htmldocs
deploy:
needs:
- build
- context
if: |
github.ref == 'refs/heads/master' &&
success() ||
(!cancelled() &&
!failure() &&
needs.context.outputs.skip-reason == 'skip_after_successful_duplicate')
permissions:
actions: read
pages: write
id-token: write
environment:
name: github-pages
url: ${{ steps.deployment.outputs.page_url }}
name: Deploy docs to GitHub Pages
runs-on: ubuntu-latest
steps:
- name: Download github-pages artifact
if: needs.context.outputs.skip-reason == 'skip_after_successful_duplicate'
uses: actions/[email protected]
with:
name: github-pages
path: page
run-id: ${{ fromJson(needs.context.outputs.skipped-by).id }}
github-token: ${{ github.token }}
- name: Upload pages artifact
if: needs.context.outputs.skip-reason == 'skip_after_successful_duplicate'
uses: actions/[email protected]
with:
name: github-pages
path: page/artifact.tar
retention-days: 1
if-no-files-found: error
- name: Deploy page
id: deployment
uses: actions/[email protected]
passed:
needs: build
if: failure() || cancelled()
name: All tests passed
runs-on: ubuntu-latest
steps:
- run: exit 1