-
Notifications
You must be signed in to change notification settings - Fork 50
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
adds reusable unit test gh/action workflows
Signed-off-by: James Kunstle <[email protected]>
- Loading branch information
1 parent
eae2ec8
commit c9ebf6e
Showing
3 changed files
with
136 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,127 @@ | ||
# SPDX-License-Identifier: Apache-2.0 | ||
|
||
name: "Run unit tests on specified EC2" | ||
|
||
on: | ||
pull_request: | ||
types: [opened, reopened, synchronize] | ||
push: | ||
branches: | ||
- "main" | ||
- "release-**" | ||
|
||
env: | ||
pytest_mark: "fast" | ||
ec2_runner_variant: "g6e.12xlarge" | ||
|
||
jobs: | ||
start-ec2-runner: | ||
runs-on: ubuntu-latest | ||
outputs: | ||
label: ${{ steps.start-ec2-runner.outputs.label }} | ||
ec2-instance-id: ${{ steps.start-ec2-runner.outputs.label }} | ||
|
||
steps: | ||
- name: "Harden runner" | ||
uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f # v2.10.1 | ||
with: | ||
egress-policy: audit | ||
|
||
- name: "Configure AWS credentials" | ||
uses: "aws-actions/configure-aws-credentials@e3dd6a429d7300a6a4c196c26e071d42e0343502" # v4.0.2 | ||
with: | ||
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} | ||
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | ||
aws-region: ${{ vars.AWS_REGION }} | ||
|
||
- name: "Start EC2 runner" | ||
id: start-ec2-runner | ||
uses: machulav/ec2-github-runner@1827d6ca7544d7044ddbd2e9360564651b463da2 # v2.3.7 | ||
with: | ||
mode: start | ||
github-token: ${{ secrets.GH_PERSONAL_ACCESS_TOKEN }} | ||
ec2-image-id: ${{ vars.AWS_EC2_AMI }} | ||
ec2-instance-type: ${{ vars.AWS_REGION }} | ||
subnet-id: subnet-024298cefa3bedd61 | ||
security-group-id: sg-06300447c4a5fbef3 | ||
iam-role-name: instructlab-ci-runner | ||
aws-resource-tags: > | ||
[ | ||
{"Key": "Name", "Value": "instructlab-training-ci-github-runner"}, | ||
{"Key": "GitHubRepository", "Value": "${{ github.repository }}"}, | ||
{"Key": "GitHubRef", "Value": "${{ github.ref }}"}, | ||
{"Key": "GitHubPR", "Value": "${{ github.event.number }}"} | ||
] | ||
run-unit-tests: | ||
needs: | ||
- start-ec2-runner | ||
runs-on: ${{needs.start-ec2-runner.outputs.label}} | ||
steps: | ||
- name: "Harden runner" | ||
uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f # v2.10.1 | ||
with: | ||
egress-policy: audit | ||
|
||
- name: "Install packages" | ||
run: | | ||
cat /etc/os-release | ||
sudo dnf install -y gcc gcc-c++ make git python3.11 python3.11-devel | ||
- name: "Checkout code" | ||
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 | ||
with: | ||
fetch-depth: 0 | ||
|
||
- name: "Verify environment variables are setup correctly" | ||
run: | | ||
export CUDA_HOME="/usr/local/cuda" | ||
export LD_LIBRARY_PATH="$LD_LIBRARY_PATH:/usr/local/cuda/lib64:/usr/local/cuda/extras/CUPTI/lib64" | ||
export PATH="$PATH:$CUDA_HOME/bin" | ||
nvidia-smi | ||
# installs in $GITHUB_WORKSPACE/venv. | ||
# only has to install Tox because Tox will do the other virtual environment management. | ||
- name: "Setup Python virtual environment" | ||
run: | | ||
python3.11 -m venv --upgrade-deps venv | ||
. venv/bin/activate | ||
pip install tox | ||
- name: "Show disk utilization BEFORE tests" | ||
run: | | ||
df -h | ||
- name: "Run unit tests with Tox and Pytest" | ||
run: | | ||
tox -e py3-unit -- -m ${{env.pytest_mark}} | ||
- name: "Show disk utilization AFTER tests" | ||
run: | | ||
df -h | ||
stop-ec2-runner: | ||
needs: | ||
- start-ec2-runner | ||
- run-unit-tests | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: "Harden runner" | ||
uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f # v2.10.1 | ||
with: | ||
egress-policy: audit | ||
- name: "Configure AWS credentials" | ||
uses: "aws-actions/configure-aws-credentials@e3dd6a429d7300a6a4c196c26e071d42e0343502" # v4.0.2 | ||
with: | ||
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} | ||
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | ||
aws-region: ${{ vars.AWS_REGION }} | ||
|
||
- name: "Stop EC2 runner" | ||
id: start-ec2-runner | ||
uses: machulav/ec2-github-runner@1827d6ca7544d7044ddbd2e9360564651b463da2 # v2.3.7 | ||
with: | ||
mode: stop | ||
github-token: ${{ secrets.GH_PERSONAL_ACCESS_TOKEN }} | ||
label: ${{ needs.start-ec2-runner.outputs.label }} | ||
ec2-instance-type: ${{ env.ec2_runner_variant }} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
# Third Party | ||
import pytest | ||
|
||
|
||
@pytest.mark.fast | ||
def test_fake(): | ||
assert True |