-
-
Notifications
You must be signed in to change notification settings - Fork 163
/
azure-pipelines.yml
131 lines (123 loc) · 3.44 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
# ASP.NET Core (.NET Framework)
# Build and test ASP.NET Core projects targeting the full .NET Framework.
# Add steps that publish symbols, save build artifacts, and more:
# https://docs.microsoft.com/azure/devops/pipelines/languages/dotnet-core
trigger:
branches:
include:
- release/*
- develop
- master
tags:
include:
- v*
pr:
branches:
include:
- '*' # must quote since "*" is a YAML reserved character; we want a string
variables:
solution: FubarDev.FtpServer.sln
buildPlatform: 'Any CPU'
buildConfiguration: Release
jobs:
- job: prepare
displayName: Setting the build number
steps:
- task: UseGitVersion@5
inputs:
versionSpec: '5.0.2-beta1.130'
includePrerelease: true
updateAssemblyInfo: false
env:
BUILD_BUILDNUMBER: $(GitVersion.FullSemVer)
- job: pack
displayName: Build and create NuGet packages
dependsOn: prepare
condition: and(succeeded(), not(eq(variables['Build.Reason'], 'PullRequest')))
pool:
vmImage: 'windows-latest'
steps:
- task: DotNetCoreCLI@2
inputs:
command: 'restore'
projects: '$(solution)'
feedsToUse: 'select'
verbosityRestore: 'Normal'
- task: VSBuild@1
inputs:
solution: '$(solution)'
platform: '$(buildPlatform)'
configuration: '$(buildConfiguration)'
msbuildArgs: '/p:Version="$(build.buildNumber)"'
- task: BuildQualityChecks@6
inputs:
checkWarnings: true
warningFailOption: 'build'
allowWarningVariance: true
warningVariance: '5'
showStatistics: true
includePartiallySucceeded: false
warningTaskFilters: '/^vsbuild/i'
warningFilters: |
/##\[warning\].+CS.+:/i
/##\[warning\].+SA.+:/i
- task: DotNetCoreCLI@2
inputs:
command: custom
custom: pack
arguments: $(solution) --output $(Build.ArtifactStagingDirectory) --include-symbols /p:Configuration=$(buildConfiguration) /p:Version=$(build.buildNumber) --verbosity Minimal
- publish: $(Build.ArtifactStagingDirectory)
artifact: packages
- job: build
displayName: Build the solution
dependsOn: prepare
condition: and(succeeded(), eq(variables['Build.Reason'], 'PullRequest'))
pool:
vmImage: 'windows-latest'
steps:
- task: DotNetCoreCLI@2
inputs:
command: 'restore'
projects: '$(solution)'
feedsToUse: 'select'
verbosityRestore: 'Normal'
- task: VSBuild@1
inputs:
solution: '$(solution)'
platform: '$(buildPlatform)'
configuration: '$(buildConfiguration)'
msbuildArgs: '/p:Version="$(build.buildNumber)"'
- task: BuildQualityChecks@6
inputs:
checkWarnings: true
warningFailOption: 'build'
allowWarningVariance: true
warningVariance: '5'
showStatistics: true
includePartiallySucceeded: false
warningTaskFilters: '/^vsbuild/i'
warningFilters: |
/##\[warning\].+CS.+:/i
/##\[warning\].+SA.+:/i
- job: test
displayName: Running the tests
dependsOn: prepare
variables:
buildConfiguration: 'Debug'
steps:
- task: DotNetCoreCLI@2
inputs:
command: 'test'
projects: 'test/FubarDev.FtpServer.Tests/FubarDev.FtpServer.Tests.csproj'
- job: tagRelease
displayName: Tagging the build
dependsOn:
- test
- pack
condition: and(succeeded(), startsWith(variables['Build.SourceBranch'], 'refs/tags/v'))
steps:
- checkout: none
- task: tagBuildOrRelease@0
inputs:
type: 'Build'
tags: 'release'