PR Triggered Tests #31
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
name: PR Triggered Tests | |
on: | |
pull_request_target: | |
types: [opened, synchronize, reopened] | |
workflow_dispatch: | |
jobs: | |
trigger-azure-pipeline: | |
runs-on: ubuntu-latest | |
if: contains(github.event.pull_request.base.ref, 'main') || github.event_name == 'workflow_dispatch' | |
steps: | |
- name: Check if authorized to run tests | |
id: check | |
run: | | |
# Add any conditions if necessary. For now, always allow. | |
echo "ok=true" >> $GITHUB_OUTPUT | |
- name: Trigger Azure DevOps Pipeline | |
id: trigger_pipeline | |
if: steps.check.outputs.ok == 'true' | |
run: | | |
PAT="${{ secrets.AZURE_DEVOPS_PAT }}" | |
ORG="sergiovelderrain" | |
PROJECT="sergiovelderrain" | |
PIPELINE_ID="3" | |
API_VERSION="7.0" | |
# Ensure PAT is not empty | |
if [ -z "$PAT" ]; then | |
echo "AZURE_DEVOPS_PAT is not set or empty!" | |
exit 1 | |
fi | |
# Base64 encode credentials and remove newline | |
AUTH=$(echo -n ":$PAT" | base64 | tr -d '\n') | |
# Use the PR's head ref for the pipeline branch if it's a PR event | |
# If manually triggered (workflow_dispatch), default to a known branch like 'develop' | |
if [ "${{ github.event_name }}" = "workflow_dispatch" ]; then | |
PR_HEAD_REF="main" | |
else | |
PR_HEAD_REF="${{ github.event.pull_request.head.ref }}" | |
fi | |
JSON_BODY='{ | |
"resources": { | |
"repositories": { | |
"self": { | |
"refName": "refs/heads/'"${PR_HEAD_REF}"'" | |
} | |
} | |
} | |
}' | |
echo "Triggering Azure DevOps pipeline with the following JSON:" | |
echo "$JSON_BODY" | |
# Trigger the pipeline and capture the response | |
RESPONSE=$(curl --fail --http1.1 -s -X POST \ | |
-H "Authorization: Basic $AUTH" \ | |
-H "Content-Type: application/json" \ | |
-d "$JSON_BODY" \ | |
"https://dev.azure.com/$ORG/$PROJECT/_apis/pipelines/$PIPELINE_ID/runs?api-version=$API_VERSION") | |
echo "Pipeline trigger response:" | |
echo "$RESPONSE" | |
# Verify response is JSON before parsing | |
if ! echo "$RESPONSE" | grep -q '^{'; then | |
echo "The response is not in JSON format. Cannot parse with jq." | |
exit 1 | |
fi | |
# Extract the pipeline run ID from the response using jq | |
RUN_ID=$(echo "$RESPONSE" | jq -r '.id') | |
if [ "$RUN_ID" == "null" ] || [ -z "$RUN_ID" ]; then | |
echo "Could not extract run ID from the response." | |
exit 1 | |
fi | |
echo "run_id=$RUN_ID" >> $GITHUB_OUTPUT | |
- name: Wait for Azure DevOps Pipeline to complete | |
if: steps.check.outputs.ok == 'true' | |
run: | | |
PAT="${{ secrets.AZURE_DEVOPS_PAT }}" | |
ORG="sergiovelderrain" | |
PROJECT="sergiovelderrain" | |
API_VERSION="7.0" | |
RUN_ID=${{ steps.trigger_pipeline.outputs.run_id }} | |
# Base64 encode credentials and remove newline | |
AUTH=$(echo -n ":$PAT" | base64 | tr -d '\n') | |
echo "Checking status for RUN_ID: $RUN_ID" | |
# Poll every 15 seconds for up to 30 minutes (120 polls) | |
for i in {1..120}; do | |
STATUS_RESPONSE=$(curl --http1.1 -s \ | |
-H "Authorization: Basic $AUTH" \ | |
"https://dev.azure.com/$ORG/$PROJECT/_apis/pipelines/runs/$RUN_ID?api-version=$API_VERSION") | |
STATE=$(echo "$STATUS_RESPONSE" | jq -r '.state') | |
RESULT=$(echo "$STATUS_RESPONSE" | jq -r '.result') | |
echo "Pipeline state: $STATE" | |
echo "Pipeline result: $RESULT" | |
if [ "$STATE" = "completed" ]; then | |
if [ "$RESULT" = "succeeded" ]; then | |
echo "Pipeline completed successfully." | |
exit 0 | |
else | |
echo "Pipeline failed or did not succeed. Result: $RESULT" | |
exit 1 | |
fi | |
fi | |
echo "Pipeline not completed yet. Waiting..." | |
sleep 15 | |
done | |
echo "Pipeline did not complete within the expected time." | |
exit 1 |