Skip to content

Lattigo: Add configure-crypto-context pass #4970

Lattigo: Add configure-crypto-context pass

Lattigo: Add configure-crypto-context pass #4970

Workflow file for this run

name: Build and Test
permissions: read-all
on:
push:
branches:
- main
pull_request:
branches:
- main
concurrency:
group: ${{ github.workflow }}-${{ github.head_ref || github.ref }}
cancel-in-progress: true
jobs:
check-cache:
runs-on:
labels: ubuntu-22.04-8core
outputs:
runner: ${{ steps.runner.outputs.runner }}
steps:
- name: Check out repository code
uses: actions/checkout@8e5e7e5ab8b370d6c329ec480221332ada57f0ab # pin@v3
- name: Cache bazel build artifacts
id: cache
uses: actions/cache@1bd1e32a3bdc45362d1e726936510720a7c30a57 # [email protected]
with:
path: |
~/.cache/bazel
key: ${{ runner.os }}-${{ env.ImageVersion }}-bazel-${{ hashFiles('.bazelversion', '.bazelrc', 'WORKSPACE') }}-${{ hashFiles('bazel/import_llvm.bzl') }}
restore-keys: |
${{ runner.os }}-${{ env.ImageVersion }}-bazel-${{ hashFiles('.bazelversion', '.bazelrc', 'WORKSPACE') }}-
lookup-only: true
- name: Select runner
id: runner
env:
CACHE_HIT: ${{ steps.cache.outputs.cache-hit == 'true' }}
run: |
set -euo pipefail
if [[ "${CACHE_HIT}" == "true" ]]; then
echo "runner=ubuntu-22.04-8core" >> "$GITHUB_OUTPUT"
else
echo "runner=ubuntu-22.04-32core" >> "$GITHUB_OUTPUT"
fi
build-and-test:
needs: check-cache
runs-on:
labels: ${{ needs.check-cache.outputs.runner }}
steps:
- name: Check out repository code
uses: actions/checkout@8e5e7e5ab8b370d6c329ec480221332ada57f0ab # pin@v3
with:
key: ${{ runner.os }}-${{ env.ImageVersion }}-bazel-${{ hashFiles('.bazelversion', '.bazelrc', 'WORKSPACE') }}-${{ hashFiles('bazel/import_llvm.bzl') }}
- name: Cache bazel build artifacts
uses: actions/cache@1bd1e32a3bdc45362d1e726936510720a7c30a57 # [email protected]
with:
path: |
~/.cache/bazel
key: ${{ runner.os }}-${{ env.ImageVersion }}-bazel-${{ hashFiles('.bazelversion', '.bazelrc', 'WORKSPACE') }}-${{ hashFiles('bazel/import_llvm.bzl') }}
restore-keys: |
${{ runner.os }}-${{ env.ImageVersion }}-bazel-${{ hashFiles('.bazelversion', '.bazelrc', 'WORKSPACE') }}-
# --noincompatible_strict_action_env is used below to inherit the path
# from the parent process, which is required for the build to be cached
# and reused in the `Test rust codegen targets` step below, as that step
# requires the `PATH` to find the `cargo` binary.
- name: "Run `bazel build`"
run: |
bazel build --noincompatible_strict_action_env -c fastbuild //...
- name: "Run `bazel test`"
run: |
bazel test --noincompatible_strict_action_env -c fastbuild //...
# Tests specifically for the tfhe-rs codegen
- name: rustup toolchain install
uses: dtolnay/rust-toolchain@439cf607258077187679211f12aa6f19af4a0af7 # [email protected]
with:
toolchain: stable
- name: Test rust codegen targets
run: |
bash .github/workflows/run_rust_tests.sh