Skip to content

ci: add functional tests #4

ci: add functional tests

ci: add functional tests #4

Workflow file for this run

##
# Copyright 2023,2024 Cesar Fuguet
#
# SPDX-License-Identifier: Apache-2.0 WITH SHL-2.1
#
# Licensed under the Solderpad Hardware License v 2.1 (the “License”); you
# may not use this file except in compliance with the License, or, at your
# option, the Apache License version 2.0. You may obtain a copy of the
# License at
#
# https://solderpad.org/licenses/SHL-2.1/
#
# Unless required by applicable law or agreed to in writing, any work
# distributed under the License is distributed on an “AS IS” BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
##
##
# Author : Cesar Fuguet
# Date : October, 2024
# Description: GitHub Action to run tests on pull requests and pushes
##
name: HPDcache Test CI
on: [push, pull_request]
jobs:
# Install tools required to run the tests
build-env:
name: build-env
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@master
# Install Dependencies
- name: Install Dependencies
run: |
./.github/scripts/install_deps_ubuntu.sh
# Install SystemC
- name: Cache SystemC
id: cache-systemc
uses: actions/cache@v3
with:
path: build/systemc-3.0.1
key: ${{ runner.os }}-build-systemc-${{ hashFiles('.github/scripts/install_systemc.sh') }}
- name: Install SystemC
run: |
. .github/scripts/env.sh
./.github/scripts/install_systemc.sh
# Install Verilator
- name: Cache Verilator
id: cache-verilator
uses: actions/cache@v3
with:
path: build/verilator-v5.028
key: ${{ runner.os }}-build-verilator-${{ hashFiles('.github/scripts/install_verilator.sh') }}
- name: Install Verilator
run: |
. .github/scripts/env.sh
./.github/scripts/install_verilator.sh
# Run the tests
run-tests:
name: run-tests
runs-on: ubuntu-latest
needs: build-env
steps:
- name: Build SystemC testbench
run: |
. .github/scripts/env.sh
cd rtl/tb
make build -j${PARALLEL_JOBS}
- name: Run the random test sequence (short)
run: |
. .github/scripts/env.sh
cd rtl/tb
make nonregression SEQUENCE=random NTESTS=128 NTRANSACTIONS=5000
- name: Run the random test sequence (long)
run: |
. .github/scripts/env.sh
cd rtl/tb
make nonregression SEQUENCE=random NTESTS=32 NTRANSACTIONS=100000
- name: Run the single addr test sequence
run: |
. .github/scripts/env.sh
cd rtl/tb
make nonregression SEQUENCE=single_addr NTESTS=64 NTRANSACTIONS=5000