ci(docker-build): add python layer #696
Workflow file for this run
This file contains 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
--- | |
# | |
# .github/workflows/python.yml | |
# | |
name: Python Workflow | |
on: # yamllint disable-line rule:truthy | |
pull_request: | |
defaults: | |
run: | |
shell: bash | |
jobs: | |
stage1: | |
name: Change Check | |
runs-on: ubuntu-latest | |
outputs: | |
docs_changed: ${{ steps.check_file_changed.outputs.docs_changed }} | |
steps: | |
- name: Checkout Repo | |
id: checkout-repo | |
uses: actions/checkout@v3 | |
with: | |
fetch-depth: 0 | |
ref: ${{ github.ref }} | |
submodules: recursive | |
- name: Get Change List | |
id: check_file_changed | |
run: | | |
# Diff HEAD with the previous commit then output to stdout. | |
printf "=== Which files changed? ===\n" | |
GIT_DIFF="$(git diff --name-only HEAD^ HEAD)" | |
printf "%s\n" "${GIT_DIFF}" | |
printf "\n" | |
# Check if the files are present in the changed file list (added, modified, deleted) then output to stdout. | |
HAS_DIFF=false | |
printf "=== Which Python files changed? ===\n" | |
if printf "%s\n" "${GIT_DIFF}" | grep -E '^(python/.*[.]py|.github/workflows/python.yml)'; then | |
HAS_DIFF=true | |
fi | |
printf "\n" | |
# Did Python files change? | |
printf "=== Did Python files change? ===\n" | |
printf "%s\n" "${HAS_DIFF}" | |
printf "\n" | |
# Set the output named "docs_changed" | |
printf "%s=%s\n" "docs_changed" "${HAS_DIFF}" >> "${GITHUB_OUTPUT}" | |
stage2: | |
name: Python Checks | |
strategy: | |
matrix: | |
python-version: ['3.10', '3.11'] | |
os: [ubuntu-latest] | |
runs-on: ${{ matrix.os }} | |
needs: [stage1] | |
if: needs.stage1.outputs.docs_changed == 'True' | |
steps: | |
- name: Checkout Repo | |
id: checkout-repo | |
uses: actions/checkout@v3 | |
- name: Set up Python ${{ matrix.python-version }} | |
id: setup-python | |
uses: actions/setup-python@v3 | |
with: | |
python-version: ${{ matrix.python-version }} | |
- name: Show Python version | |
id: python-version | |
run: | | |
python --version | |
- name: Install Python Tools | |
id: install-python-tools | |
run: | | |
python -m pip install --upgrade pip | |
- name: CD to Python Dir | |
id: cd-to-python-dir | |
run: | | |
pwd | |
ls | |
cd ./python | |
pwd | |
ls | |
- name: Analysing the code with pylint | |
id: pylint | |
run: | | |
pip install --upgrade pylint | |
cd ./python | |
./for_each pylint --ignore-patterns '(__init__|.*_test).py' . | |
- name: Analysing the code with ruff | |
id: ruff | |
run: | | |
pip install --upgrade ruff | |
cd ./python | |
./for_each ruff check --ignore E501 --exclude ./*_test.py . | |
- name: Analysing the code with pyright | |
id: pyright | |
run: | | |
pip install --upgrade pyright | |
cd ./python | |
./for_each pyright --stats . || true | |
- name: Analysing the code with bandit | |
id: bandit | |
run: | | |
pip install --upgrade bandit[toml] | |
cd ./python | |
./for_each bandit --verbose --recursive -n 3 . || true | |
- name: Testing with pytest | |
id: pytest-test-run | |
run: |- | |
sudo apt install libsqlite3-dev | |
pip install --upgrade db-sqlite3 pysqlite3 | |
pip install --upgrade pytest coverage pytest-cov | |
cd ./python | |
PYTHONPATH="." ./for_each pytest --verbose --cov=. --cov-branch --cov-report={term-missing,xml:.coverage.xml} |