Skip to content

split up jobs in ci #32

split up jobs in ci

split up jobs in ci #32

Workflow file for this run

name: Do the thing in CI
on:
push:
branches: ['master']
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
jobs:
run:
runs-on: ubuntu-latest
strategy:
matrix:
build:
- bun
- clang
- deno
- fortran
- gcc
- java
- kotlin
- node
- python3
- ruby
- rust
- scala
steps:
# clone
- name: Checkout
uses: actions/checkout@v3
# cache
- uses: actions/cache@v3
with:
path: |
~/.cargo/bin/
~/.cargo/registry/index/
~/.cargo/registry/cache/
~/.cargo/git/db/
~/.cargo/.crates.toml
~/.cargo/.crates2.json
target/
key: ${{ runner.os }}-cargo
- uses: actions/cache@v3
with:
path: scripts/node_modules
key: ${{ runner.os }}-node_modules-${{ hashFiles('**/package-lock.json') }}
# install dependencies
- uses: extractions/setup-just@v1
- uses: oven-sh/setup-bun@v1
- uses: denoland/setup-deno@v1
with:
deno-version: "~1"
- run: just setup
# build
- name: build
run: just build-${{ matrix.build }}
# bench
- name: check
run: |
case "$name" in
*"python"*|*"ruby"*)
args="--runs 1"
;;
*)
args="--warmup 3"
;;
esac
out="${{ matrix.build }}.json"
hyperfine $args --shell=none --export-json "$out" "$(cat CMD)"
jq '.results[0] | del(.exit_codes)' "$out" | sponge "$out"
timers "$f" >/dev/null 2> >(jq '. += {"max_rss":'$(rg -oP '(?:max_rss:\s*)(\d+)' -r '$1')'}' "$out" | sponge "$out")
# report
- uses: actions/upload-artifact@v3
with:
name: "${{ matrix.build }}.json"
report:
needs: ['run']
runs-on: ubuntu-latest
steps:
- uses: oven-sh/setup-bun@v1
- name: Download Results
uses: actions/download-artifact@v2
with:
path: results
- run: ls -lah .
- run: ls -lah results
# TODO: create report