mirror of
https://github.com/asterisk/asterisk.git
synced 2025-10-12 15:45:18 +00:00
86 lines
3.7 KiB
YAML
86 lines
3.7 KiB
YAML
#
|
|
# Workflows, like this one, that are triggered by PRs submitted
|
|
# from forked repositories are severly limited in what they can do
|
|
# for security reasons. For instance, they can't add or remove
|
|
# labels or comments even on the PR that triggered them. Since
|
|
# we need to both of those things, GitHub recommends creating a
|
|
# separate workflow that does those tasks that's triggered when
|
|
# this PR workflow starts or finishes. Since that workflow isn't
|
|
# being run in the context of a forked repo, it has all the
|
|
# privileges needed to add and remove labels and comments. The
|
|
# accompanying OnPRStateChangedPriv workflow does just that.
|
|
|
|
name: PRChanged
|
|
# WARNING! The run name MUST start with "PR <pr_number>".
|
|
# The accompanying privleged workflow parses this to find
|
|
# the PR number. It's the only reliable way it can get it.
|
|
run-name: "PR ${{ github.event.number }} ${{ github.event.action }} by ${{ github.actor }}"
|
|
on:
|
|
pull_request:
|
|
types: [opened, reopened, synchronize]
|
|
|
|
concurrency:
|
|
group: check-${{ github.event.number }}
|
|
cancel-in-progress: true
|
|
|
|
jobs:
|
|
#
|
|
# Pull requests created from forked respositories don't have access
|
|
# to the "Action Variables" ('vars' context) so we need to retrieve
|
|
# control data from an action that's located in asterisk-ci-actions.
|
|
#
|
|
Setup:
|
|
runs-on: ubuntu-latest
|
|
outputs:
|
|
vars: ${{ steps.setvars.outputs.control_data }}
|
|
testsuite_test_pr: ${{ steps.testsuitepr.outputs.testsuite_test_pr }}
|
|
steps:
|
|
- id: setvars
|
|
uses: asterisk/asterisk-ci-actions/GetRepoControlData@main
|
|
with:
|
|
repo: ${{ github.event.repository.name }}
|
|
|
|
- id: wait
|
|
env:
|
|
PR_STATE_CHANGE_DELAY_SEC: ${{ fromJSON(steps.setvars.outputs.control_data).PR_STATE_CHANGE_DELAY_SEC || 120 }}
|
|
run: |
|
|
echo "Waiting for ${PR_STATE_CHANGE_DELAY_SEC} seconds to give user a chance to add PR comments"
|
|
sleep ${PR_STATE_CHANGE_DELAY_SEC}
|
|
exit 0
|
|
|
|
- name: GetTestsuitePR
|
|
id: testsuitepr
|
|
uses: asterisk/asterisk-ci-actions/GetTestsuitePRFromAsteriskPR@main
|
|
with:
|
|
repo: ${{ github.repository }}
|
|
pr_number: ${{ github.event.number }}
|
|
testsuite_test_pr_regex: ${{ fromJSON(steps.setvars.outputs.control_data).TESTSUITE_TEST_PR_REGEX }}
|
|
testsuite_test_auto_merge_regex: ${{ fromJSON(steps.setvars.outputs.control_data).TESTSUITE_TEST_AUTO_MERGE_REGEX }}
|
|
github_token: ${{ secrets.GITHUB_TOKEN }}
|
|
|
|
- name: DumpEnvironment
|
|
if: ${{ fromJSON(steps.setvars.outputs.control_data).RUN_DUMP_ENV }}
|
|
uses: asterisk/asterisk-ci-actions/DumpEnvironmentAction@main
|
|
with:
|
|
action-vars: ${{ toJSON(steps.setvars.outputs) }}
|
|
action-inputs: ${{ toJSON(steps.testsuitepr.outputs) }}
|
|
|
|
Check:
|
|
name: Check
|
|
needs: Setup
|
|
uses: asterisk/asterisk-ci-actions/.github/workflows/AsteriskUnitGateTest.yml@main
|
|
with:
|
|
test_type: prstatechange
|
|
asterisk_repo: ${{ github.repository }}
|
|
pr_number: ${{ github.event.number }}
|
|
base_branch: ${{ github.event.pull_request.base.ref }}
|
|
build_options: ${{ fromJSON(needs.Setup.outputs.vars).BUILD_OPTIONS }}
|
|
unittest_command: ${{ fromJSON(needs.Setup.outputs.vars).UNITTEST_COMMAND }}
|
|
testsuite_repo: ${{ fromJSON(needs.Setup.outputs.vars).TESTSUITE_REPO }}
|
|
testsuite_test_pr: ${{ needs.Setup.outputs.testsuite_test_pr }}
|
|
gatetest_list: ${{ fromJSON(needs.Setup.outputs.vars).GATETEST_LIST }}
|
|
gatetest_commands: ${{ fromJSON(needs.Setup.outputs.vars).GATETEST_COMMANDS }}
|
|
secrets:
|
|
TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
|