|
1 |
| -echo "build: Build started" |
| 1 | +Write-Output "build: Tool versions follow" |
| 2 | + |
| 3 | +dotnet --version |
| 4 | +dotnet --list-sdks |
| 5 | + |
| 6 | +Write-Output "build: Build started" |
2 | 7 |
|
3 | 8 | Push-Location $PSScriptRoot
|
| 9 | +try { |
| 10 | + if(Test-Path .\artifacts) { |
| 11 | + Write-Output "build: Cleaning ./artifacts" |
| 12 | + Remove-Item ./artifacts -Force -Recurse |
| 13 | + } |
4 | 14 |
|
5 |
| -if(Test-Path .\artifacts) { |
6 |
| - echo "build: Cleaning .\artifacts" |
7 |
| - Remove-Item .\artifacts -Force -Recurse |
8 |
| -} |
| 15 | + & dotnet restore --no-cache |
9 | 16 |
|
10 |
| -& dotnet restore --no-cache |
| 17 | + $dbp = [Xml] (Get-Content .\Directory.Version.props) |
| 18 | + $versionPrefix = $dbp.Project.PropertyGroup.VersionPrefix |
11 | 19 |
|
12 |
| -$branch = @{ $true = $env:APPVEYOR_REPO_BRANCH; $false = $(git symbolic-ref --short -q HEAD) }[$env:APPVEYOR_REPO_BRANCH -ne $NULL]; |
13 |
| -$revision = @{ $true = "{0:00000}" -f [convert]::ToInt32("0" + $env:APPVEYOR_BUILD_NUMBER, 10); $false = "local" }[$env:APPVEYOR_BUILD_NUMBER -ne $NULL]; |
14 |
| -$suffix = @{ $true = ""; $false = "$($branch.Substring(0, [math]::Min(10,$branch.Length)))-$revision"}[$branch -eq "main" -and $revision -ne "local"] |
15 |
| -$commitHash = $(git rev-parse --short HEAD) |
16 |
| -$buildSuffix = @{ $true = "$($suffix)-$($commitHash)"; $false = "$($branch)-$($commitHash)" }[$suffix -ne ""] |
| 20 | + Write-Output "build: Package version prefix is $versionPrefix" |
17 | 21 |
|
18 |
| -echo "build: Package version suffix is $suffix" |
19 |
| -echo "build: Build version suffix is $buildSuffix" |
| 22 | + $branch = @{ $true = $env:CI_TARGET_BRANCH; $false = $(git symbolic-ref --short -q HEAD) }[$NULL -ne $env:CI_TARGET_BRANCH]; |
| 23 | + $revision = @{ $true = "{0:00000}" -f [convert]::ToInt32("0" + $env:CI_BUILD_NUMBER, 10); $false = "local" }[$NULL -ne $env:CI_BUILD_NUMBER]; |
| 24 | + $suffix = @{ $true = ""; $false = "$($branch.Substring(0, [math]::Min(10,$branch.Length)) -replace '([^a-zA-Z0-9\-]*)', '')-$revision"}[$branch -eq "main" -and $revision -ne "local"] |
| 25 | + $commitHash = $(git rev-parse --short HEAD) |
| 26 | + $buildSuffix = @{ $true = "$($suffix)-$($commitHash)"; $false = "$($branch)-$($commitHash)" }[$suffix -ne ""] |
20 | 27 |
|
21 |
| -foreach ($src in ls src/*) { |
22 |
| - Push-Location $src |
| 28 | + Write-Output "build: Package version suffix is $suffix" |
| 29 | + Write-Output "build: Build version suffix is $buildSuffix" |
23 | 30 |
|
24 |
| - echo "build: Packaging project in $src" |
| 31 | + & dotnet build -c Release --version-suffix=$buildSuffix /p:ContinuousIntegrationBuild=true |
| 32 | + if($LASTEXITCODE -ne 0) { throw "Build failed" } |
25 | 33 |
|
26 |
| - & dotnet build -c Release --version-suffix=$buildSuffix |
27 |
| - if($LASTEXITCODE -ne 0) { exit 1 } |
| 34 | + foreach ($src in Get-ChildItem src/*) { |
| 35 | + Push-Location $src |
28 | 36 |
|
29 |
| - if ($suffix) { |
30 |
| - & dotnet pack -c Release --include-symbols -o ..\..\artifacts --version-suffix=$suffix --no-build |
31 |
| - } else { |
32 |
| - & dotnet pack -c Release --include-symbols -o ..\..\artifacts --no-build |
| 37 | + Write-Output "build: Packaging project in $src" |
| 38 | + |
| 39 | + if ($suffix) { |
| 40 | + & dotnet pack -c Release --no-build --no-restore -o ../../artifacts --version-suffix=$suffix |
| 41 | + } else { |
| 42 | + & dotnet pack -c Release --no-build --no-restore -o ../../artifacts |
| 43 | + } |
| 44 | + if($LASTEXITCODE -ne 0) { throw "Packaging failed" } |
| 45 | + |
| 46 | + Pop-Location |
33 | 47 | }
|
34 |
| - if($LASTEXITCODE -ne 0) { exit 1 } |
35 | 48 |
|
36 |
| - Pop-Location |
37 |
| -} |
| 49 | + foreach ($test in Get-ChildItem test/*.Tests) { |
| 50 | + Push-Location $test |
38 | 51 |
|
39 |
| -foreach ($test in ls test/*.Tests) { |
40 |
| - Push-Location $test |
| 52 | + Write-Output "build: Testing project in $test" |
41 | 53 |
|
42 |
| - echo "build: Testing project in $test" |
| 54 | + & dotnet test -c Release --no-build --no-restore |
| 55 | + if($LASTEXITCODE -ne 0) { throw "Testing failed" } |
43 | 56 |
|
44 |
| - & dotnet test -c Release |
45 |
| - if($LASTEXITCODE -ne 0) { exit 3 } |
| 57 | + Pop-Location |
| 58 | + } |
| 59 | + |
| 60 | + if ($env:NUGET_API_KEY) { |
| 61 | + # GitHub Actions will only supply this to branch builds and not PRs. We publish |
| 62 | + # builds from any branch this action targets (i.e. main and dev). |
| 63 | + |
| 64 | + Write-Output "build: Publishing NuGet packages" |
| 65 | + |
| 66 | + foreach ($nupkg in Get-ChildItem artifacts/*.nupkg) { |
| 67 | + & dotnet nuget push -k $env:NUGET_API_KEY -s https://api.nuget.org/v3/index.json "$nupkg" |
| 68 | + if($LASTEXITCODE -ne 0) { throw "Publishing failed" } |
| 69 | + } |
46 | 70 |
|
| 71 | + if (!($suffix)) { |
| 72 | + Write-Output "build: Creating release for version $versionPrefix" |
| 73 | + |
| 74 | + iex "gh release create v$versionPrefix --title v$versionPrefix --generate-notes $(get-item ./artifacts/*.nupkg) $(get-item ./artifacts/*.snupkg)" |
| 75 | + } |
| 76 | + } |
| 77 | +} finally { |
47 | 78 | Pop-Location
|
48 | 79 | }
|
49 |
| - |
50 |
| -Pop-Location |
|
0 commit comments