-
Notifications
You must be signed in to change notification settings - Fork 0
114 lines (93 loc) · 3.33 KB
/
update-packages.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
name: Update packages
on:
workflow_dispatch:
schedule:
- cron: "0 2 * * 0"
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
jobs:
update_packages:
name: Update packages
runs-on: windows-latest
outputs:
branchExists: ${{ steps.verify-changed-files.outputs.files_changed }}
steps:
- name: Generate a token
id: generate_token
uses: tibdex/[email protected]
with:
app_id: ${{ secrets.APP_ID }}
private_key: ${{ secrets.APP_PRIVATE_KEY }}
- name: Checkout code
uses: actions/checkout@v4
with:
fetch-depth: 0
token: ${{ steps.generate_token.outputs.token }}
- name: Set solution name
run: |
echo "solution=$(([io.fileinfo]$(Get-ChildItem -Path .\* -Include *.sln)).name)" | Out-File -FilePath $env:GITHUB_ENV -Append
- name: Setup .NET
uses: actions/setup-dotnet@v4
with:
dotnet-version: "8.0.x"
- name: Add MSBuild to PATH
uses: microsoft/setup-msbuild@v2
env:
ACTIONS_ALLOW_UNSECURE_COMMANDS: true
- name: Setup Nuget
uses: nuget/setup-nuget@v2
env:
ACTIONS_ALLOW_UNSECURE_COMMANDS: true
- name: Create new branch
run: git branch feature/update_dependencies_${{ github.run_number }}
- name: Switch branch
run: git checkout feature/update_dependencies_${{ github.run_number }}
- name: NuGet restore
run: nuget restore
- name: Update NuGet packages
run: nuget update "${{ env.solution }}" -FileConflictAction Ignore
- name: Setup GIT config
run: |
git config user.name "net-framework-updater[bot]"
git config user.email "136581072+net-framework-updater[bot]@users.noreply.github.com"
git config --global --add --bool push.autoSetupRemote true
- name: Verify Changed files
uses: tj-actions/verify-changed-files@v20
id: verify-changed-files
- name: Commit and Push
if: steps.verify-changed-files.outputs.files_changed == 'true'
run: |
git add .
git commit -a -m "Packages update (CI)"
git push
create_pull_request:
name: Create pull request
runs-on: ubuntu-latest
needs: update_packages
if: needs.update_packages.outputs.branchExists == 'true'
steps:
- name: Generate a token
id: generate_token
uses: tibdex/[email protected]
with:
app_id: ${{ secrets.APP_ID }}
private_key: ${{ secrets.APP_PRIVATE_KEY }}
- name: Checkout code
uses: actions/checkout@v4
with:
fetch-depth: 0
token: ${{ steps.generate_token.outputs.token }}
ref: feature/update_dependencies_${{ github.run_number }}
- name: Create pull request
uses: devops-infra/[email protected]
with:
github_token: ${{ steps.generate_token.outputs.token }}
source_branch: feature/update_dependencies_${{ github.run_number }}
target_branch: main
title: Update NuGet packages
assignee: guibranco
reviewer: guibranco
label: dependencies,.NET,infra,nuget,packages
template: .github/PULL_REQUEST_TEMPLATE/FEATURE.md
get_diff: true