# # 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 ". # 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 }}