Create, collect and publish junit reports for static typing.

(cherry picked from commit fb8363afdf53d6656fe020dd08f9e91d9da45565)
This commit is contained in:
Patrick Lehmann
2022-02-28 18:28:26 +01:00
parent 0a1d11d24f
commit 2d10c74d2f
4 changed files with 58 additions and 28 deletions

View File

@@ -35,13 +35,13 @@ on:
required: false
default: '-r tests/requirements.txt'
type: string
test_directory:
tests_directory:
description: 'Path to the directory containing tests (test working directory).'
required: false
default: 'tests'
type: string
unittest_directory:
description: 'Path to the directory containing unit tests (relative to test_directory).'
description: 'Path to the directory containing unit tests (relative to tests_directory).'
required: false
default: 'unit'
type: string
@@ -122,16 +122,19 @@ jobs:
- name: Collect coverage
continue-on-error: true
run: |
cd ${{ inputs.test_directory }}
[ 'x${{ inputs.coverage_config }}' != 'x' ] && PYCOV_ARGS='--cov-config=${{ inputs.coverage_config }}' || unset PYCOV_ARGS
python -m pytest -rA --cov=. $PYCOV_ARGS ${{ inputs.unittest_directory }} --color=yes
RELDIR="$(realpath --relative-to=${{ inputs.tests_directory }} .)"
echo $RELDIR
cd ${{ inputs.tests_directory }}
[ 'x${{ inputs.coverage_config }}' != 'x' ] && PYCOV_ARGS="--cov-config=$RELDIR/${{ inputs.coverage_config }}" || unset PYCOV_ARGS
echo python -m pytest -rA --cov=$RELDIR $PYCOV_ARGS ${{ inputs.unittest_directory }} --color=yes
python -m pytest -rA --cov=$RELDIR $PYCOV_ARGS ${{ inputs.unittest_directory }} --color=yes
- name: Convert to cobertura format
run: coverage xml
run: coverage xml --data-file=${{ inputs.tests_directory }}/.coverage
- name: Convert to HTML format
run: |
coverage html -d ${{ steps.getVariables.outputs.coverage_report_html_directory }}
coverage html --data-file=${{ inputs.tests_directory }}/.coverage -d ${{ steps.getVariables.outputs.coverage_report_html_directory }}
rm ${{ steps.getVariables.outputs.coverage_report_html_directory }}/.gitignore
- name: 📤 Upload 'Coverage Report' artifact

View File

@@ -92,11 +92,13 @@ jobs:
params = {
'python_version': pythonVersion,
'artifacts': {
'unittesting': f"{name}-TestReport",
'coverage': f"{name}-Coverage",
'typing': f"{name}-Typing",
'package': f"{name}-Package",
'doc': f"{name}-Documentation",
'unittesting': f"{name}-Unittest-Summary",
'code-coverage': f"{name}-Code-Coverage",
'typing_html': f"{name}-Typing",
'typing_junit': f"{name}-Typing-Summary",
'package': f"{name}-Package",
'doc': f"{name}-Documentation",
'doc-coverage': f"{name}-Documentation-Coverage",
}
}
print(f"::set-output name=params::{params!s}")

View File

@@ -35,19 +35,29 @@ on:
required: false
default: '-r tests/requirements.txt'
type: string
report:
description: 'Directory to upload as an artifact.'
required: false
default: 'htmlmypy'
type: string
commands:
description: 'Commands to run the static type checks.'
required: true
type: string
artifact:
html_report:
description: 'Directory to upload as an artifact.'
required: false
default: 'htmlmypy'
type: string
junit_report:
description: 'junit file to upload as an artifact.'
required: false
default: 'StaticTypingSummary.xml'
type: string
html_artifact:
description: 'Name of the typing artifact.'
required: true
type: string
junit_artifact:
description: 'Name of the typing artifact.'
required: false
default: ''
type: string
jobs:
@@ -73,12 +83,22 @@ jobs:
continue-on-error: true
run: ${{ inputs.commands }}
- name: 📤 Upload 'Static Typing Report' artifact
if: ${{ inputs.artifact != '' }}
- name: 📤 Upload 'Static Typing Report' HTML artifact
if: ${{ inputs.html_artifact != '' }}
continue-on-error: true
uses: actions/upload-artifact@v2
with:
name: ${{ inputs.artifact }}
path: ${{ inputs.report }}
name: ${{ inputs.html_artifact }}
path: ${{ inputs.html_report }}
if-no-files-found: error
retention-days: 1
- name: 📤 Upload 'Static Typing Report' JUnit artifact
if: ${{ inputs.junit_artifact != '' }}
continue-on-error: true
uses: actions/upload-artifact@v2
with:
name: ${{ inputs.junit_artifact }}
path: ${{ inputs.junit_report }}
if-no-files-found: error
retention-days: 1