# Copyright (C) 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 # # https://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: Pipeline on: workflow_call: jobs: License-check: name: Check license headers runs-on: ubuntu-latest steps: - uses: actions/checkout@v3 with: submodules: recursive - name: Check Licenses uses: SymbiFlow/actions/checks@main Docs: runs-on: ubuntu-latest name: '📓 Docs' steps: - name: 🧰 Checkout uses: actions/checkout@v3 with: submodules: recursive - name: 🛠️ Setup environment run: | sudo apt update -qq sudo apt install -y make make -C docs env - name: 📓 Build the documentation run: | . ./docs/env/conda/bin/activate f4pga-docs make -C docs html - name: '📤 Upload artifact: Sphinx HTML' uses: actions/upload-artifact@v3 with: name: Documentation-HTML path: docs/_build/html - name: 🚀 Publish site to GitHub Pages if: github.event_name != 'pull_request' run: | cd docs/_build/html touch .nojekyll git init cp ../../../.git/config ./.git/config git add . git config --local user.email "BuildTheDocs@GitHubActions" git config --local user.name "GitHub Actions" git commit -a -m "update ${{ github.sha }}" git push -u origin +HEAD:gh-pages Deprecated: runs-on: ubuntu-latest strategy: fail-fast: false matrix: include: - { fam: xc7, example: counter_test } - { fam: eos-s3, example: btn_counter } name: '🚦 Example (deprecated sh) | ${{ matrix.fam }}' env: F4PGA_INSTALL_DIR: /opt/f4pga F4PGA_FAM: ${{ matrix.fam }} steps: - name: 🧰 Checkout uses: actions/checkout@v3 - name: 🔧 Prepare environment run: ./.github/scripts/prepare_environment.sh - name: 🐍 Install f4pga (pip) run: | . ./.github/scripts/activate.sh cd f4pga pip install . cd .. - name: 🚧 Test f4pga-env run: | . ./.github/scripts/activate.sh echo "F4PGA_ENV_BIN=$(f4pga-env bin)" >> "$GITHUB_ENV" echo "F4PGA_ENV_SHARE=$(f4pga-env share)" >> "$GITHUB_ENV" - name: 🚧 Test make example run: | . ./.github/scripts/activate.sh export VPRPATH=$(f4pga-env bin) cd f4pga-examples cd ${{ matrix.fam }} case '${{ matrix.fam }}' in xc7) TARGET="arty_35" make -C counter_test;; eos-s3) make -C btn_counter;; esac - name: '📤 Upload artifact: Arty 35 bitstream' if: matrix.fam == 'xc7' uses: actions/upload-artifact@v3 with: name: arty_35-Bitstream path: f4pga-examples/xc7/counter_test/build/arty_35/top.bit if-no-files-found: error - name: '📤 Upload artifact: QuickLogic bitstream' if: matrix.fam == 'eos-s3' uses: actions/upload-artifact@v3 with: name: eos-s3-Bitstream path: f4pga-examples/eos-s3/btn_counter/build/top.bit if-no-files-found: error pyF4PGA: runs-on: ubuntu-latest name: '🐍 Example | xc7' env: F4PGA_INSTALL_DIR: /opt/f4pga F4PGA_FAM: xc7 steps: - name: 🧰 Checkout uses: actions/checkout@v3 # with: # submodules: recursive - name: 🔧 Prepare environment run: ./.github/scripts/prepare_environment.sh - name: 🐍 Install f4pga (pip) run: | . ./.github/scripts/activate.sh cd f4pga pip install --use-feature=in-tree-build . cd .. - name: 🚧 Test f4pga build run: | . ./.github/scripts/activate.sh cd f4pga-examples f4pga build --flow ../.github/sftest.json - name: '📤 Upload artifact: Arty 35 bitstream' uses: actions/upload-artifact@v3 with: name: arty_35-Bitstream-pyF4PGA path: f4pga-examples/build/arty_35/top.bit PYTHONPATH: runs-on: ubuntu-latest name: '🐍 PYTHONPATH' env: F4PGA_INSTALL_DIR: /opt/f4pga F4PGA_FAM: xc7 steps: - name: 🧰 Checkout uses: actions/checkout@v3 - name: 🚧 Test pyF4PGA (PYTHONPATH) run: | PYTHONPATH=$(pwd) python3 f4pga/__init__.py PYTHONPATH=$(pwd) python3 f4pga/__init__.py -h Tests: runs-on: ubuntu-latest name: '🐍 Python wrappers' env: F4PGA_INSTALL_DIR: /opt/f4pga F4PGA_FAM: xc7 steps: - name: 🧰 Checkout uses: actions/checkout@v3 - name: 🔧 Prepare environment run: ./.github/scripts/prepare_environment.sh - name: 🐍 Install f4pga (pip) run: | . ./.github/scripts/activate.sh cd f4pga pip install --use-feature=in-tree-build . cd .. - name: 🚦 Test Python wrappers run: | . ./.github/scripts/activate.sh pip3 install -r ./test/requirements.txt pytest --verbose --capture=no -rA --color=yes test/