-
Notifications
You must be signed in to change notification settings - Fork 141
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
PR: Reduce test workflow for each PR/commit #1780
Changes from all commits
7e97ade
518fe3f
0975b11
df33623
29a7727
9655633
8f94ad3
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
event_name="$1" | ||
branch_name="$2" | ||
|
||
if [[ "$event_name" == "workflow_dispatch" ]] || [[ "$branch_name" == "master" ]]; then | ||
echo '{ | ||
"python-version": ["3.8", "3.9", "3.10", "3.11"], | ||
"os": ["ubuntu-latest", "macos-latest"], | ||
"borg-version": ["1.2.4"] | ||
}' | jq -c . > matrix-unit.json | ||
|
||
echo '{ | ||
"python-version": ["3.8", "3.9", "3.10", "3.11"], | ||
"os": ["ubuntu-latest", "macos-latest"], | ||
"borg-version": ["1.1.18", "1.2.2", "1.2.4", "2.0.0b5"], | ||
"exclude": [{"borg-version": "2.0.0b5", "python-version": "3.8"}] | ||
}' | jq -c . > matrix-integration.json | ||
|
||
elif [[ "$event_name" == "push" ]] || [[ "$event_name" == "pull_request" ]]; then | ||
echo '{ | ||
"python-version": ["3.8", "3.9", "3.10", "3.11"], | ||
"os": ["ubuntu-latest", "macos-latest"], | ||
"borg-version": ["1.2.4"] | ||
}' | jq -c . > matrix-unit.json | ||
|
||
echo '{ | ||
"python-version": ["3.10"], | ||
"os": ["ubuntu-latest"], | ||
"borg-version": ["1.2.4"] | ||
}' | jq -c . > matrix-integration.json | ||
fi |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -26,16 +26,36 @@ jobs: | |
shell: bash | ||
run: make lint | ||
|
||
prepare-matrix: | ||
runs-on: ubuntu-latest | ||
outputs: | ||
matrix-unit: ${{ steps.set-matrix-unit.outputs.matrix }} | ||
matrix-integration: ${{ steps.set-matrix-integration.outputs.matrix }} | ||
steps: | ||
- uses: actions/checkout@v3 | ||
|
||
- name: Give execute permission to script | ||
run: chmod +x ./.github/scripts/generate-matrix.sh | ||
|
||
- name: Generate matrices | ||
run: | | ||
./.github/scripts/generate-matrix.sh "${{ github.event_name }}" "${GITHUB_REF##refs/heads/}" | ||
|
||
- name: Set matrix for unit tests | ||
id: set-matrix-unit | ||
run: echo "matrix=$(cat matrix-unit.json)" >> $GITHUB_OUTPUT | ||
|
||
- name: Set matrix for integration tests | ||
id: set-matrix-integration | ||
run: echo "matrix=$(cat matrix-integration.json)" >> $GITHUB_OUTPUT | ||
|
||
test-unit: | ||
needs: prepare-matrix | ||
timeout-minutes: 20 | ||
runs-on: ${{ matrix.os }} | ||
strategy: | ||
fail-fast: false | ||
|
||
matrix: | ||
python-version: ["3.8", "3.9", "3.10", "3.11"] | ||
os: [ubuntu-latest, macos-latest] | ||
borg-version: ["1.2.4"] | ||
matrix: ${{fromJson(needs.prepare-matrix.outputs.matrix-unit)}} | ||
|
||
steps: | ||
- uses: actions/checkout@v3 | ||
|
@@ -51,15 +71,15 @@ jobs: | |
|
||
- name: Setup tmate session | ||
uses: mxschmitt/action-tmate@v3 | ||
if: ${{ github.event_name == 'workflow_dispatch' && github.event.inputs.debug_enabled }} | ||
if: ${{ github.event_name == 'workflow_dispatch' && github.event.inputs.debug_enabled == 'true' }} | ||
|
||
- name: Run Unit Tests with pytest (Linux) | ||
if: runner.os == 'Linux' | ||
env: | ||
BORG_VERSION: ${{ matrix.borg-version }} | ||
run: | | ||
xvfb-run --server-args="-screen 0 1024x768x24+32" \ | ||
-a dbus-run-session -- make test-unit | ||
-a dbus-run-session -- make test-unit | ||
|
||
- name: Run Unit Tests with pytest (macOS) | ||
if: runner.os == 'macOS' | ||
|
@@ -78,18 +98,12 @@ jobs: | |
env_vars: OS, python | ||
|
||
test-integration: | ||
needs: prepare-matrix | ||
timeout-minutes: 20 | ||
runs-on: ${{ matrix.os }} | ||
strategy: | ||
fail-fast: false | ||
|
||
matrix: | ||
python-version: ["3.8", "3.9", "3.10", "3.11"] | ||
os: [ubuntu-latest, macos-latest] | ||
borg-version: ["1.1.18", "1.2.2", "1.2.4", "2.0.0b5"] | ||
exclude: | ||
- borg-version: "2.0.0b5" | ||
python-version: "3.8" | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Biggest hurdle I ran into with the integration tests is excluding the combination of Borg 2.0.0b5 with python 3.8. Skipped this for now. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Doesn't adding the exclude to the matrix work? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Unfortunately it does not work with the way I'm dynamically creating the matrix, this only works when the matrix is static I believe. |
||
matrix: ${{fromJson(needs.prepare-matrix.outputs.matrix-integration)}} | ||
|
||
steps: | ||
- uses: actions/checkout@v3 | ||
|
@@ -105,15 +119,15 @@ jobs: | |
|
||
- name: Setup tmate session | ||
uses: mxschmitt/action-tmate@v3 | ||
if: ${{ github.event_name == 'workflow_dispatch' && github.event.inputs.debug_enabled }} | ||
if: ${{ github.event_name == 'workflow_dispatch' && github.event.inputs.debug_enabled == 'true'}} | ||
|
||
- name: Run Integration Tests with pytest (Linux) | ||
if: runner.os == 'Linux' | ||
env: | ||
BORG_VERSION: ${{ matrix.borg-version }} | ||
run: | | ||
xvfb-run --server-args="-screen 0 1024x768x24+32" \ | ||
-a dbus-run-session -- make test-integration | ||
-a dbus-run-session -- make test-integration | ||
|
||
- name: Run Integration Tests with pytest (macOS) | ||
if: runner.os == 'macOS' | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This corrects a serious error I found while testing. Before, the conditional 'debug_enabled' would always evaluate to
True
since the call returns a string which is truthy. This was causing a manual workflow to always be ran in debugging mode, even with debugging disabled.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Another thing I found when running in debug mode is that the tests would always timeout (execution time > 20 minutes). Should we consider raising the execution timeout if debug mode is enabled?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think that's because of the remote shell created. It stops execution and allows you to connect to the box.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Okay, guess the timeout is fine as is then.