| # Copyright 2020-2022 F4PGA Authors |
| # |
| # Licensed under the Apache License, Version 2.0 (the "License"); |
| # you may not use this file except in compliance with the License. |
| # You may obtain a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # 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. |
| # |
| # SPDX-License-Identifier: Apache-2.0 |
| |
| name: CI tests |
| |
| on: [push, pull_request] |
| |
| jobs: |
| |
| Run-tests: |
| runs-on: ubuntu-20.04 |
| |
| strategy: |
| fail-fast: false |
| matrix: |
| plugin: |
| - fasm |
| - xdc |
| - params |
| - sdc |
| - ql-iob |
| - design_introspection |
| - integrateinv |
| - ql-qlf |
| - systemverilog |
| - uhdm |
| - dsp-ff |
| |
| steps: |
| |
| - uses: actions/checkout@v2 |
| with: |
| submodules: recursive |
| |
| - uses: actions/setup-python@v2 |
| |
| - name: Install |
| run: | |
| sudo apt-get update |
| sudo apt-get install git g++-9 build-essential bison flex \ |
| libreadline-dev gawk tcl-dev libffi-dev git graphviz xdot \ |
| pkg-config libboost-system-dev libboost-python-dev \ |
| libboost-filesystem-dev zlib1g-dev clang-format-8 cmake |
| |
| - name: Format |
| run: source .github/workflows/format-check.sh |
| env: |
| OS: ${{ runner.os }} |
| |
| - name: ccache |
| uses: hendrikmuhs/ccache-action@v1 |
| |
| - name: Install Yosys |
| run: | |
| export PATH="/usr/lib/ccache:/usr/local/opt/ccache/libexec:$PATH" |
| source .github/workflows/setup.sh |
| env: |
| OS: ${{ runner.os }} |
| |
| - name: Build and test plugins |
| run: | |
| export PATH="/usr/lib/ccache:/usr/local/opt/ccache/libexec:$PATH" |
| source env/conda/bin/activate yosys-plugins |
| source .github/workflows/build-and-test.sh |
| env: |
| OS: ${{ runner.os }} |
| PLUGIN_NAME: ${{ matrix.plugin }} |