forked from dotnet/dotnet-monitor
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdotnet-monitor.yml
162 lines (150 loc) · 5.46 KB
/
dotnet-monitor.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
trigger: none
pr:
autoCancel: true
branches:
include:
- main
- release/*
- internal/release/*
- feature/*
paths:
exclude:
- .devcontainer
- .github
- .vscode
- .gitignore
- cspell.json
- eng/actions
- samples
- '**.md'
schedules:
# Schedule before docker update pipeline
- cron: "0 3 * * Mon-Fri"
displayName: M-F Scheduled Build
branches:
include:
- main
parameters:
- name: testGroup
displayName: 'Test Group'
type: string
default: Default
values:
- Default
- All
- None
- CI
- PR
- name: updateDocker
displayName: 'Update dotnet-docker? (Only for release branches)'
type: boolean
default: false
- name: useHelix
displayName: Use Helix Testing
type: boolean
default: true
variables:
- template: /eng/common/templates/variables/pool-providers.yml
- name: _TeamName
value: DotNetCore
- name: _TPNFile
value: THIRD-PARTY-NOTICES.TXT
- ${{ if and(ne(variables['System.TeamProject'], 'public'), notin(variables['Build.Reason'], 'PullRequest')) }}:
# DotNet-Diagnostics-SDL-Params provides Tsa* variables for SDL checks.
- group: DotNet-Diagnostics-SDL-Params
stages:
- stage: Build
displayName: Build and Test
jobs:
- ${{ if and(ne(variables['System.TeamProject'], 'public'), notin(variables['Build.Reason'], 'PullRequest')) }}:
# Generate a TPN for only the dotnet-monitor project
- template: /eng/pipelines/jobs/tpn.yml
# Build and (optionally) test binaries
- template: /eng/pipelines/jobs/platform-matrix.yml
parameters:
jobTemplate: /eng/pipelines/jobs/build-binaries.yml
includeArm64: ${{ or(ne(variables['System.TeamProject'], 'public'), eq(parameters.useHelix, 'true')) }}
includeDebug: true
jobParameters:
publishBinaries: true
publishArtifacts: ${{ and(ne(variables['System.TeamProject'], 'public'), notin(variables['Build.Reason'], 'PullRequest')) }}
- ${{ if ne(parameters.testGroup, 'None') }}:
- template: /eng/pipelines/jobs/platform-matrix.yml
parameters:
jobTemplate: /eng/pipelines/jobs/test-binaries.yml
includeArm64: ${{ parameters.useHelix }}
jobParameters:
testGroup: ${{ parameters.testGroup }}
useHelix: ${{ parameters.useHelix }}
- ${{ if and(ne(variables['System.TeamProject'], 'public'), notin(variables['Build.Reason'], 'PullRequest')) }}:
- stage: Archive
displayName: Archive
dependsOn:
- Build
jobs:
# Sign binaries before archiving
- template: /eng/pipelines/jobs/sign-binaries.yml
# Build RID (runtime identifier) archives
- template: /eng/pipelines/jobs/platform-matrix.yml
parameters:
jobTemplate: /eng/pipelines/jobs/build-archive.yml
includeArm64: true
# This stage creates NuGet packages and generates the BAR manifests
- ${{ if and(ne(variables['System.TeamProject'], 'public'), notin(variables['Build.Reason'], 'PullRequest')) }}:
- stage: PackSignPublish
displayName: Pack, Sign, and Generate Manifests
dependsOn:
- Archive
jobs:
# Pack, sign, and publish manifest
- template: /eng/pipelines/jobs/pack-sign-publish.yml
# Register with BAR
- template: /eng/common/templates/job/publish-build-assets.yml
parameters:
configuration: Release
dependsOn:
- Pack_Sign
publishUsingPipelines: true
pool:
name: $(DncEngInternalBuildPool)
demands: ImageOverride -equals 1es-windows-2019
# These are the stages that perform validation of several SDL requirements and publish the bits required to the designated feed.
- template: /eng/common/templates/post-build/post-build.yml
parameters:
# This is to enable SDL runs part of Post-Build Validation Stage.
# as well as NuGet, SourceLink, and signing validation.
# The variables get imported from group dotnet-diagnostics-sdl-params
validateDependsOn:
- PackSignPublish
publishingInfraVersion: 3
enableSourceLinkValidation: ${{ and(not(startsWith(variables['Build.SourceBranch'], 'refs/heads/internal/release/')), not(startsWith(variables['Build.SourceBranch'], 'refs/heads/test/release/'))) }}
enableSigningValidation: true
enableSymbolValidation: false
enableNugetValidation: true
publishInstallersAndChecksums: true
SDLValidationParameters:
enable: true
continueOnError: true
publishGdn: true
params: >-
-SourceToolsList @("policheck","credscan")
-TsaInstanceURL $(_TsaInstanceURL)
-TsaProjectName $(_TsaProjectName)
-TsaNotificationEmail $(_TsaNotificationEmail)
-TsaCodebaseAdmin $(_TsaCodebaseAdmin)
-TsaBugAreaPath $(_TsaBugAreaPath)
-TsaIterationPath $(_TsaIterationPath)
-TsaRepositoryName "dotnet-monitor"
-TsaCodebaseName "dotnet-monitor"
-TsaPublish $True
-PoliCheckAdditionalRunConfigParams @("UserExclusionPath < $(Build.SourcesDirectory)/eng/PoliCheckExclusions.xml")
artifactNames:
- 'PackageArtifacts'
# This sets up the bits to do a Release.
- template: /eng/pipelines/stages/preparerelease.yml
parameters:
${{ if eq(parameters.updateDocker, 'true') }}:
updateDockerCondition: true
${{ else }}:
# If scheduled build from main and nightly update from main enabled
updateDockerCondition: and(eq(variables['Build.SourceBranch'], 'refs/heads/main'), eq(variables['Build.Reason'], 'Schedule'), eq(variables['NightlyUpdateDockerFromMain'], 'true'))