Skip to content

Commit

Permalink
Merge pull request #105 from azure-javaee/ensure_workflow_delete_reso…
Browse files Browse the repository at this point in the history
…urces

Ensure workflow delete resources
  • Loading branch information
venunathb authored Mar 6, 2024
2 parents 6df2cd5 + 11efd77 commit 88fe2f3
Show file tree
Hide file tree
Showing 4 changed files with 248 additions and 87 deletions.
111 changes: 82 additions & 29 deletions .github/workflows/ihsBuild.yml
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,8 @@ on:
workflow_dispatch:
inputs:
imageVersionNumber:
description: 'Must provide image version number'
required: true
description: 'Provide image version number'
required: false
# Allows you to run this workflow using GitHub APIs
# PERSONAL_ACCESS_TOKEN=<GITHUB_PERSONAL_ACCESS_TOKEN>
# REPO_NAME=WASdev/azure.websphere-traditional.image
Expand All @@ -33,8 +33,8 @@ env:
unEntitledIbmPassword: ${{ secrets.UNENTITLED_IBM_USER_PWD }}
vmAdminId: ${{ secrets.VM_ADMIN_ID }}
vmAdminPassword: ${{ secrets.VM_ADMIN_PASSWORD }}
testResourceGroup: imageTest${{ github.run_id }}${{ github.run_number }}-ihs
vmName: vm${{ github.run_id }}${{ github.run_number }}
testResourceGroup: imageTest-${{ github.repository_owner }}-${{ github.run_id }}-${{ github.run_number }}-ihs
vmName: vm-${{ github.run_id }}-${{ github.run_number }}
vhdStorageAccountName: storage${{ github.run_id }}${{ github.run_number }}
location: eastus
scriptLocation: https://raw.githubusercontent.com/${{ secrets.USER_NAME }}/azure.websphere-traditional.image/$GITHUB_REF_NAME/ihs/test/
Expand All @@ -56,7 +56,8 @@ jobs:
build:
# The type of runner that the job will run on
runs-on: ubuntu-latest

outputs:
imageVersionNumber: ${{ steps.setup-env-variables-based-on-dispatch-event.outputs.imageVersionNumber }}
# Steps represent a sequence of tasks that will be executed as part of the job
steps:
- name: Get versions of external dependencies
Expand All @@ -74,7 +75,7 @@ jobs:
else
imageVersionNumber=${{ github.event.client_payload.imageVersionNumber }}
fi
echo "##[set-output name=imageVersionNumber;]${imageVersionNumber}"
echo "imageVersionNumber=${imageVersionNumber}" >> $GITHUB_OUTPUT
- name: Set up JDK 11
uses: actions/setup-java@v2
with:
Expand Down Expand Up @@ -173,6 +174,20 @@ jobs:
az vm deallocate --resource-group ${{ env.testResourceGroup }} --name ${{ env.vmName }}
az vm generalize --resource-group ${{ env.testResourceGroup }} --name ${{ env.vmName }}
az image create --resource-group ${{ env.testResourceGroup }} --name ${{ env.vmName }} --source ${{ env.vmName }}
verify_the_image:
needs: build
runs-on: ubuntu-latest
steps:
- name: Checkout ${{ env.repoName }}
uses: actions/checkout@v3
with:
path: ${{ env.repoName }}
ref: ${{ github.event.inputs.ref }}
- name: Azure login
uses: azure/login@v1
with:
creds: ${{ env.azureCredentials }}
- name: Verify the image
run: |
imageResourceId=$(az image show --name ${{ env.vmName }} --resource-group ${{ env.testResourceGroup }} --query id -o tsv)
Expand All @@ -187,13 +202,13 @@ jobs:
for (( i=0; i<${#vmGroups[@]}; i++ )); do
rgName=${vmGroups[$i]}
az group create -n $rgName -l ${{ env.location }}
az deployment group create --resource-group $rgName --name testDeployment \
--template-file ${{ env.repoName }}/utilities/verifyTemplate.json \
--parameters deploymentMode=${deploymentModes[$i]} ibmUserId=${ibmUserIds[$i]} ibmUserPwd=${ibmUserPwds[$i]} \
imageResourceId=$imageResourceId vmAdminId=${{ env.vmAdminId }} vmAdminPwd=${{ env.vmAdminPassword }} \
scriptLocation=${{ env.scriptLocation }}
az group delete -n $rgName --yes --no-wait
done
- name: Verify the image with twas-cluster integration-test pipeline
Expand All @@ -206,7 +221,7 @@ jobs:
-H "X-GitHub-Api-Version: 2022-11-28" \
https://api.github.com/repos/${{ env.twasClusterRepo }}/actions/workflows/integration-test.yaml/dispatches \
-d $(echo $requestData | jq -c)
# Wait until the workflow run starts
idAndStatus=$(curl -L \
-H "Accept: application/vnd.github+json" \
Expand Down Expand Up @@ -248,7 +263,7 @@ jobs:
| jq -r '.status')
echo "Workflow run ${workflowRunId} is ${status}"
done
# Verify the workflow run result
jobs=$(curl -L \
-H "Accept: application/vnd.github+json" \
Expand All @@ -262,23 +277,15 @@ jobs:
else
echo "twas-cluster integration test workflow run ${workflowRunId} succeeded."
fi
- name: Clean up all resources except for vhd storage account
uses: azure/CLI@v1
update_sas_url:
needs: [build, verify_the_image]
runs-on: ubuntu-latest
steps:
- name: Azure login
uses: azure/login@v1
with:
azcliversion: ${{ env.azCliVersion }}
inlineScript: |
az image delete --ids \
$(az image show -g ${{ env.testResourceGroup }} -n ${{ env.vmName }} --query id -o tsv)
az vm delete --yes --ids \
$(az vm show -g ${{ env.testResourceGroup }} -n ${{ env.vmName }} --query id -o tsv)
az network nic delete --ids \
$(az network nic list -g ${{ env.testResourceGroup }} --query [0].id -o tsv)
az network vnet delete --ids \
$(az network vnet list -g ${{ env.testResourceGroup }} --query [0].id -o tsv)
az network public-ip delete --ids \
$(az network public-ip list -g ${{ env.testResourceGroup }} --query [0].id -o tsv)
az network nsg delete --ids \
$(az network nsg list -g ${{ env.testResourceGroup }} --query [0].id -o tsv)
creds: ${{ env.azureCredentials }}
- name: Generate SAS url
id: sas_url
run: |
Expand All @@ -293,7 +300,7 @@ jobs:
blobStorageEndpoint=$( az storage account show -n ${{ env.vhdStorageAccountName }} -g ${{ env.testResourceGroup }} -o json | jq -r '.primaryEndpoints.blob' )
osDiskSasUrl=${blobStorageEndpoint}vhds/${{ env.vmName }}.vhd?$sasToken
dataDiskSasUrl=${blobStorageEndpoint}vhds/${{ env.vmName }}datadisk1.vhd?$sasToken
echo "osDiskSasUrl: ${osDiskSasUrl}, dataDiskSasUrl: ${dataDiskSasUrl}" > sas-url-ihs.txt
echo "##[set-output name=osDiskSasUrl;]${osDiskSasUrl}"
echo "##[set-output name=dataDiskSasUrl;]${dataDiskSasUrl}"
Expand All @@ -304,6 +311,7 @@ jobs:
path: sas-url-ihs.txt
- name: Update offer sas url and version
uses: microsoft/microsoft-partner-center-github-action@v3.1
if: ${{ needs.build.outputs.imageVersionNumber != '' }}
with:
offerId: ${{ env.offerId }}
planId: ${{ env.planId }}
Expand All @@ -312,17 +320,62 @@ jobs:
tenantId: ${{ env.tenantId }}
secretValue: ${{ env.secretValue }}
imageType: ${{ env.imageType }}
imageVersionNumber: ${{ steps.setup-env-variables-based-on-dispatch-event.outputs.imageVersionNumber }}
imageVersionNumber: ${{ needs.build.outputs.imageVersionNumber }}
operatingSystemFamily: ${{ env.operatingSystemFamily }}
operatingSystemType: ${{ env.operatingSystemType }}
osDiskSasUrl: ${{steps.sas_url.outputs.osDiskSasUrl}}
dataDiskSasUrl: ${{steps.sas_url.outputs.dataDiskSasUrl}}
verbose: "false"

summary:
needs: build
needs: [build, verify_the_image, update_sas_url]
runs-on: ubuntu-latest
steps:
- name: Output inputs from workflow_dispatch
run: echo "${{ toJSON(github.event.inputs) }}"
- name: Output client_payload from repository_dispatch
run: echo "${{ toJSON(github.event.client_payload) }}"

delete_resource:
needs: [ build, verify_the_image, update_sas_url,summary ]
runs-on: ubuntu-latest
if: always()
steps:
- name: Azure login
uses: azure/login@v1
with:
creds: ${{ env.azureCredentials }}
- name: Clean up all resources except for vhd storage account
continue-on-error: true
run: |
az image delete --ids \
$(az image show -g ${{ env.testResourceGroup }} -n ${{ env.vmName }} --query id -o tsv)
az vm delete --yes --ids \
$(az vm show -g ${{ env.testResourceGroup }} -n ${{ env.vmName }} --query id -o tsv)
az network nic delete --ids \
$(az network nic list -g ${{ env.testResourceGroup }} --query [0].id -o tsv)
az network vnet delete --ids \
$(az network vnet list -g ${{ env.testResourceGroup }} --query [0].id -o tsv)
az network public-ip delete --ids \
$(az network public-ip list -g ${{ env.testResourceGroup }} --query [0].id -o tsv)
az network nsg delete --ids \
$(az network nsg list -g ${{ env.testResourceGroup }} --query [0].id -o tsv)
- name: Delete resource groups during verification
continue-on-error: true
run: |
vmGroups=( ${{ env.testResourceGroup }}-entitled ${{ env.testResourceGroup }}-unentitled ${{ env.testResourceGroup }}-evaluation )
for (( i=0; i<${#vmGroups[@]}; i++ )); do
rgName=${vmGroups[$i]}
if $(az group exists --name $rgName); then
echo "Resource group $rgName exists. Deleting..."
az group delete --name $rgName --yes --no-wait
echo "Resource group $rgName has been scheduled for deletion."
else
echo "Resource group $rgName does not exist."
fi
done
- name: Delete testResourceGroup
if: ${{ needs.verify_the_image.result != 'success' }}
run: |
echo "The verify_the_image result is ${{ needs.verify_the_image.result }}, delete the testResourceGroup."
az group delete -n ${{ env.testResourceGroup }} --yes --no-wait
Loading

0 comments on commit 88fe2f3

Please sign in to comment.