-
Notifications
You must be signed in to change notification settings - Fork 0
79 lines (64 loc) · 2.56 KB
/
CI.yaml
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
name: .Net
on:
push:
branches: [ master ]
pull_request:
branches: [ master ]
jobs:
build:
runs-on: windows-latest
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Extract version
id: getversion
run: |
$xml = [xml](Get-Content DetectiveSpecs/DetectiveSpecs.csproj)
$version = $xml.Project.PropertyGroup.Version
Add-Content -Path $env:GITHUB_ENV -Value "VERSION=$version"
shell: pwsh
- name: Check version
id: checkversion
continue-on-error: true
run: |
pwsh ./.github/scripts/CheckVersion.ps1 -githubRepository ${{ github.repository }} -version $env:VERSION -accessToken $env:ACCESS_TOKEN
shell: pwsh
env:
VERSION: ${{ env.VERSION }}
ACCESS_TOKEN: ${{ secrets.ACCESS_TOKEN }}
- name: Setup .NET 8.0
uses: actions/setup-dotnet@v4
with:
dotnet-version: 8.0.x
- name: Setup NuGet.exe for use with actions
uses: NuGet/setup-nuget@v2
- name: Configure github packages as nuget source
env:
ACCESS_TOKEN: ${{ secrets.ACCESS_TOKEN }}
run: |
$uri = "https://nuget.pkg.github.com/${{ github.repository_owner }}/index.json"
dotnet nuget add source --username ${{ github.actor }} --password $env:ACCESS_TOKEN --store-password-in-clear-text --name github $uri
- name: Restore dependencies
run: dotnet restore
- name: Build
run: dotnet build --no-restore
- name: Test
run: dotnet test --no-build --verbosity normal
- name: Publish
run: pwsh ./.github/scripts/Publish.ps1 -project "DetectiveSpecs/DetectiveSpecs.csproj" -version $env:VERSION -workspacePath ${{ runner.workspace }}
- name: Upload Artifact
uses: actions/upload-artifact@v4
with:
name: DetectiveSpecs
path: ${{ runner.workspace }}/Staging/Build/
- name: Create Github Release
env:
ACCESS_TOKEN: ${{ secrets.ACCESS_TOKEN }}
VERSION: ${{ env.VERSION }}
run: pwsh ./.github/scripts/CreateRelease.ps1 -accessToken $env:ACCESS_TOKEN -version $env:VERSION
- name: Upload Asset to Release
env:
ACCESS_TOKEN: ${{ secrets.ACCESS_TOKEN }}
VERSION: ${{ env.VERSION }}
RELEASE_ID: ${{ env.RELEASE_ID }}
run : pwsh ./.github/scripts/UploadRelease.ps1 -accessToken $env:ACCESS_TOKEN -workspace ${{ runner.workspace }} -releaseId $env:RELEASE_ID -version $env:VERSION