Skip to content

Commit

Permalink
Hoist CI components into reusable actions and workflows (#122)
Browse files Browse the repository at this point in the history
* Hoist functional tests into composite action

Signed-off-by: Hanno Becker <[email protected]>

* Hoist benchmarking into reusable job

Signed-off-by: Hanno Becker <[email protected]>

* Hoist CI components into reusable workflows

Signed-off-by: Hanno Becker <[email protected]>

* Add triggerable workflow for CI on EC2

Fixes #118

Signed-off-by: Hanno Becker <[email protected]>

* Move reusable workflows into actions

Signed-off-by: Hanno Becker <[email protected]>

* Reduce nix output

Signed-off-by: Hanno Becker <[email protected]>

* Address review feedback

Signed-off-by: Hanno Becker <[email protected]>

---------

Signed-off-by: Hanno Becker <[email protected]>
  • Loading branch information
hanno-becker authored Sep 11, 2024
1 parent bc53aaf commit e3d21eb
Show file tree
Hide file tree
Showing 12 changed files with 396 additions and 155 deletions.
58 changes: 40 additions & 18 deletions .github/actions/bench/action.yml
Original file line number Diff line number Diff line change
Expand Up @@ -32,24 +32,46 @@ inputs:
gh_token:
description: GitHub access token
required: true
use-nix:
description: Whether to run in the default Nix environment
default: true
custom_shell:
description: The shell to use. Only relevant if use-nix is 'false'
default: 'bash'
runs:
using: composite
steps:
- name: Run benchmark
shell: nix develop .#ci -c bash -e {0}
run: |
tests bench -c ${{ inputs.perf }} --cflags "${{ inputs.cflags }}" --arch-flags "${{ inputs.archflags }}" -v --output output.json ${{ inputs.bench_extra_args }}
- name: Dump benchmark
shell: bash
if: ${{ inputs.store_results != 'true' }}
run: |
cat output.json
- name: Store benchmark result
if: ${{ inputs.store_results == 'true' }}
uses: benchmark-action/github-action-benchmark@v1
with:
name: ${{ inputs.name }}
tool: 'customSmallerIsBetter'
output-file-path: output.json
github-token: ${{ inputs.gh_token }}
auto-push: true
- name: Setup nix
if: ${{ inputs.use-nix }}
uses: ./.github/actions/setup-nix
with:
devShell: ci
script: |
ARCH=$(uname -m)
cat >> $GITHUB_STEP_SUMMARY <<-EOF
## Setup
Architecture: $ARCH
- $(uname -a)
- $(nix --version)
- $(${{ matrix.target.cross_prefix }}gcc --version | grep -m1 "")
- $(bash --version | grep -m1 "")
## CPU Info
$(cat /proc/cpuinfo)
EOF
- name: Set shell
shell: bash
run: echo SHELL="${{ inputs.use-nix && 'nix develop .#ci -c bash -e {0}' || inputs.custom_shell }}" >> $GITHUB_ENV
- name: Run benchmark
shell: ${{ env.SHELL }}
run: |
tests bench -c ${{ inputs.perf }} --cflags "${{ inputs.cflags }}" --arch-flags "${{ inputs.archflags }}" -v --output output.json ${{ inputs.bench_extra_args }}
- name: Store benchmark result
if: ${{ inputs.store_results == 'true' }}
uses: benchmark-action/github-action-benchmark@v1
with:
name: ${{ inputs.name }}
tool: 'customSmallerIsBetter'
output-file-path: output.json
github-token: ${{ inputs.gh_token }}
auto-push: true
47 changes: 47 additions & 0 deletions .github/actions/cbmc/action.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
# SPDX-License-Identifier: Apache-2.0

name: CBMC
description: Run CBMC proofs for MLKEM-C_AArch64

inputs:
use-nix:
description: Whether to run in the default Nix environment
default: true
custom_shell:
description: The shell to use. Only relevant if use-nix is 'false'
default: 'bash'
cross-prefix:
description: Binary prefix for cross compilation
default: ''
runs:
using: composite
steps:
- uses: actions/checkout@v4
- name: Setup nix
if: ${{ inputs.use-nix }}
uses: ./.github/actions/setup-nix
with:
devShell: ci-cbmc
script: |
cat >> $GITHUB_STEP_SUMMARY << EOF
## Setup
Architecture: $(uname -m)
- $(nix --version)
- $(cbmc --version)
- litani Version $(litani --version)
- Cadical Version $(cadical --version)
- $(${{ inputs.cross_prefix }}gcc --version | grep -m1 "")
- $(bash --version | grep -m1 "")
EOF
- name: Set shell
shell: bash
run: echo SHELL="${{ inputs.use-nix && 'nix develop .#ci-cbmc -c bash -e {0}' || inputs.custom_shell }}" >> $GITHUB_ENV
- name: Run CBMC proofs
shell: ${{ env.SHELL }}
run: |
cd cbmc/proofs;
echo "::group::cbmc"
KYBER_K=2 ./run-cbmc-proofs.py --summarize;
KYBER_K=3 ./run-cbmc-proofs.py --summarize;
KYBER_K=4 ./run-cbmc-proofs.py --summarize;
echo "::endgroup::"
64 changes: 64 additions & 0 deletions .github/actions/functest/action.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,64 @@
# SPDX-License-Identifier: Apache-2.0

name: Functional tests
description: Run functional tests for MLKEM-C_AArch64

inputs:
use-nix:
description: Whether to run in the default Nix environment
default: true
cflags:
description: CFLAGS to pass to compilation
default: ''
cross-prefix:
description: Binary prefix for cross compilation
default: ''
runs:
using: composite
steps:
- name: Setup nix
uses: ./.github/actions/setup-nix
if: ${{ inputs.use-nix }}
with:
devShell: ci
script: |
ARCH=$(uname -m)
cat >> $GITHUB_STEP_SUMMARY <<-EOF
## Setup
Architecture: $ARCH
- $(uname -a)
- $(nix --version)
- $(${{ inputs.cross-prefix }}gcc --version | grep -m1 "")
- $(bash --version | grep -m1 "")
EOF
- name: Set shell
shell: bash
run: echo SHELL="${{ inputs.use-nix && 'nix develop .#ci -c bash -e {0}' || inputs.custom_shell }}" >> $GITHUB_ENV
- name: Run functional tests
id: func_test
shell: ${{ env.SHELL }}
run: |
echo "::group::func_test"
tests func --cross-prefix=${{ inputs.cross-prefix }} --cflags ${{ inputs.cflags }} -v
echo "::endgroup::"
- name: Run KAT tests
if: |
success()
|| steps.func_test.conclusion == 'failure'
id: kat_test
shell: ${{ env.SHELL }}
run: |
echo "::group::func_test"
tests kat --cross-prefix=${{ inputs.cross-prefix }} --cflags ${{ inputs.cflags }} -v
echo "::endgroup::"
- name: Run Nistkat tests
id: nistkat_test
if: |
success()
|| steps.func_test.conclusion == 'failure'
|| steps.kat_test.conclusion == 'failure'
shell: ${{ env.SHELL }}
run: |
echo "::group::func_test"
tests nistkat --cross-prefix=${{ inputs.cross-prefix }} --cflags ${{ inputs.cflags }} -v
echo "::endgroup::"
41 changes: 41 additions & 0 deletions .github/actions/lint/action.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
# SPDX-License-Identifier: Apache-2.0

name: Lint
description: Lint MLKEM-C_AArch64

inputs:
use-nix:
description: Whether to run in the default Nix environment
default: true
custom_shell:
description: The shell to use. Only relevant if use-nix is 'false'
default: 'bash'
cross-prefix:
description: Binary prefix for cross compilation
default: ''
runs:
using: composite
steps:
- name: Setup nix
if: ${{ inputs.use-nix }}
uses: ./.github/actions/setup-nix
with:
devShell: ci-linter
script: |
cat >> $GITHUB_STEP_SUMMARY << EOF
## Setup
Architecture: $(uname -m)
- $(uname -a)
- $(nix --version)
- $(astyle --version)
- $(${{ matrix.target.cross-prefix }}gcc --version | grep -m1 "")
- $(bash --version | grep -m1 "")
EOF
- name: Set shell
shell: bash
run: echo SHELL="${{ inputs.use-nix && 'nix develop .#ci-linter -c bash -e {0}' || inputs.custom_shell }}" >> $GITHUB_ENV
- name: Run linter
shell: ${{ env.SHELL }}
run: |
echo "## Lint & Checks" >> $GITHUB_STEP_SUMMARY
lint
4 changes: 2 additions & 2 deletions .github/actions/setup-nix/action.yml
Original file line number Diff line number Diff line change
Expand Up @@ -17,10 +17,10 @@ runs:
- uses: DeterminateSystems/nix-installer-action@v13
- uses: DeterminateSystems/magic-nix-cache-action@v7
- name: Prepare nix dev shell
shell: nix develop .#${{ inputs.devShell }} -c bash -e {0}
shell: nix develop --quiet .#${{ inputs.devShell }} -c bash -e {0}
run: |
- name: Dependency check
shell: nix develop .#${{ inputs.devShell }} -c bash -e {0}
shell: nix develop --quiet .#${{ inputs.devShell }} -c bash -e {0}
if: inputs.script != ''
env:
INPUT_SCRIPT: ${{ inputs.script }}
Expand Down
30 changes: 3 additions & 27 deletions .github/workflows/bench.yml
Original file line number Diff line number Diff line change
Expand Up @@ -32,40 +32,16 @@ jobs:
archflags: "-mcpu=cortex-a55 -march=armv8.2-a"
cflags: "-static -DFORCE_AARCH64"
bench_extra_args: -w exec-on-a55
runs-on: self-hosted-${{ matrix.target.system }}
defaults:
run:
shell: nix develop .#ci -c bash -e {0}
permissions:
contents: write
if: github.repository_owner == 'pq-code-package' && (github.event.label.name == 'benchmark' || github.ref == 'refs/heads/main')
runs-on: self-hosted-${{ matrix.target.system }}
steps:
- uses: actions/checkout@v4
- name: Setup nix
uses: ./.github/actions/setup-nix
with:
devShell: ci
script: |
ARCH=$(uname -m)
cat >> $GITHUB_STEP_SUMMARY <<-EOF
## Setup
Architecture: $ARCH
- $(uname -a)
- $(nix --version)
- $(astyle --version)
- $(${{ matrix.target.cross_prefix }}gcc --version | grep -m1 "")
- $(bash --version | grep -m1 "")
## CPU Info
$(cat /proc/cpuinfo)
EOF
- name: Run benchmark
uses: ./.github/actions/bench
- uses: ./.github/actions/bench
with:
name: ${{ matrix.target.name }}
cflags: ${{ matrix.target.cflags }}
archflags: ${{ matrix.target.archflags }}
perf: ${{ matrix.target.bench_pmu }}
store_results: ${{ github.repository_owner == 'pq-code-package' && github.ref == 'refs/heads/main' }}
bench_extra_args: ${{ matrix.target.bench_extra_args }}
gh_token: ${{ secrets.GITHUB_TOKEN }}
gh_token: ${{ secrets.AWS_GITHUB_TOKEN }}
2 changes: 2 additions & 0 deletions .github/workflows/bench_ec2_all.yml
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
# SPDX-License-Identifier: Apache-2.0

name: Bench EC2
on:
workflow_dispatch:
Expand Down
2 changes: 2 additions & 0 deletions .github/workflows/bench_ec2_any.yml
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
# SPDX-License-Identifier: Apache-2.0

name: bench-ec2-any
on:
workflow_dispatch:
Expand Down
26 changes: 5 additions & 21 deletions .github/workflows/bench_ec2_reusable.yml
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
# SPDX-License-Identifier: Apache-2.0

name: bench-ec2-reusable
on:
workflow_call:
Expand Down Expand Up @@ -72,31 +74,13 @@ jobs:
security-group-id: sg-0ab2e297196c8c381
bench:
name: Bench ${{ inputs.name }}
runs-on: ${{ needs.start-ec2-runner.outputs.label }}
needs: start-ec2-runner # required to start the main job when the runner is ready
runs-on: ${{ needs.start-ec2-runner.outputs.label }} # run the job on the newly created runner
steps:
- uses: actions/checkout@v4
- name: Setup nix
uses: ./.github/actions/setup-nix
with:
devShell: ci
script: |
ARCH=$(uname -m)
cat >> $GITHUB_STEP_SUMMARY <<-EOF
## Setup
Architecture: $ARCH
- $(uname -a)
- $(nix --version)
- $(astyle --version)
- $(${{ matrix.target.cross_prefix }}gcc --version | grep -m1 "")
- $(bash --version | grep -m1 "")
## CPU Info
$(cat /proc/cpuinfo)
EOF
- name: Run benchmark
uses: ./.github/actions/bench
- uses: ./.github/actions/bench
with:
use-nix: true
name: ${{ inputs.name }}
cflags: ${{ inputs.cflags }}
archflags: ${{ inputs.archflags }}
Expand Down
Loading

0 comments on commit e3d21eb

Please sign in to comment.