-
Notifications
You must be signed in to change notification settings - Fork 44
205 lines (170 loc) · 7.89 KB
/
CI.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
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
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
# This workflow uses actions that are not certified by GitHub.
# They are provided by a third-party and are governed by
# separate terms of service, privacy policy, and support
# documentation.
# This workflow will build, test, sign and package a WPF or Windows Forms desktop application
# built on .NET Core.
# To learn how to migrate your existing application to .NET Core,
# refer to https://docs.microsoft.com/en-us/dotnet/desktop-wpf/migration/convert-project-from-net-framework
#
# To configure this workflow:
#
# 1. Configure environment variables
# GitHub sets default environment variables for every workflow run.
# Replace the variables relative to your project in the "env" section below.
#
# 2. Signing
# Generate a signing certificate in the Windows Application
# Packaging Project or add an existing signing certificate to the project.
# Next, use PowerShell to encode the .pfx file using Base64 encoding
# by running the following Powershell script to generate the output string:
#
# $pfx_cert = Get-Content '.\SigningCertificate.pfx' -Encoding Byte
# [System.Convert]::ToBase64String($pfx_cert) | Out-File 'SigningCertificate_Encoded.txt'
#
# Open the output file, SigningCertificate_Encoded.txt, and copy the
# string inside. Then, add the string to the repo as a GitHub secret
# and name it "Base64_Encoded_Pfx."
# For more information on how to configure your signing certificate for
# this workflow, refer to https://github.com/microsoft/github-actions-for-desktop-apps#signing
#
# Finally, add the signing certificate password to the repo as a secret and name it "Pfx_Key".
# See "Build the Windows Application Packaging project" below to see how the secret is used.
#
# For more information on GitHub Actions, refer to https://github.com/features/actions
# For a complete CI/CD sample to get started with GitHub Action workflows for Desktop Applications,
# refer to https://github.com/microsoft/github-actions-for-desktop-apps
name: CI workflow
on:
push:
branches: [ master, LTS-* ]
tags: [ v* ]
pull_request:
branches: [ master, LTS-* ]
tags: [ v* ]
jobs:
build:
strategy:
matrix:
configuration: [Release] # [Debug, Release]
runs-on: windows-latest #windows-latest
# For a list of available runner types, refer to
# https://help.github.com/en/actions/reference/workflow-syntax-for-github-actions#jobsjob_idruns-on
env:
Solution_Name: Rollbar.sln # Replace with your solution name, i.e. MyWpfApp.sln.
#Test_Project_Path: your-test-project-path # Replace with the path to your test project, i.e. MyWpfApp.Tests\MyWpfApp.Tests.csproj.
#Wap_Project_Directory: your-wap-project-directory-name # Replace with the Wap project directory relative to the solution, i.e. MyWpfApp.Package.
#Wap_Project_Path: your-wap-project-path # Replace with the path to your Wap project, i.e. MyWpf.App.Package\MyWpfApp.Package.wapproj.
steps:
- name: Checkout the SDK's codebase
uses: actions/checkout@v2
with:
fetch-depth: 0
#- name: Setup NuGet
# uses: NuGet/[email protected]
#- name: Restore NuGet Packages
# run: nuget restore $env:Solution_Name
#- name: Build the SDK
# run: msbuild $env:Solution_Name /p:Configuration=${{ matrix.configuration }}
- name: Setup dotnet
uses: actions/setup-dotnet@v1
with:
dotnet-version: |
6.x
5.x
3.1.x
- name: .NET Core Version
run: dotnet --version
- name: .NET Core Info
run: dotnet --info
#- name: Setup MSBuild Path
# uses: warrenbuckley/Setup-MSBuild@v1
- name: Setup VSTest Path
uses: darenm/Setup-VSTest@v1
- name: Restore the SDK's Nuget packages
run: dotnet restore $env:Solution_Name
#- name: .NET version sweeper
# You may pin to the exact commit or the version.
# uses: dotnet/versionsweeper@bb17f163824795f0eef6dbe812bb00df92b9eb6d
#uses: dotnet/[email protected]
#with:
# The owner of the repo. Assign from github.repository_owner. Example, "dotnet".
#owner:
# The repository name. Example, "samples".
#name:
# The branch name. Assign from github.ref. Example, "main".
#branch: master
# The root directory
#dir: # optional, default is /github/workspace
# The search pattern, defaults to "*.csproj;*.fsproj;*.vbproj;*.xproj;project.json". Valid delimiters for lists, ',',';', or '|'. Example, "*.csproj,*.fsproj".
#pattern: # optional, default is *.csproj;*.fsproj;*.vbproj;*.xproj;project.json
# Whether or not to report projects that are not using the new SDK-style project format.
##sdkCompliance: # optional, default is false
- name: Build the SDK
run: dotnet build $env:Solution_Name --configuration ${{ matrix.configuration }} --no-restore
- name: Unit-test the SDK build
run: dotnet test $env:Solution_Name --configuration ${{ matrix.configuration }} --no-build --blame --verbosity normal --collect "Code Coverage"
# - run:
# mkdir -p ${{ github.workspace }}/artifacts
# echo hello > ${{ github.workspace }}/artifacts/world.txt
# Upload the MSIX package: https://github.com/marketplace/actions/upload-artifact
#- name: Upload build artifacts
# uses: actions/upload-artifact@v2
# with:
# name: 'SDK-build'
# path: ${{ github.workspace }}/artifacts/**/*
# sonarcloud:
# runs-on: ubuntu-latest
# steps:
# - name: Checkout the SDK's codebase
# uses: actions/checkout@v2
# with:
# # Disabling shallow clone is recommended for improving relevancy of reporting
# fetch-depth: 0
#
# - name: SonarCloud Scan
# uses: SonarSource/[email protected]
# with:
# # Set the sonar.projectBaseDir analysis property
# projectBaseDir: . # optional, default is .
# env:
# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
# SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}
#- name: .NET SonarScanner Github Actions wrapper
# # You may pin to the exact commit or the version.
# # uses: dodopizza/dotnet-sonarscanner@842f8330436bbc4a4bc5d49cf280508dfd1b910f
# uses: dodopizza/[email protected]
# with:
# # Command to invoke build
# buildCommand:
# # Command to invoke tests
# testCommand: # optional
# # Specifies the key of the analyzed project in SonarQube
# projectKey:
# # Specifies the name of the analyzed project in SonarQube
# projectName:
# # The server URL
# sonarHostname: # optional, default is https://sonarcloud.io
# # Organisation
# sonarOrganisation:
# # Arguments to append to the begin command
# beginArguments: # optional
# # Arguments to append to the end command
# endArguments: # optional
#- name: .NET Library Build and Release
# # You may pin to the exact commit or the version.
# # uses: ricado-group/dotnet-library-build-release-action@b3246af7ac43c6311eebce46f3515daa7dfbd076
# uses: ricado-group/dotnet-library-build-release-action@v1
# with:
# # The Project Name (e.g. RICADO.Logging)
# project-name:
# # The URL of the Private NuGet Repository (e.g. https://nuget.pkg.github.com/myname/index.json)
# private-nuget-url:
# # The Token used for Authentication with the Private NuGet Repository
# private-nuget-token:
# # The URL of the Public NuGet Repository (e.g. https://api.nuget.org/v3/index.json)
# public-nuget-url: # optional, default is https://api.nuget.org/v3/index.json
# # The Token used for Authentication with the Public NuGet Repository
# public-nuget-token: # optional
# # Whether the Library should be Published to the Public NuGet Repository
# publish-public: # optional, default is false