Azure Pipeline Merge Queue Check #1550
Workflow file for this run
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: Azure Pipeline Merge Queue Check | |
on: | |
workflow_dispatch: | |
pull_request: | |
branches: | |
- master | |
merge_group: | |
types: | |
- checks_requested | |
jobs: | |
Azure-Merge-Queue-Check: | |
if: ${{ github.event_name == 'merge_group' }} | |
strategy: | |
matrix: | |
go-version: ['1.21'] | |
os: [ubuntu-latest] | |
name: Azure Pipeline Merge Queue Check | |
runs-on: ${{ matrix.os }} | |
permissions: | |
actions: read | |
contents: read | |
id-token: write | |
steps: | |
- name: Azure Login | |
uses: Azure/login@v2.0.0 | |
env: | |
AZURE_CORE_OUTPUT: none | |
with: | |
creds: ${{ secrets.AZURE_CREDENTIALS }} | |
- name: Check Azure Pipelines | |
uses: azure/CLI@v2 | |
env: | |
AZURE_CORE_OUTPUT: none | |
with: | |
azcliversion: latest | |
inlineScript: | | |
az account show | |
export AZURE_DEVOPS_EXT_PAT=${{ secrets.AZURE_DEVOPS_EXT_PAT }} | |
echo "Sanity check recently triggered Merge Queue Pipeline runs" | |
az pipelines runs list --pipeline-ids ${{ secrets.AZURE_PIPELINE_ID }} --org ${{ secrets.AZURE_PIPELINE_ORG }} --project ${{ secrets.AZURE_PIPELINE_PROJECT }} --reason individualCI --top 10 --query-order QueueTimeDesc --output json | jq -r .[].sourceBranch | |
status=`az pipelines runs list --pipeline-ids ${{ secrets.AZURE_PIPELINE_ID }} --org ${{ secrets.AZURE_PIPELINE_ORG }} --project ${{ secrets.AZURE_PIPELINE_PROJECT }} --top 1 --branch $GITHUB_REF --query-order QueueTimeDesc --output json | jq -r .[].status` | |
echo "Triggered CI Status - $status" | |
echo "Branch Ref - $GITHUB_REF" | |
echo "Checking for AZP triggered CI for 60s" | |
end=$((SECONDS+60)) # Stop checking if not queued within a minute | |
while [ $SECONDS -lt $end ]; do | |
echo "Waiting for 5 seconds for AZP to trigger run and show inProgress or notStarted" | |
sleep 5s | |
status=`az pipelines runs list --pipeline-ids ${{ secrets.AZURE_PIPELINE_ID }} --org ${{ secrets.AZURE_PIPELINE_ORG }} --project ${{ secrets.AZURE_PIPELINE_PROJECT }} --top 1 --branch $GITHUB_REF --query-order QueueTimeDesc --output json | jq -r .[].status` | |
echo "Current CI Status - $status" | |
if [ $status = 'inProgress' ] || [ $status = 'notStarted' ]; then | |
echo "AZP triggered pipeline queued successfully" | |
exit 0 | |
fi | |
done | |
echo "AZP did not trigger CI" | |
az pipelines run --branch $GITHUB_REF --id ${{ secrets.AZURE_PIPELINE_ID }} --org ${{ secrets.AZURE_PIPELINE_ORG }} --project ${{ secrets.AZURE_PIPELINE_PROJECT }} | |
echo "Pipeline queued for $GITHUB_REF" | |
echo "Pipeline will be marked as Manually triggered for $GITHUB_REF" | |
echo "Checking for Manually triggered CI for 60s" | |
end=$((SECONDS+60)) # Stop checking if not queued within a minute | |
while [ $SECONDS -lt $end ]; do | |
echo "Waiting for 5 seconds for pipeline to show inProgress or notStarted on AZP" | |
sleep 5s | |
status=`az pipelines runs list --pipeline-ids ${{ secrets.AZURE_PIPELINE_ID }} --org ${{ secrets.AZURE_PIPELINE_ORG }} --project ${{ secrets.AZURE_PIPELINE_PROJECT }} --top 1 --branch $GITHUB_REF --query-order QueueTimeDesc --output json | jq -r .[].status` | |
echo "Current CI Status - $status" | |
if [ $status = 'inProgress' ] || [ $status = 'notStarted' ]; then | |
echo "Manually triggered pipeline queued successfully" | |
exit 0 | |
fi | |
done | |
echo "Pipeline not queued, break merge queue run. Please requeue the PR to the merge queue from the appropriate PR." | |
# NOTE: For this workflow to impact the Merge Queue and PR it must be made required in the appropriate branch protection rule | |
exit 1 |