Skip to content
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

Add pytests and CI for simple configuration checks #32

Merged
merged 26 commits into from
Apr 2, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
26 commits
Select commit Hold shift + click to select a range
24a8349
Add pytests for simple configuration checks
jo-basevi Mar 22, 2024
7bb5281
pr-1-ci.yml: Added job for simple ci checks run on the runner, and on…
CodeGat Mar 25, 2024
81b9368
conftest.py: Added in markers for config and highres
CodeGat Mar 25, 2024
44fa032
Add metadata checks to pytests
jo-basevi Mar 25, 2024
eef29bc
Update pytest marker descriptions in conftest.py
jo-basevi Mar 27, 2024
7119fa6
Add test to enforce manifest reproduce exe is on
jo-basevi Mar 27, 2024
061378f
pr-1-ci.yml: Made model-specific checks an optional input
CodeGat Mar 27, 2024
1bf520b
pr-1-ci.yml: Various fixes during review
CodeGat Mar 27, 2024
2da3572
test/conftest.py: Add pytest test marker back in
jo-basevi Mar 27, 2024
4c718c3
README-DEV.md: Added notes on the new jobs and workflows
CodeGat Mar 27, 2024
c429770
pr-1-ci.yml: Simplified branch-check job logic
CodeGat Mar 27, 2024
2ac3c8d
Updated commits done by github-actions[bot] to use the org var
CodeGat Mar 27, 2024
8121664
Update test/test_config.py with review suggestions
jo-basevi Mar 27, 2024
6c8b66e
Update .github/workflows/pr-1-ci.yml
CodeGat Mar 28, 2024
6f9a1c3
Refactor access-om2 specific pytests
jo-basevi Mar 28, 2024
784db81
pr-1-ci.yml: Update markers and directory where tests are run from
jo-basevi Mar 28, 2024
db96ead
Change test dependencies versions (to match payu's condaenv)
jo-basevi Mar 28, 2024
e644a29
Add target-branch option to pytests - so can infer info from target b…
jo-basevi Mar 28, 2024
3cc43af
pr-2-confirm.yml: Automatic bumping to 1.0 if there is no version in …
CodeGat Mar 28, 2024
c601d98
pr-1-ci.yml: Soft-fail job added that checks if the PR has modified t…
CodeGat Mar 28, 2024
024f6b7
Removed 'metadata.yml' from list of ignored paths in PR
CodeGat Mar 28, 2024
e7096ed
pr-1-ci.yml: Noted in the repro result comments that the version is m…
CodeGat Apr 1, 2024
7e2a764
pr-1-ci.yml: Removed dev-branch focussed repro comments because they …
CodeGat Apr 1, 2024
db7a43b
schedule-2-start.yml: Added correct link to tag
CodeGat Apr 1, 2024
31ed470
pr-1-ci.yml: Gave each Test Results check a distinct name
CodeGat Apr 2, 2024
f787291
Update pytests: Fail access-om2 tests for unknown resolutions and add…
jo-basevi Apr 2, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 0 additions & 1 deletion .github/workflows/call-pr-1-ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,6 @@ on:
- tools/**
- doc/**
- .*
- metadata.yaml
- README.md
jobs:
call:
Expand Down
168 changes: 128 additions & 40 deletions .github/workflows/pr-1-ci.yml
Original file line number Diff line number Diff line change
@@ -1,6 +1,22 @@
name: PR Checks
on:
workflow_call:
inputs:
qa-pytest-markers:
type: string
required: false
default: config
description: List of markers for the pytest QA CI checks
qa-pytest-add-model-markers:
type: boolean
required: false
default: true
description: Whether to run model-specific tests
repro-pytest-markers:
type: string
required: false
default: checksum
description: List of markers for the pytest repro CI checks
# Workflows that call this workflow use the following triggers:
# pull_request:
# branches:
Expand All @@ -12,7 +28,6 @@ on:
# - tools/**
# - doc/**
# - .*
# - metadata.yaml
# - README.md
jobs:
commit-check:
Expand All @@ -35,10 +50,15 @@ jobs:

branch-check:
name: PR Source Branch Check
# This check is used as a precursor to any repro-ci checks - which are only fired
# on dev-* -> release-* PRs.
# This check is run to confirm that the source branch is of the form `dev-<config>`
# and the target branch is of the form `release-<config>`. We are being especially
# concerned with branch names because deployment to GitHub Environments can only
# be done on source branches with a certain pattern. See #20.
# be done on source branches with a certain pattern. See ACCESS-NRI/access-om2-configs#20.
if: needs.commit-check.outputs.authorship != vars.GH_ACTIONS_BOT_GIT_USER_NAME && startsWith(github.base_ref, 'release-') && startsWith(github.head_ref, 'dev-')
needs:
- commit-check
runs-on: ubuntu-latest
permissions:
pull-requests: write
Expand All @@ -47,20 +67,6 @@ jobs:
with:
ref: ${{ github.head_ref }}

- name: Check Source
run: |
if [[ "${{ startsWith(github.head_ref, 'dev-') }}" == "false" ]]; then
echo "::error::Source branch ${{ github.head_ref }} doesn't match 'dev-*'"
exit 1
fi

- name: Check Target
run: |
if [[ "${{ startsWith(github.base_ref, 'release-') }}" == "false" ]]; then
echo "::error::Target branch ${{ github.base_ref }} doesn't match 'release-*'"
exit 1
fi

- name: Compare Source and Target Config Names
# In this step, we cut the 'dev-' and 'release-' to compare config names directly.
run: |
Expand All @@ -77,24 +83,89 @@ jobs:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
GH_REPO: ${{ github.repository }}
BODY: |
:x: Automated testing cannot be run on this branch :x:
:x: Automated Reproducibility testing cannot be run on this branch :x:
Source and Target branches must be of the form `dev-<config>` and `release-<config>` respectively, and `<config>` must match between them.
Rename the Source branch or check the Target branch, and try again.
run: gh pr comment --body '${{ env.BODY }}'

qa-ci:
# Run quick, non-HPC tests on the runner.
name: QA CI Checks
needs:
- commit-check
if: needs.commit-check.outputs.authorship != vars.GH_ACTIONS_BOT_GIT_USER_NAME
runs-on: ubuntu-latest
permissions:
checks: write
steps:
- name: Checkout PR ${{ github.event.action.pull_request.number }}
uses: actions/checkout@v4
with:
ref: ${{ github.head_ref }}
path: pr

- name: Checkout Tests
uses: actions/checkout@v4
with:
ref: main
path: pytest

- name: Setup Python 3.11
uses: actions/setup-python@v5
with:
python-version: 3.11
cache: pip

- name: Install requirements.txt
working-directory: ./pytest
run: pip install -r ./test/requirements.txt

- name: Get Final List of Markers
id: pytest-markers
run: |
aidanheerdegen marked this conversation as resolved.
Show resolved Hide resolved
if [[ ${{ inputs.qa-pytest-add-model-markers }} == "true" ]]; then
echo "markers=${{ inputs.qa-pytest-markers }} or access_om2" >> $GITHUB_OUTPUT
else
echo "markers=${{ inputs.qa-pytest-markers }}" >> $GITHUB_OUTPUT
fi

- name: Invoke Simple CI Pytests
# We continue on error because we will let the checks generated in
# the next step speak to the state of the testing
continue-on-error: true
working-directory: ./pr
run: |
echo "Running pytest using '-m ${{ steps.pytest-markers.outputs.markers }}'"
pytest ../pytest/test \
-m '${{ steps.pytest-markers.outputs.markers }}' \
--target-branch '${{ github.base_ref }}' \
--junitxml=./test_report.xml

- name: Parse Test Report
id: tests
uses: EnricoMi/publish-unit-test-result-action/composite@e780361cd1fc1b1a170624547b3ffda64787d365 #v2.12.0
with:
files: ./pr/test_report.xml
comment_mode: off
check_run: true
check_name: QA Test Results
compare_to_earlier_commit: false
report_individual_runs: true
report_suite_logs: any

repro-ci:
# run the given config on the deployment GitHub Environment (`environment-name`) and
# Run the given config on the deployment GitHub Environment (`environment-name`) and
# upload the checksums and test details
needs:
- commit-check
- branch-check
if: needs.commit-check.outputs.authorship != 'github-actions' && needs.branch-check.result == 'success'
if: needs.commit-check.outputs.authorship != vars.GH_ACTIONS_BOT_GIT_USER_NAME && needs.branch-check.result == 'success'
uses: access-nri/reproducibility/.github/workflows/checks.yml@main
with:
model-name: access-om2
environment-name: Gadi
config-tag: ${{ github.head_ref }}
test-markers: checksum
test-markers: ${{ inputs.repro-pytest-markers }}
secrets: inherit
permissions:
contents: write
Expand Down Expand Up @@ -138,6 +209,7 @@ jobs:
files: ${{ env.TESTING_LOCAL_LOCATION }}/checksum/test_report.xml
comment_mode: off
check_run: true
check_name: Repro Test Results
compare_to_earlier_commit: false
report_individual_runs: true
report_suite_logs: any
Expand All @@ -153,6 +225,38 @@ jobs:
echo "result=pass" >> $GITHUB_OUTPUT
fi

bump-check:
name: Version Bump Check
# Check that the `.version` in the metadata.yaml has been modified in
# this PR.
needs:
- repro-ci
runs-on: ubuntu-latest
steps:
- name: Checkout PR Target
uses: actions/checkout@v4
with:
ref: ${{ github.base_ref }}
path: target

- name: Checkout PR Source
uses: actions/checkout@v4
with:
ref: ${{ github.head_ref }}
path: source

- name: Modification Check
run: |
target=$(yq e '.version' ./target/metadata.yaml)
source=$(yq e '.version' ./source/metadata.yaml)

if [[ "${source}" != "${target}" && "${source}" != "null" ]]; then
echo "::notice::The version has been modified to ${target}. Merging is now availible"
else
echo "::error::The version has not been modified in this PR. Merging is disallowed until an appropriate '!bump' is issued"
exit 1
fi

result:
name: Repro Result Notifier
# Notify the PR of the result of the Repro check
Expand All @@ -171,35 +275,19 @@ jobs:
ref: ${{ github.head_ref }}

- name: Successful Release Comment
if: needs.check-checksum.outputs.result == 'pass' && startsWith(github.base_ref, 'release-')
if: needs.check-checksum.outputs.result == 'pass'
env:
BODY: |
:white_check_mark: The Bitwise Reproducibility check succeeded when comparing against `${{ needs.check-checksum.outputs.compared-checksum-version }}` for this `Release` config. :white_check_mark:
For further information, the experiment can be found on Gadi at ${{ needs.repro-ci.outputs.experiment-location }}, and the test results at ${{ needs.check-checksum.outputs.check-run-url }}.
Consider bumping the minor version of `access-om2-configs` - to bump the version, comment `!bump minor`. The meaning of these version bumps is explained in the README.md, under `Config Tags`.
run: gh pr comment --body '${{ env.BODY }}'

- name: Successful Dev Comment
if: needs.check-checksum.outputs.result == 'pass' && startsWith(github.base_ref, 'dev-')
env:
BODY: |
:white_check_mark: The Bitwise Reproducibility check succeeded when comparing against `${{ needs.check-checksum.outputs.compared-checksum-version }}` for this `Dev` config. :white_check_mark:
For further information, the experiment can be found on Gadi at ${{ needs.repro-ci.outputs.experiment-location }}, and the test results at ${{ needs.check-checksum.outputs.check-run-url }}.
You must bump the minor version of `access-om2-configs` - to bump the version, comment `!bump minor` or modify the `version` in `metadata.yaml`. The meaning of these version bumps is explained in the README.md, under `Config Tags`.
run: gh pr comment --body '${{ env.BODY }}'

- name: Failed Release Comment
if: needs.check-checksum.outputs.result == 'fail' && startsWith(github.base_ref, 'release-')
if: needs.check-checksum.outputs.result == 'fail'
env:
BODY: |
:x: The Bitwise Reproducibility check failed when comparing against `${{ needs.check-checksum.outputs.compared-checksum-version }}` for this `Release` config. :x:
For further information, the experiment can be found on Gadi at ${{ needs.repro-ci.outputs.experiment-location }}, and the test results at ${{ needs.check-checksum.outputs.check-run-url }}.
You must bump the major version of `access-om2-configs` before this PR is merged to account for this - to bump the version, comment `!bump major`. The meaning of these version bumps is explained in the README.md, under `Config Tags`.
run: gh pr comment --body '${{ env.BODY }}'

- name: Failed Dev Comment
if: needs.check-checksum.outputs.result == 'fail' && startsWith(github.base_ref, 'dev-')
env:
BODY: |
:warning: The Bitwise Reproducibility check failed when comparing against `${{ needs.check-checksum.outputs.compared-checksum-version }}` for this `Dev` config. :warning:
For further information, the experiment can be found on Gadi at ${{ needs.repro-ci.outputs.experiment-location }}, and the test results at ${{ needs.check-checksum.outputs.check-run-url }}.
You must bump the major version of `access-om2-configs` before this PR is merged to account for this - to bump the version, comment `!bump major`or modify the `version` in `metadata.yaml`. The meaning of these version bumps is explained in the README.md, under `Config Tags`.
run: gh pr comment --body '${{ env.BODY }}'
10 changes: 8 additions & 2 deletions .github/workflows/pr-2-confirm.yml
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,12 @@ jobs:
id: bump
run: |
version=$(yq '.version' metadata.yaml)

if [[ "${version}" == "null" ]]; then
echo "before=null" >> $GITHUB_OUTPUT
echo "after=1.0" >> $GITHUB_OUTPUT
fi

regex="([0-9]+)\.([0-9]+)"
if [[ $version =~ $regex ]]; then
major_version="${BASH_REMATCH[1]}"
Expand Down Expand Up @@ -118,8 +124,8 @@ jobs:

- name: Commit and Push Updates
run: |
git config user.name github-actions
git config user.email [email protected]
git config user.name ${{ vars.GH_ACTIONS_BOT_GIT_USER_NAME }}
git config user.email ${{ vars.GH_ACTIONS_BOT_GIT_USER_EMAIL }}

if [[ "${{ needs.bump-version.outputs.type }}" == "minor" ]]; then
git commit -am "Bumped version to ${{ needs.bump-version.outputs.after }} as part of ${{ env.RUN_URL }}"
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/schedule-2-start.yml
Original file line number Diff line number Diff line change
Expand Up @@ -80,7 +80,7 @@ jobs:
MODEL_URL: https://github.com/ACCESS-NRI/access-om2
CONFIG: access-om2-configs
CONFIG_URL: https://github.com/ACCESS-NRI/access-om2-configs
TAG_URL: https://github.com/ACCESS-NRI/access-om2-configs/tags/${{ needs.check-checksum.outputs.compared-checksum-version }}
TAG_URL: https://github.com/ACCESS-NRI/access-om2-configs/releases/tag/${{ needs.check-checksum.outputs.compared-checksum-version }}
RUN_URL: ${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}
steps:
- name: Create issue
Expand Down
19 changes: 17 additions & 2 deletions README-DEV.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,9 +10,9 @@ The Reproducibility CI is comprised of two main triggers: on Pull Request and Sc

### Triggered On Pull Request

This pipeline uses the `pr-1-ci.yml` workflow for the majority of the PR lifecycle.
This pipeline uses the `pr-1-ci.yml` workflow for the majority of the PR lifecycle. The `main` version of this workflow is called by `call-pr-1-ci.yml` workflow on the config branch.

It also uses `pr-2-confirm.yml`, and `pr-3-bump-tag.yml` to control supplementary actions like bumping the `.version` field in the `metadata.yaml` file correctly and committing the checksums, and updating the config tag on merge.
It also uses `pr-2-confirm.yml`, and `pr-3-bump-tag.yml` (via `call-pr-3-bump-tag.yml` on the config branch) to control supplementary actions like bumping the `.version` field in the `metadata.yaml` file correctly and committing the checksums, and updating the config tag on merge.

The overall pipeline looks like this:

Expand All @@ -22,13 +22,28 @@ Merge: `pr-3-bump-tag.yml`
#### The PR CI Lifecycle: `pr-1-ci.yml`

This file does the bulk of the handling of the PR.
It contains the following inputs, when the PR-triggered `call-pr-1-ci.yml` calls it:

| Name | Type | Description | Required | Default | Example |
| ---- | ---- | ----------- | -------- | ------- | ------- |
| `qa-pytest-markers` | `string` | Markers used for the pytest QA CI checks, in the python format | `false` | `config or metadata` | `config or metadata or highres` |
| `qa-pytest-add-model-markers` | `boolean` | Markers used for the pytest QA CI checks, in the python format | `false` | `false` | `true` |
| `repro-pytest-markers` | `string` | Markers used for the pytest repro CI checks, in the python format | `false` | `checksum` | `checksum or performance` |

##### `commit-check`

The first job, `commit-check`, is used to short-circuit execution of this workflow in the case where the latest commit was authored by `github-actions`, so there isn't a recursive cycle of checking and adding to the PR.

`github-actions` authors commit to the `testing` directory and `metadata.yaml` files in the PR.

##### `branch-check`

This job is used as a check before running [`repro-ci`](#repro-ci) checks, which are only run on PRs `dev-*` -> `release-*`. It also makes sure that the branches are formatted correctly.

##### `qa-ci`

These checks are runner-hosted, quick configuration sanity checks that will always fire on PRs into `release-*` or `dev-*`.

##### `repro-ci`

This job uses a reusable workflow that runs a given model on Gadi using a particular config tag (in this case, it'll be the source PR branch), and uploads the checksum as an artifact named `<model>-<config-tag>`, for example, `access-om2-release-config-fix`.
Expand Down
Loading