This browser is no longer supported.
Upgrade to Microsoft Edge to take advantage of the latest features, security updates, and technical support.
Download Microsoft Edge
More info about Internet Explorer and Microsoft Edge
Azure DevOps Services | Azure DevOps Server 2022 | Azure DevOps Server 2020
Runtime parameters let you have more control over what values can be passed to a pipeline. With runtime parameters you can:
Supply different values to scripts and tasks at runtime
Control parameter types, ranges allowed, and defaults
Dynamically select jobs and stages with template expressions
You can specify
parameters in templates
and in the pipeline. Parameters have data types such as number and string, and they can be restricted to a subset of values. The
parameters
section in a YAML defines what parameters are available.
Parameters are only available at template parsing time. Parameters are expanded just before the pipeline runs so that values surrounded by
${{ }}
are replaced with parameter values. Use
variables
if you need your values to be more widely available during your
pipeline run
.
This guidance does not apply to classic pipelines. For parameters in classic pipelines, see
Process parameters (classic)
.
Parameters must contain a name and data type. Parameters can't be optional. A default value needs to be assigned in your YAML file or when you run your pipeline. If you don't assign a default value or set
default
to
false
, the first available value is used.
Use
templateContext
to pass extra properties to stages, steps, and jobs that are used as parameters in a template.
Use parameters in pipelines
Set runtime parameters at the beginning of a YAML.
This example pipeline includes an
image
parameter with three hosted agents as
string
options. In the jobs section, the
pool
value specifies the agent from the parameter used to run the job. The
trigger
is set to none so that you can select the value of
image
when you manually trigger your pipeline to run.
parameters:
- name: image
displayName: Pool Image
type: string
default: ubuntu-latest
values:
- windows-latest
- ubuntu-latest
- macOS-latest
trigger: none
jobs:
- job: build
displayName: build
pool:
vmImage: ${{ parameters.image }}
steps:
- script: echo building $(Build.BuildNumber) with ${{ parameters.image }}
When the pipeline runs, you select the Pool Image. If you don't make a selection, the default option, ubuntu-latest
gets used.
Use conditionals with parameters
You can also use parameters as part of conditional logic. With conditionals, part of a YAML runs if it meets the if
criteria.
Use parameters to determine what steps run
This pipeline adds a second boolean parameter, test
, which can be used to control whether or not to run tests in the pipeline. When the value of test
is true, the step that outputs Running all the tests runs.
parameters:
- name: image
displayName: Pool Image
values:
- windows-latest
- ubuntu-latest
- macOS-latest
- name: test
displayName: Run Tests?
type: boolean
default: false
trigger: none
jobs:
- job: build
displayName: Build and Test
pool:
vmImage: ${{ parameters.image }}
steps:
- script: echo building $(Build.BuildNumber)
- ${{ if eq(parameters.test, true) }}:
- script: echo "Running all the tests"
Use parameters to set what configuration is used
You can also use parameters to set which job runs. In this example, different architectures build depending on the value of config
parameter, which is a string
type. By default, both the x86
and x64
architectures build.
parameters:
- name: configs
type: string
default: 'x86,x64'
trigger: none
jobs:
- ${{ if contains(parameters.configs, 'x86') }}:
- job: x86
steps:
- script: echo Building x86...
- ${{ if contains(parameters.configs, 'x64') }}:
- job: x64
steps:
- script: echo Building x64...
- ${{ if contains(parameters.configs, 'arm') }}:
- job: arm
steps:
- script: echo Building arm...
Selectively exclude a stage
You can also use parameters to set whether a stage runs. In this example, there's a pipeline with four stages and different jobs for each stage. The Performance Test stage runs if the parameter runPerfTests
is true. The default value of runPerfTests
is false so without any updates, only three of the four stages run.
parameters:
- name: runPerfTests
type: boolean
default: false
trigger: none
stages:
- stage: Build
displayName: Build
jobs:
- job: Build
steps:
- script: echo running Build
- stage: UnitTest
displayName: Unit Test
dependsOn: Build
jobs:
- job: UnitTest
steps:
- script: echo running UnitTest
- ${{ if eq(parameters.runPerfTests, true) }}:
- stage: PerfTest
displayName: Performance Test
dependsOn: Build
jobs:
- job: PerfTest
steps:
- script: echo running PerfTest
- stage: Deploy
displayName: Deploy
dependsOn: UnitTest
jobs:
- job: Deploy
steps:
- script: echo running UnitTest
Loop through parameters
You can also loop through your string, number, and boolean parameters.
Script
PowerShell
In this example, you loop through parameters and print the name and value of each parameter. There are four different parameters and each represents a different type. myStringName
is a single-line string. myMultiString
is a multi-line string. myNumber
is a number. myBoolean
is a boolean value. In the steps section, the script tasks output the key and value of each parameter.
# start.yaml
parameters:
- name: myStringName
type: string
default: a string value
- name: myMultiString
type: string
default: default
values:
- default
- ubuntu
- name: myNumber
type: number
default: 2
values:
- name: myBoolean
type: boolean
default: true
steps:
- ${{ each parameter in parameters }}:
- script: echo ${{ parameter.Key }}
- script: echo ${{ parameter.Value }}
# azure-pipeline.yaml
trigger: none
extends:
template: start.yaml
In this example, you loop through parameters and print the name and value of each parameter. There are four different parameters and each represents a different type. myStringName
is a single-line string. myMultiString
is a multi-line string. myNumber
is a number. myBoolean
is a boolean value. In the steps section, you loop through parameters in a PowerShell task and set each parameter as an environment variable.
# start.yaml
parameters:
- name: myStringName
type: string
default: a string value
- name: myMultiString
type: string
default: default
values:
- default
- ubuntu
- name: myNumber
type: number
default: 2
values:
- name: myBoolean
type: boolean
default: true
steps:
- task: PowerShell@2
${{ each parameter in parameters }}:
${{ parameter.Key }}: ${{ parameter.Value }}
inputs:
filePath: test_script.ps1
pwsh: true
# azure-pipeline.yaml
trigger: none
extends:
template: start.yaml
# test_script.ps1
Write-Host "Hello, World!"
Write-Host $env:myStringName
Check for an empty parameter object
You can use the length()
expression to check whether an object parameter has no value.
parameters:
- name: foo
type: object
default: []
steps:
- checkout: none
- ${{ if eq(length(parameters.foo), 0) }}:
- script: echo Foo is empty
displayName: Foo is empty
Parameter data types
Data type
Notes
The step, stepList, job, jobList, deployment, deploymentList, stage, and stageList data types all use standard YAML schema format. This example includes string, number, boolean, object, step, and stepList.
parameters:
- name: myString
type: string
default: a string
- name: myMultiString
type: string
default: default
values:
- default
- ubuntu
- name: myNumber
type: number
default: 2
values:
- name: myBoolean
type: boolean
default: true
- name: myObject
type: object
default:
foo: FOO
bar: BAR
things:
- one
- two
- three
nested:
one: apple
two: pear
count: 3
- name: myStep
type: step
default:
script: echo my step
- name: mySteplist
type: stepList
default:
- script: echo step one
- script: echo step two
trigger: none
jobs:
- job: stepList
steps: ${{ parameters.mySteplist }}
- job: myStep
steps:
- ${{ parameters.myStep }}