Nightly #156
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
# Copyright lowRISC contributors (OpenTitan project). | |
# Licensed under the Apache License, Version 2.0, see LICENSE for details. | |
# SPDX-License-Identifier: Apache-2.0 | |
name: Nightly | |
on: | |
schedule: | |
- cron: "00 04 * * *" | |
workflow_dispatch: | |
inputs: | |
branch: | |
description: 'Branch to run the nightly (for SiVal job only)' | |
required: true | |
type: string | |
permissions: | |
id-token: write | |
contents: read | |
env: | |
VIVADO_VERSION: "2021.1" | |
jobs: | |
fpga_cw310_sival_nightly: | |
name: FPGA CW310 SiVal tests | |
runs-on: [ubuntu-22.04-fpga, cw310] | |
env: | |
GS_PATH: opentitan-test-results | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 # Required for the bitstream cache to work. | |
ref: ${{ inputs.branch || 'earlgrey_1.0.0' }} # Schedule only work on the default branch, but we want to run on a different branch. | |
- name: Prepare environment | |
uses: ./.github/actions/prepare-env | |
with: | |
service_account_json: '${{ secrets.BAZEL_CACHE_CREDS }}' | |
- name: Update hyperdebug | |
# We run the update command twice to workaround an issue with udev on the container. | |
# Where rusb cannot dynamically update its device list in CI (udev is not completely | |
# functional). If the device is in normal mode, the first thing that opentitantool | |
# does is to switch it to DFU mode and wait until it reconnects. This reconnection is | |
# never detected. But if we run the tool another time, the device list is queried again | |
# and opentitantool can finish the update. The device will now reboot in normal mode | |
# and work for the hyperdebug job. | |
run: | | |
./bazelisk.sh run //sw/host/opentitantool -- --interface=hyperdebug_dfu transport update-firmware \ | |
|| ./bazelisk.sh run //sw/host/opentitantool -- --interface=hyperdebug_dfu transport update-firmware | |
- name: Run tests after ROM boot stage | |
if: success() || failure() | |
run: | | |
module load xilinx/vivado | |
bazel_tests="$(mktemp)" | |
./bazelisk.sh query 'attr("tags", "[\[ ]cw310_sival[,\]]", tests(//sw/device/...))' \ | |
| grep -v examples \ | |
| grep -v penetrationtests \ | |
> "$bazel_tests" | |
./bazelisk.sh test \ | |
--build_tests_only \ | |
--cache_test_results=no \ | |
--test_tag_filters=-slow_test \ | |
--target_pattern_file="$bazel_tests" | |
- name: Run tests after ROM_EXT boot stage | |
if: success() || failure() | |
run: | | |
module load xilinx/vivado | |
bazel_tests="$(mktemp)" | |
./bazelisk.sh query 'attr("tags", "[\[ ]cw310_sival_rom_ext[,\]]", tests(//sw/device/...))' \ | |
| grep -v examples \ | |
| grep -v penetrationtests \ | |
> "$bazel_tests" | |
./bazelisk.sh test \ | |
--build_tests_only \ | |
--cache_test_results=no \ | |
--test_tag_filters=-slow_test \ | |
--target_pattern_file="$bazel_tests" | |
- name: Compute bucket destination | |
id: bucket_destination | |
if: ${{ !cancelled() }} | |
run: | | |
BUCKET_PATH=$GS_PATH/job/${{ github.job }}/branch/${{ inputs.branch || 'earlgrey_1.0.0'}}/$(date +%Y-%m-%d-%H%M%S)_test_results.xml | |
echo "BUCKET_PATH=$BUCKET_PATH" >> $GITHUB_OUTPUT | |
- name: Publish Bazel test results | |
uses: ./.github/actions/publish-bazel-test-results | |
if: ${{ !cancelled() }} | |
with: | |
artifact-name: fpga_cw310_sival_nightly-test-results | |
bucket-destination: ${{ steps.bucket_destination.outputs.BUCKET_PATH }} | |
fpga_cw340_sival_nightly: | |
name: FPGA CW340 SiVal tests | |
runs-on: [ubuntu-22.04-fpga, cw340] | |
env: | |
GS_PATH: opentitan-test-results | |
BAZEL_TEST_RESULTS: test_results.xml | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 # Required for the bitstream cache to work. | |
ref: ${{ inputs.branch || 'earlgrey_1.0.0' }} # Schedule only work on the default branch, but we want to run on a different branch. | |
- name: Prepare environment | |
uses: ./.github/actions/prepare-env | |
with: | |
service_account_json: '${{ secrets.BAZEL_CACHE_CREDS }}' | |
- name: Update hyperdebug | |
# We run the update command twice to workaround an issue with udev on the container. | |
# Where rusb cannot dynamically update its device list in CI (udev is not completely | |
# functional). If the device is in normal mode, the first thing that opentitantool | |
# does is to switch it to DFU mode and wait until it reconnects. This reconnection is | |
# never detected. But if we run the tool another time, the device list is queried again | |
# and opentitantool can finish the update. The device will now reboot in normal mode | |
# and work for the hyperdebug job. | |
run: | | |
./bazelisk.sh run //sw/host/opentitantool -- --interface=hyperdebug_dfu transport update-firmware \ | |
|| ./bazelisk.sh run //sw/host/opentitantool -- --interface=hyperdebug_dfu transport update-firmware | |
- name: Run tests after ROM boot stage | |
if: success() || failure() | |
run: | | |
module load xilinx/vivado | |
bazel_tests="$(mktemp)" | |
./bazelisk.sh query 'attr("tags", "[\[ ]cw340_sival[,\]]", tests(//sw/device/...))' \ | |
| grep -v examples \ | |
| grep -v penetrationtests \ | |
> "$bazel_tests" | |
./bazelisk.sh test \ | |
--build_tests_only \ | |
--cache_test_results=no \ | |
--test_tag_filters=-slow_test \ | |
--target_pattern_file="$bazel_tests" | |
- name: Run tests after ROM_EXT boot stage | |
if: success() || failure() | |
run: | | |
module load xilinx/vivado | |
bazel_tests="$(mktemp)" | |
./bazelisk.sh query 'attr("tags", "[\[ ]cw340_sival_rom_ext[,\]]", tests(//sw/device/...))' \ | |
| grep -v examples \ | |
| grep -v penetrationtests \ | |
> "$bazel_tests" | |
./bazelisk.sh test \ | |
--build_tests_only \ | |
--cache_test_results=no \ | |
--test_tag_filters=-slow_test \ | |
--target_pattern_file="$bazel_tests" | |
- name: Compute bucket destination | |
id: bucket_destination | |
if: ${{ !cancelled() }} | |
run: | | |
BUCKET_PATH=$GS_PATH/job/${{ github.job }}/branch/${{ inputs.branch || 'earlgrey_1.0.0'}}/$(date +%Y-%m-%d-%H%M%S)_test_results.xml | |
echo "BUCKET_PATH=$BUCKET_PATH" >> $GITHUB_OUTPUT | |
- name: Publish Bazel test results | |
uses: ./.github/actions/publish-bazel-test-results | |
if: ${{ !cancelled() }} | |
with: | |
artifact-name: fpga_cw340_sival_nightly-test-results | |
bucket-destination: ${{ steps.bucket_destination.outputs.BUCKET_PATH }} | |
fpga_cw340_slow_sival_nightly: | |
name: FPGA CW340 slow SiVal tests | |
runs-on: [ubuntu-22.04-fpga, cw340] | |
env: | |
GS_PATH: opentitan-test-results | |
BAZEL_TEST_RESULTS: test_results.xml | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 # Required for the bitstream cache to work. | |
ref: ${{ inputs.branch || 'earlgrey_1.0.0' }} # Schedule only work on the default branch, but we want to run on a different branch. | |
- name: Prepare environment | |
uses: ./.github/actions/prepare-env | |
with: | |
service_account_json: '${{ secrets.BAZEL_CACHE_CREDS }}' | |
- name: Update hyperdebug | |
# We run the update command twice to workaround an issue with udev on the container. | |
# Where rusb cannot dynamically update its device list in CI (udev is not completely | |
# functional). If the device is in normal mode, the first thing that opentitantool | |
# does is to switch it to DFU mode and wait until it reconnects. This reconnection is | |
# never detected. But if we run the tool another time, the device list is queried again | |
# and opentitantool can finish the update. The device will now reboot in normal mode | |
# and work for the hyperdebug job. | |
run: | | |
./bazelisk.sh run //sw/host/opentitantool -- --interface=hyperdebug_dfu transport update-firmware \ | |
|| ./bazelisk.sh run //sw/host/opentitantool -- --interface=hyperdebug_dfu transport update-firmware | |
- name: Run tests | |
if: success() || failure() | |
run: | | |
module load xilinx/vivado | |
bazel_tests="$(mktemp)" | |
./bazelisk.sh query 'attr("tags", "[\[ ]cw340_sival_rom_ext[,\]]", tests(//sw/device/...))' \ | |
'intersect attr("tags", "slow_test", tests(//sw/device/...))' \ | |
| grep -v examples \ | |
| grep -v penetrationtests \ | |
> "$bazel_tests" | |
./bazelisk.sh test \ | |
--build_tests_only \ | |
--cache_test_results=no \ | |
--target_pattern_file="$bazel_tests" | |
- name: Compute bucket destination | |
id: bucket_destination | |
if: ${{ !cancelled() }} | |
run: | | |
BUCKET_PATH=$GS_PATH/job/${{ github.job }}/branch/${{ inputs.branch || 'earlgrey_1.0.0'}}/$(date +%Y-%m-%d-%H%M%S)_test_results.xml | |
echo "BUCKET_PATH=$BUCKET_PATH" >> $GITHUB_OUTPUT | |
- name: Publish Bazel test results | |
uses: ./.github/actions/publish-bazel-test-results | |
if: ${{ !cancelled() }} | |
with: | |
artifact-name: fpga_cw340_slow_sival_nightly-test-results | |
bucket-destination: ${{ steps.bucket_destination.outputs.BUCKET_PATH }} | |
rom_e2e: | |
name: ROM E2E Tests | |
runs-on: [ubuntu-22.04-fpga, cw310] | |
timeout-minutes: 180 | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 # Required for the bitstream cache to work. | |
- name: Prepare environment | |
uses: ./.github/actions/prepare-env | |
with: | |
service_account_json: '${{ secrets.BAZEL_CACHE_CREDS }}' | |
- name: Run all ROM E2E tests | |
run: | | |
module load "xilinx/vivado/${VIVADO_VERSION}" | |
./bazelisk.sh test \ | |
--define DISABLE_VERILATOR_BUILD=true \ | |
--define bitstream=gcp_splice \ | |
--test_tag_filters=-verilator,-dv,-broken \ | |
--build_tests_only \ | |
--cache_test_results=no \ | |
--test_output=errors \ | |
//sw/device/silicon_creator/rom/e2e/... | |
- name: Publish Bazel test results | |
uses: ./.github/actions/publish-bazel-test-results | |
if: ${{ !cancelled() }} | |
with: | |
artifact-name: rom_e2e-test-results | |
slow_otbn_crypto_tests: | |
name: Slow OTBN Crypto Tests | |
runs-on: ubuntu-22.04 | |
timeout-minutes: 180 | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 # Required for the bitstream cache to work. | |
- name: Prepare environment | |
uses: ./.github/actions/prepare-env | |
with: | |
service_account_json: '${{ secrets.BAZEL_CACHE_CREDS }}' | |
- name: Run the tests | |
run: | | |
./bazelisk.sh test \ | |
--cache_test_results=no \ | |
--test_tag_filters=nightly \ | |
//sw/otbn/crypto/... | |
- name: Publish Bazel test results | |
uses: ./.github/actions/publish-bazel-test-results | |
if: ${{ !cancelled() }} | |
with: | |
artifact-name: slow_otbn_crypto_tests-test-results | |
bob_spi_i2c: | |
name: "BoB: SPI and I2C Tests" | |
runs-on: [ubuntu-22.04-fpga, cw310] | |
timeout-minutes: 180 | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 # Required for the bitstream cache to work. | |
- name: Prepare environment | |
uses: ./.github/actions/prepare-env | |
with: | |
service_account_json: '${{ secrets.BAZEL_CACHE_CREDS }}' | |
- name: Run the PMOD tests with Test ROM | |
run: | | |
module load "xilinx/vivado/${VIVADO_VERSION}" | |
./bazelisk.sh test \ | |
--define DISABLE_VERILATOR_BUILD=true \ | |
--define bitstream=gcp_splice \ | |
--build_tests_only \ | |
--cache_test_results=no \ | |
--test_output=errors \ | |
--test_tag_filters="cw310_test_rom" \ | |
$(./bazelisk.sh query 'attr("tags", "[\[ ]pmod[,\]]", tests(//...))') | |
- name: Run the PMOD tests for SiVal | |
run: | | |
module load "xilinx/vivado/${VIVADO_VERSION}" | |
./bazelisk.sh test \ | |
--define DISABLE_VERILATOR_BUILD=true \ | |
--define bitstream=gcp_splice \ | |
--build_tests_only \ | |
--cache_test_results=no \ | |
--test_output=errors \ | |
--test_tag_filters=cw310_sival,-broken \ | |
$(./bazelisk.sh query 'attr("tags", "[\[ ]pmod[,\]]", tests(//...))') | |
- name: Publish Bazel test results | |
uses: ./.github/actions/publish-bazel-test-results | |
if: ${{ !cancelled() }} | |
with: | |
artifact-name: bob_spi_i2c-test-results |