name: 'test' on: push: pull_request: schedule: - cron: '0 0 * * 5' workflow_dispatch: jobs: build: runs-on: ubuntu-latest strategy: fail-fast: false matrix: backend: - llvm - gcc container: ghdl/vunit:${{ matrix.backend }} steps: - uses: actions/checkout@v2 - run: make GNATMAKE='gnatmake -j'$(nproc) py: needs: [build] runs-on: ubuntu-latest container: ghdl/vunit:llvm steps: - uses: actions/checkout@v2 - run: | apt update apt install -y python3-pexpect make -j$(nproc) test_micropython test_micropython_long test: needs: [build] strategy: fail-fast: false max-parallel: 3 matrix: task: [ "tests_console", "{1..99}", "{100..199}", "{200..299}", "{300..399}", "{400..499}", "{500..599}", "{600..699}", "{700..799}", "{800..899}", "{900..999}", ] runs-on: ubuntu-latest container: ghdl/vunit:llvm steps: - uses: actions/checkout@v2 - run: bash -c "make -j$(nproc) ${{ matrix.task }}" VUnit: needs: [build] runs-on: ubuntu-latest steps: - uses: actions/checkout@v2 - run: make git.vhdl - uses: docker://ghdl/vunit:llvm with: args: python3 ./run.py -p10 symbiflow: strategy: fail-fast: false max-parallel: 2 matrix: task: [ ECP5-EVN, ORANGE-CRAB, ORANGE-CRAB-0.21 ] runs-on: ubuntu-latest env: DOCKER: 1 FPGA_TARGET: ${{matrix.task}} steps: - uses: actions/checkout@v2 - run: make microwatt.json - run: make microwatt.bit - run: make microwatt.svf - uses: actions/upload-artifact@v4 with: name: ${{matrix.task}}-bitstream path: microwatt.svf # test building verilog target from yosys/nextpnr verilog: runs-on: ubuntu-latest steps: - uses: actions/checkout@v2 - run: make DOCKER=1 microwatt.v verilator: runs-on: ubuntu-latest env: DOCKER: 1 FPGA_TARGET: verilator RAM_INIT_FILE: micropython/firmware.hex MEMORY_SIZE: 524288 steps: - uses: actions/checkout@v2 - run: | sudo apt update sudo apt install -y python3-pexpect make -j$(nproc) test_micropython_verilator test_micropython_verilator_long