-
Notifications
You must be signed in to change notification settings - Fork 7
126 lines (104 loc) · 4.43 KB
/
build.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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
# Builds a JSON file from the main.json bicep
name: Infra - Build
on:
pull_request: #On PR, we're just doing validation that it compiled to support the build policy
branches:
- main
paths:
- "bicep/*"
- "bicep/modules_bicep/**/*"
workflow_dispatch: #Manual execution will be good for debugging
jobs:
Validation:
permissions:
id-token: write
contents: write
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: ContextCheck
shell: pwsh
run: |
echo 'ghen : ${{ github.event_name }}'
echo "Sha is ${{ github.sha }}"
echo "Ref is ${{ github.ref }}"
echo "Ref name is ${{GITHUB.REF_NAME}}"
dir
- name: Install Bicep
shell: pwsh
run: |
az bicep install
- name: Azure Login
uses: Azure/login@v1
with:
client-id: ${{ secrets.AZURE_CLIENT_ID }}
tenant-id: ${{ secrets.AZURE_TENANT_ID }}
subscription-id: ${{ secrets.AZURE_SUBSCRIPTION_ID }}
enable-AzPSSession: true
environment: azurecloud
allow-no-subscriptions: false
- name: Bicep build
shell: pwsh
run: |
#write-output $pwd
$compiledir=Join-Path -Path $pwd -ChildPath "bicep/compiled"
write-output $compiledir
If(!(test-path $compiledir))
{
New-Item -ItemType Directory -Force -Path $compiledir
}
/home/runner/.azure/bin/bicep build bicep/main.bicep --outdir $compiledir
- uses: actions/checkout@v3
if: github.event_name != 'push'
name: Git Checkout target
with:
path: old
ref: ${{ github.event.pull_request.base.sha }}
- name: Bicep build (old)
shell: pwsh
run: |
#write-output $pwd
$compiledir=Join-Path -Path $pwd -ChildPath "old/bicep/compiled"
write-output $compiledir
If(!(test-path $compiledir))
{
New-Item -ItemType Directory -Force -Path $compiledir
}
/home/runner/.azure/bin/bicep build bicep/main.bicep --outdir $compiledir
- name: Check for Parameter changes in main.json
if: github.event_name != 'push'
env:
oldFilePath: "old/bicep/compiled/main.json"
newFilePath: "bicep/compiled/main.json"
shell: pwsh
run: |
$arm1params = get-content $Env:oldFilePath | ConvertFrom-Json -AsHashtable | Select -expandProperty parameters
$arm2params = get-content $Env:newFilePath | ConvertFrom-Json -AsHashtable | Select -expandProperty parameters
$arm1paramList = @()
$arm1params.keys | % {$arm1paramList += New-Object PSObject -Property ([Ordered]@{Parameter=$_; DefaultValue=$arm1params.Get_Item($_).defaultValue | ConvertTo-Json -Compress })}
$arm2paramList = @()
$arm2params.keys | % {$arm2paramList+= New-Object PSObject -Property ([Ordered]@{Parameter=$_; DefaultValue=$arm2params.Get_Item($_).defaultValue | ConvertTo-Json -Compress })}
$comparison = Compare-Object $arm1paramList $arm2paramList -Property Parameter, DefaultValue -PassThru | select Parameter, DefaultValue, @{N='FileVersion';E={$_.SideIndicator.replace('<=','Old').replace('=>','New')}}
write-output $comparison
if ($comparison.length -gt 0) {
#cd old #Need to change directory to give the gh cli repo context
#GitHub uses a markdown rendering tool called Glamour. It copes with HTML pretty well, and pwsh loves html not markdown.
[string]$html = $comparison | sort-object Parameter, @{e='FileVersion';desc=$true} | ConvertTo-Html -Fragment | Out-String
Write-Output $html
"<h2>Detected parameter change</h2><p>Parameter changes need to be reviewed carefully</p>" + $html | Out-File "ghpr.html"
} else {
write-output "no changes to parameters"
}
- name: Add comment to PR
if: github.event_name == 'pull_request'
env:
PR_URL: ${{ github.event.pull_request.html_url }}
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
shell: pwsh
run: |
if (test-path "ghpr.html") {
gh pr comment ${{ github.event.pull_request.number }} -F "ghpr.html"
}
else {
write-output "ghpr.html not found, no pr comment required"
}