-
-
Notifications
You must be signed in to change notification settings - Fork 5
/
azure-pipelines.yml
142 lines (121 loc) · 3.19 KB
/
azure-pipelines.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
# Copyright (c) .NET Foundation and Contributors
# See LICENSE file in the project root for full license information.
trigger:
branches:
include:
- main
- develop
- release-*
paths:
exclude:
- .github_changelog_generator
- .gitignore
- CHANGELOG.md
- CODE_OF_CONDUCT.md
- LICENSE.md
- README.md
- NuGet.Config
- assets/*
- config/*
- .github/*
# PR always trigger build
pr:
autoCancel: true
# add nf-tools repo to resources (for Azure Pipelines templates)
resources:
repositories:
- repository: templates
type: github
name: nanoframework/nf-tools
endpoint: nanoframework
jobs:
##############################
- job: Build_Library
condition: >-
or(
eq(variables['UPDATE_DEPENDENTS'], 'false'),
eq(variables['StartReleaseCandidate'], 'true')
)
pool:
vmImage: 'windows-latest'
variables:
- group: sign-client-credentials
- name: DOTNET_NOLOGO
value: true
- name: buildPlatform
value: 'Any CPU'
- name: buildConfiguration
value: 'Release'
- name: solution
value: 'nanoFramework.System.Text.sln'
- name: nugetPackageName
value: 'nanoFramework.System.Text'
steps:
# step from template @ nf-tools repo
# all build, update and publish steps
- template: azure-pipelines-templates/class-lib-build.yml@templates
parameters:
sonarCloudProject: 'nanoframework_lib-nanoFramework.System.Text'
runUnitTests: true
unitTestRunsettings: '$(System.DefaultWorkingDirectory)\.runsettings'
##############################
- job: Update_Dependents
condition: >-
or(
and(
succeeded(),
startsWith(variables['Build.SourceBranch'], 'refs/heads/main'),
eq(variables['StartReleaseCandidate'], 'false')
),
and(
succeeded(),
contains(variables['getCommitMessage.COMMIT_MESSAGE'], '***UPDATE_DEPENDENTS***'),
eq(variables['StartReleaseCandidate'], 'false')
),
eq(variables['UPDATE_DEPENDENTS'], 'true')
)
dependsOn:
- Build_Library
pool:
vmImage: 'windows-latest'
variables:
DOTNET_NOLOGO: true
steps:
- checkout: none
# update dependents
- template: azure-pipelines-templates/update-dependents.yml@templates
parameters:
${{ if eq(variables['UPDATE_DEPENDENTS'], 'true') }}:
waitBeforeUpdate: false
${{ else }}:
waitBeforeUpdate: true
repositoriesToUpdate: |
nanoFramework.Json
nanoFramework.m2mqtt
System.Net
System.Net.Http
Windows.Storage
Windows.Storage.Streams
System.IO.Streams
##################################
# report build failure to Discord
- job: Report_Build_Failure
condition: >-
or(
failed('Build_Library'),
failed('Update_Dependents')
)
dependsOn:
- Build_Library
- Update_Dependents
pool:
vmImage: 'windows-latest'
steps:
- checkout: self
# step from template @ nf-tools repo
# report error
- template: azure-pipelines-templates/discord-webhook-task.yml@templates
parameters:
status: 'failure'
webhookUrl: '$(DiscordWebhook)'
message: ''