Skip to content

Commit 689c3f4

Browse files
feat: added automation deployment pipeline
1 parent dcd93f9 commit 689c3f4

File tree

1 file changed

+220
-0
lines changed

1 file changed

+220
-0
lines changed

.github/workflows/deploy.yml

Lines changed: 220 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,220 @@
1+
name: CI-Validate Deployment-Multi-Agent-Custom-Automation-Engine-Solution-Accelerator
2+
3+
on:
4+
push:
5+
branches:
6+
- main
7+
8+
jobs:
9+
deploy:
10+
runs-on: ubuntu-latest
11+
steps:
12+
- name: Checkout Code
13+
uses: actions/checkout@v3
14+
15+
- name: Setup Azure CLI
16+
run: |
17+
curl -sL https://aka.ms/InstallAzureCLIDeb | sudo bash
18+
az --version # Verify installation
19+
20+
- name: Login to Azure
21+
run: |
22+
az login --service-principal -u ${{ secrets.AZURE_CLIENT_ID }} -p ${{ secrets.AZURE_CLIENT_SECRET }} --tenant ${{ secrets.AZURE_TENANT_ID }}
23+
24+
- name: Install Bicep CLI
25+
run: az bicep install
26+
27+
- name: Generate Resource Group Name
28+
id: generate_rg_name
29+
run: |
30+
echo "Generating a unique resource group name..."
31+
TIMESTAMP=$(date +%Y%m%d%H%M%S)
32+
COMMON_PART="ci-biab"
33+
UNIQUE_RG_NAME="${COMMON_PART}${TIMESTAMP}"
34+
echo "RESOURCE_GROUP_NAME=${UNIQUE_RG_NAME}" >> $GITHUB_ENV
35+
echo "Generated Resource_GROUP_PREFIX: ${UNIQUE_RG_NAME}"
36+
37+
38+
- name: Check and Create Resource Group
39+
id: check_create_rg
40+
run: |
41+
set -e
42+
echo "Checking if resource group exists..."
43+
rg_exists=$(az group exists --name ${{ env.RESOURCE_GROUP_NAME }})
44+
if [ "$rg_exists" = "false" ]; then
45+
echo "Resource group does not exist. Creating..."
46+
az group create --name ${{ env.RESOURCE_GROUP_NAME }} --location eastus2 || { echo "Error creating resource group"; exit 1; }
47+
else
48+
echo "Resource group already exists."
49+
fi
50+
51+
52+
- name: Deploy Bicep Template
53+
id: deploy
54+
run: |
55+
set -e
56+
az deployment group create \
57+
--resource-group ${{ env.RESOURCE_GROUP_NAME }} \
58+
--template-file deploy/macae.bicep
59+
60+
61+
- name: Send Notification on Failure
62+
if: failure()
63+
run: |
64+
RUN_URL="https://github.com/${{ github.repository }}/actions/runs/${{ github.run_id }}"
65+
66+
# Construct the email body
67+
EMAIL_BODY=$(cat <<EOF
68+
{
69+
"body": "<p>Dear Team,</p><p>We would like to inform you that the Multi-Agent-Custom-Automation-Engine-Solution-Accelerator Automation process has encountered an issue and has failed to complete successfully.</p><p><strong>Build URL:</strong> ${RUN_URL}<br> ${OUTPUT}</p><p>Please investigate the matter at your earliest convenience.</p><p>Best regards,<br>Your Automation Team</p>"
70+
}
71+
EOF
72+
)
73+
74+
# Send the notification
75+
curl -X POST "${{ secrets.LOGIC_APP_URL }}" \
76+
-H "Content-Type: application/json" \
77+
-d "$EMAIL_BODY" || echo "Failed to send notification"
78+
79+
80+
- name: Get OpenAI, Container Registry Resource from Resource Group
81+
id: get_openai_resource
82+
run: |
83+
84+
85+
set -e
86+
echo "Fetching OpenAI resource from resource group ${{ env.RESOURCE_GROUP_NAME }}..."
87+
88+
# Run the az resource list command to get the OpenAI resource name
89+
openai_resource_name=$(az resource list --resource-group ${{ env.RESOURCE_GROUP_NAME }} --resource-type "Microsoft.CognitiveServices/accounts" --query "[0].name" -o tsv)
90+
91+
if [ -z "$openai_resource_name" ]; then
92+
echo "No OpenAI resource found in resource group ${{ env.RESOURCE_GROUP_NAME }}."
93+
exit 1
94+
else
95+
echo "OPENAI_RESOURCE_NAME=${openai_resource_name}" >> $GITHUB_ENV
96+
echo "OpenAI resource name: ${openai_resource_name}"
97+
fi
98+
99+
echo "Fetching container registry resource from resource group ${{ env.RESOURCE_GROUP_NAME }}..."
100+
101+
# Fetch Azure Container Registry name
102+
acr_name=$(az acr list --resource-group ${{ env.RESOURCE_GROUP_NAME }} --query "[0].name" -o tsv)
103+
104+
if [ -z "$acr_name" ]; then
105+
echo "No Azure Container Registry found in resource group ${{ env.RESOURCE_GROUP_NAME }}."
106+
exit 1
107+
else
108+
echo "ACR_NAME=${acr_name}" >> $GITHUB_ENV
109+
echo "Azure Container Registry name: ${acr_name}"
110+
fi
111+
112+
113+
- name: Build the image and update the container app
114+
id: build-and-update
115+
run: |
116+
117+
set -e
118+
# Define variables for acr and container app names
119+
acr_name="${{ env.ACR_NAME }}"
120+
echo "ACR name: {$acr_name}"
121+
container_app_name="biab"
122+
buildImageTag="biab:latest"
123+
124+
echo "Building the container image..."
125+
# Build the image
126+
az acr build -r ${acr_name} -t ${buildImageTag} ./agnext-biab-02
127+
echo "Image build completed successfully."
128+
129+
echo "Updating the container app..."
130+
# Update the container app
131+
az containerapp update -n ${container_app_name} -g ${{ env.RESOURCE_GROUP_NAME }} --image ${acr_name}.azurecr.io/${buildImageTag}
132+
echo "Container app update completed successfully."
133+
134+
135+
- name: Delete Bicep Deployment
136+
if: success()
137+
run: |
138+
set -e
139+
echo "Checking if resource group exists..."
140+
rg_exists=$(az group exists --name ${{ env.RESOURCE_GROUP_NAME }})
141+
if [ "$rg_exists" = "true" ]; then
142+
echo "Resource group exist. Cleaning..."
143+
az group delete \
144+
--name ${{ env.RESOURCE_GROUP_NAME }} \
145+
--yes \
146+
--no-wait
147+
echo "Resource group deleted... ${{ env.RESOURCE_GROUP_NAME }}"
148+
else
149+
echo "Resource group does not exists."
150+
fi
151+
152+
153+
- name: Wait for resource deletion to complete
154+
run: |
155+
156+
157+
# Add resources to the array
158+
resources_to_check=("${{ env.OPENAI_RESOURCE_NAME }}")
159+
160+
echo "List of resources to check: ${resources_to_check[@]}"
161+
162+
# Maximum number of retries
163+
max_retries=3
164+
165+
# Retry intervals in seconds (30, 60, 120)
166+
retry_intervals=(30 60 120)
167+
168+
# Retry mechanism to check resources
169+
retries=0
170+
while true; do
171+
resource_found=false
172+
173+
# Get the list of resources in YAML format again on each retry
174+
resource_list=$(az resource list --resource-group ${{ env.RESOURCE_GROUP_NAME }} --output yaml)
175+
176+
# Iterate through the resources to check
177+
for resource in "${resources_to_check[@]}"; do
178+
echo "Checking resource: $resource"
179+
if echo "$resource_list" | grep -q "name: $resource"; then
180+
echo "Resource '$resource' exists in the resource group."
181+
resource_found=true
182+
else
183+
echo "Resource '$resource' does not exist in the resource group."
184+
fi
185+
done
186+
187+
# If any resource exists, retry
188+
if [ "$resource_found" = true ]; then
189+
retries=$((retries + 1))
190+
if [ "$retries" -gt "$max_retries" ]; then
191+
echo "Maximum retry attempts reached. Exiting."
192+
break
193+
else
194+
# Wait for the appropriate interval for the current retry
195+
echo "Waiting for ${retry_intervals[$retries-1]} seconds before retrying..."
196+
sleep ${retry_intervals[$retries-1]}
197+
fi
198+
else
199+
echo "No resources found. Exiting."
200+
break
201+
fi
202+
done
203+
204+
205+
- name: Purging the Resources
206+
if: success()
207+
run: |
208+
209+
set -e
210+
echo "Azure OpenAI: ${{ env.OPENAI_RESOURCE_NAME }}"
211+
212+
# Purge OpenAI Resource
213+
echo "Purging the OpenAI Resource..."
214+
if ! az resource delete --ids /subscriptions/${{ secrets.AZURE_SUBSCRIPTION_ID }}/providers/Microsoft.CognitiveServices/locations/eastus/resourceGroups/${{ env.RESOURCE_GROUP_NAME }}/deletedAccounts/${{ env.OPENAI_RESOURCE_NAME }} --verbose; then
215+
echo "Failed to purge openai resource: ${{ env.OPENAI_RESOURCE_NAME }}"
216+
else
217+
echo "Purged the openai resource: ${{ env.OPENAI_RESOURCE_NAME }}"
218+
fi
219+
220+
echo "Resource purging completed successfully"

0 commit comments

Comments
 (0)