-
Notifications
You must be signed in to change notification settings - Fork 0
57 lines (55 loc) · 2.43 KB
/
policyinitiativebuilder.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
name: Build and deploy .NET application to container app policyinitiativebuilder
on:
push:
branches:
- master
env:
CONTAINER_APP_CONTAINER_NAME: policyinitiativebuilder
CONTAINER_APP_NAME: policyinitiativebuilder
CONTAINER_APP_RESOURCE_GROUP_NAME: rg-policy-initiative-builder
CONTAINER_REGISTRY_LOGIN_SERVER: policyinitiativebuilder.azurecr.io
DOTNET_CORE_VERSION: 9.0.x
PROJECT_NAME_FOR_DOCKER: policyinitiativebuilder
jobs:
build:
runs-on: ubuntu-latest
steps:
- name: Checkout to the branch
uses: actions/checkout@v4
- name: Setup .NET SDK
uses: actions/setup-dotnet@v1.8.0
with:
include-prerelease: True
dotnet-version: ${{ env.DOTNET_CORE_VERSION }}
- name: Log in to container registry
uses: azure/docker-login@v2
with:
login-server: ${{ env.CONTAINER_REGISTRY_LOGIN_SERVER }}
username: ${{ secrets.PolicyInitiativeBuilder_USERNAME_31DD }}
password: ${{ secrets.PolicyInitiativeBuilder_PASSWORD_31DD }}
- name: Build and push container image to registry
run: dotnet publish -c Release -r linux-x64 -p:PublishProfile=DefaultContainer -p:ContainerImageTag=${{ github.sha }} --no-self-contained -p:ContainerRegistry=${{ env.CONTAINER_REGISTRY_LOGIN_SERVER }} -bl
- name: Upload binlog for investigation
uses: actions/upload-artifact@v4
with:
if-no-files-found: error
name: binlog
path: msbuild.binlog
deploy:
runs-on: ubuntu-latest
needs: build
steps:
- name: Azure Login
uses: azure/login@v2
with:
creds: ${{ secrets.policyinitiativebuilder_SPN }}
- name: Deploy to containerapp
uses: azure/CLI@v2
with:
inlineScript: >
az config set extension.use_dynamic_install=yes_without_prompt
az containerapp registry set --name ${{ env.CONTAINER_APP_NAME }} --resource-group ${{ env.CONTAINER_APP_RESOURCE_GROUP_NAME }} --server ${{ env.CONTAINER_REGISTRY_LOGIN_SERVER }} --username ${{ secrets.PolicyInitiativeBuilder_USERNAME_31DD }} --password ${{ secrets.PolicyInitiativeBuilder_PASSWORD_31DD }}
az containerapp update --name ${{ env.CONTAINER_APP_NAME }} --container-name ${{ env.CONTAINER_APP_CONTAINER_NAME }} --resource-group ${{ env.CONTAINER_APP_RESOURCE_GROUP_NAME }} --image ${{ env.CONTAINER_REGISTRY_LOGIN_SERVER }}/${{ env.PROJECT_NAME_FOR_DOCKER }}:${{ github.sha }}
- name: logout
run: >
az logout