Split test directory and unit test directory into 2 parameters.

This commit is contained in:
Patrick Lehmann
2022-02-28 17:50:31 +01:00
parent 6c73825f18
commit c997afb2c2
3 changed files with 37 additions and 12 deletions

View File

@@ -35,10 +35,15 @@ on:
required: false required: false
default: '-r tests/requirements.txt' default: '-r tests/requirements.txt'
type: string type: string
unittest_directory: test_directory:
description: 'Path to the directory containing unit tests.' description: 'Path to the directory containing tests (test working directory).'
required: false required: false
default: 'tests/unit' default: 'tests'
type: string
unittest_directory:
description: 'Path to the directory containing unit tests (from test_directory).'
required: false
default: 'unit'
type: string type: string
coverage_config: coverage_config:
description: 'Path to the .coveragerc file. Use pyproject.toml by default.' description: 'Path to the .coveragerc file. Use pyproject.toml by default.'
@@ -117,6 +122,7 @@ jobs:
- name: Collect coverage - name: Collect coverage
continue-on-error: true continue-on-error: true
run: | run: |
cd ${{ inputs.test_directory }}
[ 'x${{ inputs.coverage_config }}' != 'x' ] && PYCOV_ARGS='--cov-config=${{ inputs.coverage_config }}' || unset PYCOV_ARGS [ '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 python -m pytest -rA --cov=. $PYCOV_ARGS ${{ inputs.unittest_directory }} --color=yes

View File

@@ -48,10 +48,15 @@ on:
required: false required: false
default: '' default: ''
type: string type: string
unittest_directory: test_directory:
description: 'Path to the directory containing unit tests.' description: 'Path to the directory containing tests (test working directory).'
required: false required: false
default: 'tests/unit' default: 'tests'
type: string
unittest_directory:
description: 'Path to the directory containing unit tests (from test_directory).'
required: false
default: 'unit'
type: string type: string
artifact: artifact:
description: "Generate unit test report with junitxml and upload results as an artifact." description: "Generate unit test report with junitxml and upload results as an artifact."
@@ -113,20 +118,22 @@ jobs:
- name: ☑ Run unit tests - name: ☑ Run unit tests
if: matrix.system == 'windows' if: matrix.system == 'windows'
run: | run: |
$PYTEST_ARGS = if ("${{ inputs.artifact }}".length -gt 0) { "--junitxml=TestReport.xml" } else { "" } cd ${{ inputs.test_directory }}
$PYTEST_ARGS = if ("${{ inputs.artifact }}".length -gt 0) { "--junitxml=TestReportSummary.xml" } else { "" }
python -m pytest -rA ${{ inputs.unittest_directory }} $PYTEST_ARGS --color=yes python -m pytest -rA ${{ inputs.unittest_directory }} $PYTEST_ARGS --color=yes
- name: ☑ Run unit tests - name: ☑ Run unit tests
if: matrix.system != 'windows' if: matrix.system != 'windows'
run: | run: |
[ 'x${{ inputs.artifact }}' != 'x' ] && PYTEST_ARGS='--junitxml=TestReport.xml' || unset PYTEST_ARGS cd ${{ inputs.test_directory }}
[ 'x${{ inputs.artifact }}' != 'x' ] && PYTEST_ARGS='--junitxml=TestReportSummary.xml' || unset PYTEST_ARGS
python -m pytest -rA ${{ inputs.unittest_directory }} $PYTEST_ARGS --color=yes python -m pytest -rA ${{ inputs.unittest_directory }} $PYTEST_ARGS --color=yes
- name: 📤 Upload 'TestReport.xml' artifact - name: 📤 Upload 'TestReportSummary.xml' artifact
if: inputs.artifact != '' if: inputs.artifact != ''
uses: actions/upload-artifact@v2 uses: actions/upload-artifact@v2
with: with:
name: ${{ inputs.artifact }}-${{ matrix.system }}-${{ matrix.python }} name: ${{ inputs.artifact }}-${{ matrix.system }}-${{ matrix.python }}
path: TestReport.xml path: ${{ inputs.test_directory }}/TestReportSummary.xml
if-no-files-found: error if-no-files-found: error
retention-days: 1 retention-days: 1

View File

@@ -52,7 +52,8 @@ jobs:
python-coverage:p python-coverage:p
python-lxml:p python-lxml:p
mingw_requirements: '-r tests/requirements.mingw.txt' mingw_requirements: '-r tests/requirements.mingw.txt'
unittest_directory: 'tests/unit' test_directory: 'tests'
unittest_directory: 'unit'
artifact: ${{ fromJson(needs.Params.outputs.params).artifacts.unittesting }} artifact: ${{ fromJson(needs.Params.outputs.params).artifacts.unittesting }}
Coverage: Coverage:
@@ -64,6 +65,8 @@ jobs:
# Optional # Optional
python_version: ${{ fromJson(needs.Params.outputs.params).python_version }} python_version: ${{ fromJson(needs.Params.outputs.params).python_version }}
requirements: '-r tests/requirements.txt' requirements: '-r tests/requirements.txt'
test_directory: 'tests'
unittest_directory: 'unit'
secrets: secrets:
codacy_token: ${{ secrets.CODACY_PROJECT_TOKEN }} codacy_token: ${{ secrets.CODACY_PROJECT_TOKEN }}
@@ -164,7 +167,16 @@ jobs:
with: with:
package: ${{ fromJson(needs.Params.outputs.params).artifacts.package }} package: ${{ fromJson(needs.Params.outputs.params).artifacts.package }}
remaining: | remaining: |
${{ fromJson(needs.Params.outputs.params).artifacts.unittesting }}-* ${{ fromJson(needs.Params.outputs.params).artifacts.unittesting }}-ubuntu-3.8
${{ fromJson(needs.Params.outputs.params).artifacts.unittesting }}-ubuntu-3.9
${{ fromJson(needs.Params.outputs.params).artifacts.unittesting }}-ubuntu-3.10
${{ fromJson(needs.Params.outputs.params).artifacts.unittesting }}-windows-3.8
${{ fromJson(needs.Params.outputs.params).artifacts.unittesting }}-windows-3.9
${{ fromJson(needs.Params.outputs.params).artifacts.unittesting }}-windows-3.10
${{ fromJson(needs.Params.outputs.params).artifacts.unittesting }}-msys2-3.9
${{ fromJson(needs.Params.outputs.params).artifacts.unittesting }}-macos-3.8
${{ fromJson(needs.Params.outputs.params).artifacts.unittesting }}-macos-3.9
${{ fromJson(needs.Params.outputs.params).artifacts.unittesting }}-macos-3.10
${{ fromJson(needs.Params.outputs.params).artifacts.coverage }} ${{ fromJson(needs.Params.outputs.params).artifacts.coverage }}
${{ fromJson(needs.Params.outputs.params).artifacts.typing }} ${{ fromJson(needs.Params.outputs.params).artifacts.typing }}
${{ fromJson(needs.Params.outputs.params).artifacts.doc }} ${{ fromJson(needs.Params.outputs.params).artifacts.doc }}