forked from NuGet/NuGet.Client
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathbuild.ps1
More file actions
175 lines (144 loc) · 5.94 KB
/
build.ps1
File metadata and controls
175 lines (144 loc) · 5.94 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
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
[CmdletBinding(DefaultParameterSetName='RegularBuild')]
param (
[ValidateSet("debug", "release")]
[string]$Configuration = 'debug',
[ValidateSet("release","rtm", "rc", "rc1", "beta", "beta1", "beta2", "final", "xprivate", "zlocal")]
[string]$ReleaseLabel = 'zlocal',
[int]$BuildNumber,
[switch]$SkipRestore,
[switch]$CleanCache,
[string]$MSPFXPath,
[string]$NuGetPFXPath,
[switch]$SkipXProj,
[switch]$SkipVS14,
[switch]$SkipVS15,
[Parameter(ParameterSetName='RegularBuild')]
[switch]$SkipSubModules,
[Parameter(ParameterSetName='RegularBuild')]
[switch]$SkipTests,
[Parameter(ParameterSetName='RegularBuild')]
[switch]$SkipILMerge,
[Parameter(ParameterSetName='FastBuild')]
[switch]$Fast
)
# For TeamCity - Incase any issue comes in this script fail the build. - Be default TeamCity returns exit code of 0 for all powershell even if it fails
trap {
if ($env:TEAMCITY_VERSION) {
Write-Host "##teamcity[buildProblem description='$(Format-TeamCityMessage($_.ToString()))']"
}
Write-Host "BUILD FAILED: $_" -ForegroundColor Red
Write-Host "ERROR DETAILS:" -ForegroundColor Red
Write-Host $_.Exception -ForegroundColor Red
Write-Host ("`r`n" * 3)
exit 1
}
function Format-TeamCityMessage([string]$Text) {
$Text.Replace("|", "||").Replace("'", "|'").Replace("[", "|[").Replace("]", "|]").Replace("`n", "|n").Replace("`r", "|r")
}
$CLIRoot=$PSScriptRoot
$env:DOTNET_INSTALL_DIR=$CLIRoot
. "$PSScriptRoot\build\common.ps1"
$RunTests = (-not $SkipTests) -and (-not $Fast)
# Adjust version skipping if only one version installed - if VS15 is not installed, no need to specify SkipVS15
$VS14Installed = Test-MSBuildVersionPresent -MSBuildVersion "14"
$SkipVS14 = $SkipVS14 -or -not $VS14Installed
$VS15Installed = Test-MSBuildVersionPresent -MSBuildVersion "15"
$SkipVS15 = $SkipVS15 -or -not $VS15Installed
Write-Host ("`r`n" * 3)
Trace-Log ('=' * 60)
$startTime = [DateTime]::UtcNow
if (-not $BuildNumber) {
$BuildNumber = Get-BuildNumber
}
Trace-Log "Build #$BuildNumber started at $startTime"
$BuildErrors = @()
Invoke-BuildStep 'Updating sub-modules' { Update-SubModules } `
-skip:($SkipSubModules -or $Fast) `
-ev +BuildErrors
Invoke-BuildStep 'Cleaning artifacts' { Clear-Artifacts } `
-skip:$SkipXProj `
-ev +BuildErrors
Invoke-BuildStep 'Cleaning nupkgs' { Clear-Nupkgs } `
-skip:$SkipXProj `
-ev +BuildErrors
Invoke-BuildStep 'Installing NuGet.exe' { Install-NuGet } `
-ev +BuildErrors
Invoke-BuildStep 'Cleaning package cache' { Clear-PackageCache } `
-skip:(-not $CleanCache) `
-ev +BuildErrors
Invoke-BuildStep 'Installing dotnet CLI' { Install-DotnetCLI } `
-ev +BuildErrors
# Restoring tools required for build
Invoke-BuildStep 'Restoring solution packages' { Restore-SolutionPackages } `
-skip:$SkipRestore `
-ev +BuildErrors
Invoke-BuildStep 'Enabling delayed signing' {
param($MSPFXPath, $NuGetPFXPath)
Enable-DelaySigning $MSPFXPath $NuGetPFXPath
} `
-args $MSPFXPath, $NuGetPFXPath `
-skip:((-not $MSPFXPath) -and (-not $NuGetPFXPath)) `
-ev +BuildErrors
Invoke-BuildStep 'Building NuGet.Core projects' {
param($Configuration, $ReleaseLabel, $BuildNumber, $SkipRestore, $Fast)
Build-CoreProjects $Configuration $ReleaseLabel $BuildNumber -SkipRestore:$SkipRestore -Fast:$Fast
} `
-args $Configuration, $ReleaseLabel, $BuildNumber, $SkipRestore, $Fast `
-skip:$SkipXProj `
-ev +BuildErrors
## Building the VS15 Tooling solution
Invoke-BuildStep 'Building NuGet.Clients projects - VS15 dependencies' {
param($Configuration, $ReleaseLabel, $BuildNumber, $SkipRestore, $Fast)
Build-ClientsProjects $Configuration $ReleaseLabel $BuildNumber -MSBuildVersion "15" -SkipRestore:$SkipRestore -Fast:$Fast
} `
-args $Configuration, $ReleaseLabel, $BuildNumber, $SkipRestore, $Fast `
-skip:$SkipVS15 `
-ev +BuildErrors
## Building the VS14 Tooling solution
Invoke-BuildStep 'Building NuGet.Clients projects - VS14 dependencies' {
param($Configuration, $ReleaseLabel, $BuildNumber, $SkipRestore, $Fast)
Build-ClientsProjects $Configuration $ReleaseLabel $BuildNumber -MSBuildVersion "14" -SkipRestore:$SkipRestore -Fast:$Fast
} `
-args $Configuration, $ReleaseLabel, $BuildNumber, $SkipRestore, $Fast `
-skip:$SkipVS14 `
-ev +BuildErrors
## ILMerge the VS14 exe only
Invoke-BuildStep 'Merging NuGet.exe' {
param($Configuration, $MSPFXPath)
Invoke-ILMerge $Configuration "14" $MSPFXPath
} `
-args $Configuration, $MSPFXPath `
-skip:($SkipILMerge -or $Fast -or $SkipVS14) `
-ev +BuildErrors
Invoke-BuildStep 'Running NuGet.Core tests' {
Test-CoreProjects -Configuration $Configuration
} `
-args $Configuration `
-skip:(-not $RunTests) `
-ev +BuildErrors
Invoke-BuildStep 'Running NuGet.Clients tests - VS15 dependencies' {
param($Configuration)
# We don't run command line tests on VS15 as we don't build a nuget.exe for this version
Test-ClientsProjects -Configuration $Configuration -MSBuildVersion "15" -SkipProjects 'NuGet.CommandLine.Test'
} `
-args $Configuration `
-skip:((-not $RunTests) -or $SkipVS15) `
-ev +BuildErrors
Invoke-BuildStep 'Running NuGet.Clients tests - VS14 dependencies' {
param($Configuration)
Test-ClientsProjects -Configuration $Configuration -MSBuildVersion "14"
} `
-args $Configuration `
-skip:((-not $RunTests) -or $SkipVS14) `
-ev +BuildErrors
Trace-Log ('-' * 60)
## Calculating Build time
$endTime = [DateTime]::UtcNow
Trace-Log "Build #$BuildNumber ended at $endTime"
Trace-Log "Time elapsed $(Format-ElapsedTime ($endTime - $startTime))"
Trace-Log ('=' * 60)
if ($BuildErrors) {
$ErrorLines = $BuildErrors | %{ ">>> $($_.Exception.Message)" }
Write-Error "Build's completed with $($BuildErrors.Count) error(s):`r`n$($ErrorLines -join "`r`n")" -ErrorAction Stop
}
Write-Host ("`r`n" * 3)