Skip to content

Resolves: Exception when an interrupt controller is in a hierarchy (#… #688

Resolves: Exception when an interrupt controller is in a hierarchy (#…

Resolves: Exception when an interrupt controller is in a hierarchy (#… #688

# This workflow will install Python dependencies, run tests and lint with a variety of Python versions
# For more information see: https://help.github.com/actions/language-and-framework-guides/using-python-with-github-actions
name: Python
on:
push:
pull_request:
jobs:
build:
runs-on: ubuntu-latest
strategy:
matrix:
python-version: ['3.8', '3.9', '3.10']
steps:
- uses: actions/checkout@v2
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v2
with:
python-version: ${{ matrix.python-version }}
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install flake8 pytest pyfakefs==4.5.6 pytest-cov pytest-asyncio codecov
# Install required dependencies for pynq since we import it in setup.py
pip install numpy cffi ipython
# Install PYNQ-Utils and PYNQ-Metadata
pip install git+https://github.com/Xilinx/PYNQ-Metadata
pip install git+https://github.com/Xilinx/PYNQ-Utils
if [ -f requirements.txt ]; then pip install -r requirements.txt; fi
- name: Lint with flake8
run: |
# stop the build if there are Python syntax errors or undefined names
flake8 pynq --count --select=E9,F63,F7,F82 --show-source --statistics
# exit-zero treats all errors as warnings. The GitHub editor is 127 chars wide
flake8 pynq --count --exit-zero --max-complexity=10 --max-line-length=127 --statistics
- name: Install PYNQ
run:
pip install -e .
- name: Test with pytest
run: |
pytest --doctest-modules --junitxml=junit/test-results-${{ matrix.python-version }}.xml
- name: Upload pytest test results
uses: actions/upload-artifact@v1
with:
name: pytest-results-${{ matrix.python-version }}
path: junit/test-results-${{ matrix.python-version }}.xml
# Use always() to always run this step to publish test results when there are test failures
if: ${{ always() }}
- name: Upload coverage
uses: codecov/codecov-action@v1
with:
token: ${{ secrets.CODECOV_TOKEN }}