-
Notifications
You must be signed in to change notification settings - Fork 146
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
test: Add option to run on PR in e2e integration workflow (#633)
- Loading branch information
1 parent
8949bb8
commit 725bcdf
Showing
2 changed files
with
79 additions
and
97 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 |
---|---|---|
|
@@ -15,99 +15,6 @@ on: | |
name: PR E2E Tests | ||
|
||
jobs: | ||
integration-fork-ubuntu: | ||
runs-on: ubuntu-latest | ||
if: | ||
github.event_name == 'workflow_dispatch' && inputs.sha != '' | ||
|
||
steps: | ||
- uses: actions-ecosystem/action-regex-match@v2 | ||
id: validate-tests | ||
with: | ||
text: ${{ inputs.test_path }} | ||
regex: '[^a-z0-9-:.\/_]' # Tests validation | ||
flags: gi | ||
|
||
# Check out merge commit | ||
- name: Checkout PR | ||
uses: actions/checkout@v4 | ||
with: | ||
ref: ${{ inputs.sha }} | ||
|
||
- name: Get the hash value of the latest commit from the PR branch | ||
uses: octokit/[email protected] | ||
id: commit-hash | ||
if: ${{ inputs.pull_request_number != '' }} | ||
with: | ||
query: | | ||
query PRHeadCommitHash($owner: String!, $repo: String!, $pr_num: Int!) { | ||
repository(owner:$owner, name:$repo) { | ||
pullRequest(number: $pr_num) { | ||
headRef { | ||
target { | ||
... on Commit { | ||
oid | ||
} | ||
} | ||
} | ||
} | ||
} | ||
} | ||
owner: ${{ github.event.repository.owner.login }} | ||
repo: ${{ github.event.repository.name }} | ||
pr_num: ${{ fromJSON(inputs.pull_request_number) }} | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
|
||
- name: Update system packages | ||
run: sudo apt-get update -y | ||
|
||
- name: Setup Python | ||
uses: actions/setup-python@v4 | ||
with: | ||
python-version: '3.x' | ||
|
||
- name: Install Python deps | ||
run: pip install .[dev,obj] | ||
|
||
- name: Install the CLI | ||
run: make install | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
|
||
- run: make INTEGRATION_TEST_PATH="${{ inputs.test_path }}" testint | ||
if: ${{ steps.validate-tests.outputs.match == '' }} | ||
env: | ||
LINODE_CLI_TOKEN: ${{ secrets.LINODE_TOKEN }} | ||
|
||
- uses: actions/github-script@v6 | ||
id: update-check-run | ||
if: ${{ inputs.pull_request_number != '' && fromJson(steps.commit-hash.outputs.data).repository.pullRequest.headRef.target.oid == inputs.sha }} | ||
env: | ||
number: ${{ inputs.pull_request_number }} | ||
job: ${{ github.job }} | ||
conclusion: ${{ job.status }} | ||
with: | ||
github-token: ${{ secrets.GITHUB_TOKEN }} | ||
script: | | ||
const { data: pull } = await github.rest.pulls.get({ | ||
...context.repo, | ||
pull_number: process.env.number | ||
}); | ||
const ref = pull.head.sha; | ||
const { data: checks } = await github.rest.checks.listForRef({ | ||
...context.repo, | ||
ref | ||
}); | ||
const check = checks.check_runs.filter(c => c.name === process.env.job); | ||
const { data: result } = await github.rest.checks.update({ | ||
...context.repo, | ||
check_run_id: check[0].id, | ||
status: 'completed', | ||
conclusion: process.env.conclusion | ||
}); | ||
return result; | ||
integration-fork-windows: | ||
runs-on: windows-latest | ||
if: | ||
|
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 |
---|---|---|
@@ -1,39 +1,82 @@ | ||
name: Integration Tests | ||
|
||
on: | ||
workflow_dispatch: | ||
inputs: | ||
use_minimal_test_account: | ||
description: 'Use minimal test account' | ||
required: false | ||
default: 'false' | ||
test_path: | ||
description: "The path from 'test/integration' to the target to be tested, e.g. 'cli'" | ||
required: false | ||
sha: | ||
description: 'The hash value of the commit.' | ||
required: false | ||
default: '' | ||
pull_request_number: | ||
description: 'The number of the PR. Ensure sha value is provided' | ||
required: false | ||
push: | ||
branches: | ||
- main | ||
- dev | ||
|
||
jobs: | ||
integration-tests: | ||
name: Run integration tests | ||
name: Run integration tests on Ubuntu | ||
runs-on: ubuntu-latest | ||
if: github.event_name == 'workflow_dispatch' && inputs.sha != '' || github.event_name == 'push' || github.event_name == 'pull_request' | ||
steps: | ||
- name: Clone Repository with SHA | ||
- name: Validate Test Path | ||
uses: actions-ecosystem/action-regex-match@v2 | ||
id: validate-tests | ||
if: ${{ inputs.test_path != '' }} | ||
with: | ||
text: ${{ inputs.test_path }} | ||
regex: '[^a-z0-9-:.\/_]' # Tests validation | ||
flags: gi | ||
|
||
- name: Checkout Repository with SHA | ||
if: ${{ inputs.sha != '' }} | ||
uses: actions/checkout@v4 | ||
with: | ||
fetch-depth: 0 | ||
submodules: 'recursive' | ||
ref: ${{ inputs.sha }} | ||
|
||
- name: Clone Repository without SHA | ||
- name: Checkout Repository without SHA | ||
if: ${{ inputs.sha == '' }} | ||
uses: actions/checkout@v4 | ||
with: | ||
fetch-depth: 0 | ||
submodules: 'recursive' | ||
|
||
- name: Get the hash value of the latest commit from the PR branch | ||
uses: octokit/[email protected] | ||
id: commit-hash | ||
if: ${{ inputs.pull_request_number != '' }} | ||
with: | ||
query: | | ||
query PRHeadCommitHash($owner: String!, $repo: String!, $pr_num: Int!) { | ||
repository(owner:$owner, name:$repo) { | ||
pullRequest(number: $pr_num) { | ||
headRef { | ||
target { | ||
... on Commit { | ||
oid | ||
} | ||
} | ||
} | ||
} | ||
} | ||
} | ||
owner: ${{ github.event.repository.owner.login }} | ||
repo: ${{ github.event.repository.name }} | ||
pr_num: ${{ fromJSON(inputs.pull_request_number) }} | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
|
||
- name: Update system packages | ||
run: sudo apt-get update -y | ||
|
||
|
@@ -70,6 +113,9 @@ jobs: | |
timestamp=$(date +'%Y%m%d%H%M') | ||
report_filename="${timestamp}_cli_test_report.xml" | ||
make testint TEST_ARGS="--junitxml=${report_filename}" | ||
if: ${{ steps.validate-tests.outputs.match == '' || inputs.test_path == '' }} | ||
env: | ||
LINODE_CLI_TOKEN: ${{ env.LINODE_CLI_TOKEN }} | ||
|
||
- name: Apply Calico Rules to LKE | ||
if: always() | ||
|
@@ -91,4 +137,33 @@ jobs: | |
python3 e2e_scripts/tod_scripts/xml_to_obj_storage/scripts/xml_to_obj.py "${filename}" | ||
env: | ||
LINODE_CLI_OBJ_ACCESS_KEY: ${{ secrets.LINODE_CLI_OBJ_ACCESS_KEY }} | ||
LINODE_CLI_OBJ_SECRET_KEY: ${{ secrets.LINODE_CLI_OBJ_SECRET_KEY }} | ||
LINODE_CLI_OBJ_SECRET_KEY: ${{ secrets.LINODE_CLI_OBJ_SECRET_KEY }} | ||
|
||
- name: Update PR Check Run | ||
uses: actions/github-script@v6 | ||
id: update-check-run | ||
if: ${{ inputs.pull_request_number != '' && fromJson(steps.commit-hash.outputs.data).repository.pullRequest.headRef.target.oid == inputs.sha }} | ||
env: | ||
number: ${{ inputs.pull_request_number }} | ||
job: ${{ github.job }} | ||
conclusion: ${{ job.status }} | ||
with: | ||
github-token: ${{ secrets.GITHUB_TOKEN }} | ||
script: | | ||
const { data: pull } = await github.rest.pulls.get({ | ||
...context.repo, | ||
pull_number: process.env.number | ||
}); | ||
const ref = pull.head.sha; | ||
const { data: checks } = await github.rest.checks.listForRef({ | ||
...context.repo, | ||
ref | ||
}); | ||
const check = checks.check_runs.filter(c => c.name === process.env.job); | ||
const { data: result } = await github.rest.checks.update({ | ||
...context.repo, | ||
check_run_id: check[0].id, | ||
status: 'completed', | ||
conclusion: process.env.conclusion | ||
}); | ||
return result; |