feat: example 5 #19
This file contains hidden or 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
| name: cocotb_unit_test | |
| on: [push, workflow_dispatch] | |
| jobs: | |
| test: | |
| runs-on: ubuntu-24.04 | |
| steps: | |
| - name: Checkout repository | |
| uses: actions/checkout@v4 | |
| with: | |
| submodules: recursive | |
| - name: Install iverilog | |
| shell: bash | |
| run: sudo apt-get update && sudo apt-get install -y iverilog | |
| - name: Setup python | |
| uses: actions/setup-python@v5 | |
| with: | |
| python-version: '3.10' | |
| - name: Install cocotb | |
| run: pip install cocotb | |
| - name: Run cocotb unit test [ex01_and_gate] | |
| run: | | |
| cd ex01_and_gate/test | |
| make | |
| ! grep failure results.xml | |
| cd ../.. | |
| - name: Run cocotb unit test [ex01_and_gate_better] | |
| run: | | |
| cd ex01_and_gate/test | |
| make TOPLEVEL=better_and_gate VERILOG_SOURCES=../better_and_gate.v | |
| ! grep failure results.xml | |
| cd ../.. | |
| - name: Run cocotb unit test [ex02_1_bit_full_adder] | |
| run: | | |
| cd ex02_1_bit_full_adder/test | |
| make | |
| ! grep failure results.xml | |
| cd ../.. | |
| - name: Run cocotb unit test [ex02_1_bit_full_adder_better] | |
| run: | | |
| cd ex02_1_bit_full_adder/test | |
| make TOPLEVEL=better_full_adder VERILOG_SOURCES=../better_full_adder.v | |
| ! grep failure results.xml | |
| cd ../.. | |
| - name: Run cocotb unit test [ex03_4_bit_half_adder] | |
| run: | | |
| cd ex03_4_bit_half_adder/test | |
| make | |
| ! grep failure results.xml | |
| cd ../.. | |
| - name: Run cocotb unit test [ex03_4_bit_half_adder_better] | |
| run: | | |
| cd ex03_4_bit_half_adder/test | |
| make TOPLEVEL=better_half_adder_4 VERILOG_SOURCES=../better_half_adder_4.v | |
| ! grep failure results.xml | |
| cd ../.. | |
| - name: Run cocotb unit test [ex04_4_input_multiplexer] | |
| run: | | |
| cd ex04_4_input_multiplexer/test | |
| make | |
| ! grep failure results.xml | |
| cd ../.. | |
| - name: Run cocotb unit test [ex04_4_input_multiplexer_ifelse] | |
| run: | | |
| cd ex04_4_input_multiplexer/test | |
| make TOPLEVEL=mux_4_ifelse VERILOG_SOURCES=../mux_4_ifelse.v | |
| ! grep failure results.xml | |
| cd ../.. | |
| # I decided to remain to use manual not using make all to run sub module | |
| # because it easy to track error module in github workflow | |
| - name: Run cocotb unit test [ex04_4_input_multiplexer_better] | |
| run: | | |
| cd ex04_4_input_multiplexer/test | |
| make TOPLEVEL=better_mux_4 VERILOG_SOURCES=../better_mux_4.v | |
| ! grep failure results.xml | |
| cd ../.. |