* add some reader classes to get the configuration * adapt unittests * get config from json or toml file * loop over all config readers to get the configuration * rename config test files * use relative paths for coverage test in vscode * do not throw an error for missing config files * remove obsolete tests * use dotted key notation for pv sub dictonary * log config reading progress * remove create_config_toml.py * remove obsolete tests for the ha_addon * disable mosquitto tests if the server is down * ignore main method for test coverage * increase test coverage * pytest-cov: use relative_files only on github, so coverage will work with vscode locally * remove unneeded imports * add missing test cases * disable branch coverage, cause its not reachable
71 lines
2.6 KiB
YAML
71 lines
2.6 KiB
YAML
# This workflow will install Python dependencies, run tests and lint with a single version of Python
|
|
# For more information see: https://docs.github.com/en/actions/automating-builds-and-tests/building-and-testing-python
|
|
|
|
name: Python application
|
|
|
|
on:
|
|
push:
|
|
branches: [ "main", "dev-*", "*/issue*" ]
|
|
paths-ignore:
|
|
- '**.md' # Do no build on *.md changes
|
|
- '**.yml' # Do no build on *.yml changes
|
|
- '**.yaml' # Do no build on *.yaml changes
|
|
- '**.yuml' # Do no build on *.yuml changes
|
|
- '**.svg' # Do no build on *.svg changes
|
|
- '**.json' # Do no build on *.json changes
|
|
- '**.cfg' # Do no build on *.cfg changes
|
|
- '**.gitignore' # Do no build on *.gitignore changes
|
|
- '**.dockerfile' # Do no build on *.dockerfile changes
|
|
- '**.sh' # Do no build on *.sh changes
|
|
pull_request:
|
|
branches: [ "main", "dev-*" ]
|
|
|
|
permissions:
|
|
contents: read
|
|
pull-requests: read # allows SonarCloud to decorate PRs with analysis results
|
|
|
|
env:
|
|
TZ: "Europe/Berlin"
|
|
SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}
|
|
|
|
jobs:
|
|
build:
|
|
|
|
runs-on: ubuntu-24.04
|
|
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
with:
|
|
fetch-depth: 0 # Shallow clones should be disabled for a better relevancy of analysis
|
|
- name: Set up Python 3.12
|
|
uses: actions/setup-python@v5
|
|
with:
|
|
python-version: "3.12"
|
|
- name: Install dependencies
|
|
run: |
|
|
python -m pip install --upgrade pip
|
|
if [ -f requirements-test.txt ]; then pip install -r requirements-test.txt; fi
|
|
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 . --count --select=E9,F63,F7,F82 --show-source --statistics
|
|
# exit-zero treats all errors as warnings. The GitHub editor is 127 chars wide
|
|
flake8 --exit-zero --ignore=C901,E121,E123,E126,E133,E226,E241,E242,E704,W503,W504,W505 --format=pylint --output-file=output_flake.txt --exclude=*.pyc app/src/
|
|
- name: Test with pytest
|
|
run: |
|
|
python -m pytest app --cov=app/src --cov-config=.cover_ghaction_rc --cov-report=xml
|
|
coverage report
|
|
- name: Analyze with SonarCloud
|
|
if: ${{ env.SONAR_TOKEN != 0 }}
|
|
uses: SonarSource/sonarqube-scan-action@v4
|
|
env:
|
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
with:
|
|
projectBaseDir: .
|
|
args:
|
|
-Dsonar.projectKey=s-allius_tsun-gen3-proxy
|
|
-Dsonar.python.coverage.reportPaths=coverage.xml
|
|
-Dsonar.python.flake8.reportPaths=output_flake.txt
|
|
# -Dsonar.docker.hadolint.reportPaths=
|
|
|