-
-
Notifications
You must be signed in to change notification settings - Fork 24
158 lines (138 loc) · 5.57 KB
/
Copy pathupdate-manifest.yml
File metadata and controls
158 lines (138 loc) · 5.57 KB
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
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
name: Update module manifest
on:
workflow_dispatch:
push:
branches: [ development ]
paths:
- ci/Update-Manifest.ps1
schedule:
- cron: '0 18 * * *'
env:
MANIFEST_FILE: ${{ github.workspace }}\VcRedist\VisualCRedistributables.json
permissions:
contents: write
pull-requests: write
jobs:
validate-arm64:
runs-on: windows-11-arm
outputs:
changes_detected: ${{ steps.commit.outputs.changes_detected }}
steps:
- uses: actions/checkout@v6
with:
ref: development
token: ${{ secrets.GITHUB_TOKEN }}
# Pull latest changes from development branch
- name: Pull latest changes
shell: pwsh
run: |
git pull origin development
# Import GPG key so that we can sign the commit
- name: Import GPG key
id: import_gpg
uses: crazy-max/ghaction-import-gpg@v7
with:
gpg_private_key: ${{ secrets.GPGKEY }}
passphrase: ${{ secrets.GPGPASSPHRASE }}
git_user_signingkey: true
git_commit_gpgsign: true
git_config_global: true
git_tag_gpgsign: true
git_push_gpgsign: false
git_committer_name: ${{ secrets.COMMIT_NAME }}
git_committer_email: ${{ secrets.COMMIT_EMAIL }}
# Uninstall existing VcRedists
- name: Uninstall VcRedists
shell: pwsh
run: |
Import-Module ${{ github.workspace }}\VcRedist -Force
Get-InstalledVcRedist | Uninstall-VcRedist -Confirm:$False -Verbose
# Validate VcRedist 14 and update the manifest
- name: Validate VcRedist 14
shell: pwsh
run: |
$Release = "14"
$Architecture = "x86", "x64","arm64"
Import-Module "${{ github.workspace }}\VcRedist" -Force
New-Item -Path "$env:RUNNER_TEMP\VcRedist" -ItemType "Directory" -ErrorAction "SilentlyContinue" | Out-Null
Get-VcList -Release $Release -Architecture $Architecture | Save-VcRedist -Path "$env:RUNNER_TEMP\VcRedist" | Install-VcRedist
$params = @{
Release = $Release
Architecture = $Architecture
Path = "$env:RUNNER_TEMP\VcRedist"
VcManifest = "${{ env.MANIFEST_FILE }}"
}
. ${{ github.workspace }}\ci\Update-Manifest.ps1 @params
# Format the date number for the commit message
- name: Get date
id: get-date
shell: pwsh
run: |
echo "date=$(Get-Date -Format "yyyy-MM-dd")" >> $env:GITHUB_OUTPUT
# Commit changes to the manifest
- name: Commit changes
id: commit
uses: stefanzweifel/git-auto-commit-action@v7
with:
commit_message: "Update manifest ARM64 ${{ steps.get-date.outputs.date }}.${{ github.run_number }}"
commit_user_name: ${{ secrets.COMMIT_NAME }}
commit_user_email: ${{ secrets.COMMIT_EMAIL }}
- name: "Run if changes have been detected"
if: steps.commit.outputs.changes_detected == 'true'
run: echo "Changes committed."
- name: "Run if no changes have been detected"
if: steps.commit.outputs.changes_detected == 'false'
run: echo "No changes detected."
create-pull-request:
runs-on: ubuntu-latest
needs:
- validate-arm64
if: needs.validate-arm64.outputs.changes_detected == 'true'
steps:
- uses: actions/checkout@v6
with:
ref: development
fetch-depth: 0
- name: Generate pull request body
shell: bash
run: |
git fetch origin main:refs/remotes/origin/main
DIFF_RANGE="origin/main...HEAD"
if ! git merge-base origin/main HEAD >/dev/null; then
DIFF_RANGE="origin/main..HEAD"
fi
{
echo "## Automated manifest update"
echo
echo "This PR was created by workflow run: ${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}"
echo
echo "### Commits in development not in main"
if git log --oneline origin/main..HEAD | grep -q .; then
git log --oneline origin/main..HEAD
else
echo "No commit summary available."
fi
echo
echo "### Files changed (vs main)"
if git diff --name-status "$DIFF_RANGE" | grep -q .; then
git diff --name-status "$DIFF_RANGE"
else
echo "No file changes detected."
fi
} > pr-body.md
- name: Create or update pull request to main
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
PR_CREATE_TOKEN: ${{ secrets.PAT }}
shell: bash
run: |
TITLE="Automated manifest update (${GITHUB_RUN_NUMBER})"
EXISTING_PR_NUMBER=$(gh pr list --base main --head development --state open --json number --jq '.[0].number')
if [[ -n "$EXISTING_PR_NUMBER" ]]; then
gh pr edit "$EXISTING_PR_NUMBER" --title "$TITLE" --body-file pr-body.md
echo "Updated PR #$EXISTING_PR_NUMBER"
elif [[ -n "$PR_CREATE_TOKEN" ]]; then
GH_TOKEN="$PR_CREATE_TOKEN" gh pr create --base main --head development --title "$TITLE" --body-file pr-body.md
else
echo "::warning::No open pull request exists from development to main, and repository secret PAT is not configured. GitHub Actions is not permitted to create pull requests with GITHUB_TOKEN in this repository. To enable automatic PR creation, configure a PAT secret named PAT with repository contents and pull request write access."
fi