Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
Azure DevOps Services | Azure DevOps Server | Azure DevOps Server 2022 | Azure DevOps Server 2020
This article explains the sequence of activities in Azure Pipelines pipeline runs. A run represents one execution of a pipeline. Both continuous integration (CI) and continuous delivery (CD) pipelines consist of runs. During a run, Azure Pipelines processes the pipeline, and agents process one or more jobs, steps, and tasks.

For each run, Azure Pipelines:
- Processes the pipeline
- Requests one or more agents to run jobs
- Hands off jobs to agents and collects the results
For each job, an agent:
- Prepares for the job
- Runs each step in the job
- Reports results
Jobs can succeed, fail, be canceled, or not complete. Understanding these outcomes helps you troubleshoot issues.
The following sections describe the pipeline run process in detail.
Pipeline processing

To process a pipeline for a run, Azure Pipelines first:
- Expands templates and evaluates template expressions.
- Evaluates dependencies at the stage level to pick the first stage to run.
For each stage it selects to run, Azure Pipelines:
- Gathers and validates all job resources for authorization to run.
- Evaluates dependencies at the job level to pick the first job to run.
Azure Pipelines does the following activities for each job it selects to run:
- Expands YAML strategy: matrixorstrategy: parallelmulti-configurations into multiple runtime jobs.
- Evaluates conditions to decide whether the job is eligible to run.
- Requests an agent for each eligible job.
As runtime jobs complete, Azure Pipelines checks whether there are new jobs eligible to run. Similarly, as stages complete, Azure Pipelines checks if there are any more stages.
Variables
Understanding the processing order clarifies why you can't use certain variables in template parameters. The first template expansion step operates only on the text of the YAML file. Runtime variables don't yet exist during that step. After that step, template parameters are already resolved.
You can't use variables to resolve service connection or environment names, because the pipeline authorizes resources before a stage starts running. Stage- and job-level variables aren't available yet. Variable groups are themselves a resource subject to authorization, so their data isn't available when checking resource authorization.
You can use pipeline-level variables that are explicitly included in the pipeline resource definition. For more information, see Pipeline resource metadata as predefined variables.
Agents
Azure Pipelines requests an agent from the pool to run a job. The process differs for Microsoft-hosted and self-hosted agent pools.
Note
Server jobs don't use a pool because they run on the Azure Pipelines server itself.

Parallel jobs
First, Azure Pipelines checks on your organization's parallel jobs. The service adds up all running jobs on all agents and compares that with the number of parallel jobs granted or purchased.
If there are no available parallel slots, the job has to wait on a slot to free up. Once a parallel slot is available, the job routes to the appropriate agent type.
Microsoft-hosted agents
The Microsoft-hosted pool is conceptually one global pool of machines, but it's physically divided into multiple pools by geography and operating system type. Based on the YAML vmImage or Classic editor pool name requested, Azure Pipelines selects an agent.
All agents in the Microsoft pool are fresh, new virtual machines (VMs) that have never run any pipelines. When the job completes, the agent VM is discarded.
Self-hosted agents
Once a parallel slot is available, Azure Pipelines examines the self-hosted pool for a compatible agent. Self-hosted agents offer capabilities, which indicate that particular software is installed or settings configured. The pipeline has demands, which are the capabilities required to run the job.
If Azure Pipelines can't find a free agent whose capabilities match the pipeline's demands, the job continues waiting. If there are no agents in the pool whose capabilities match the demands, the job fails.
Self-hosted agents are typically reused from run to run. For self-hosted agents, a pipeline job can have side effects, such as warming up caches or having most commits already available in the local repo.
Job preparation
Once an agent accepts a job, it does the following preparation work:
- Downloads all the tasks needed to run the job and caches them for future use.
- Creates working space on disk to hold the source code, artifacts, and outputs used in the run.
Step execution
The agent runs steps sequentially. Before a step starts, all previous steps must finish or be skipped.

Steps are implemented by tasks, which can be Node.js, PowerShell, or other scripts. The task system routes inputs and outputs to the backing scripts. Tasks also provide common services such as altering the system path and creating new pipeline variables.
Each step runs in its own process, isolating its environment from previous steps. Because of this process-per-step model, environment variables aren't preserved between steps. However, tasks and scripts can use a mechanism called logging commands to communicate back to the agent. When a task or script writes a logging command to standard output, the agent takes whatever action the command requests.
You can use a logging command to create new pipeline variables. Pipeline variables automatically convert into environment variables in the next step. A script can set a new variable myVar with a value of myValue as follows:
echo '##vso[task.setVariable variable=myVar]myValue'
Write-Host "##vso[task.setVariable variable=myVar]myValue"
Result reporting and collection
Each step can report warnings, errors, and failures. The step reports errors and warnings on the pipeline summary page by marking the tasks as succeeded with issues, or reports failures by marking the task as failed. A step fails if it either explicitly reports failure by using a ##vso command or ends the script with a nonzero exit code.
As steps run, the agent constantly sends output lines to Azure Pipelines, so you can see a live feed of the console. At the end of each step, the entire output from the step is uploaded as a log file. You can download the log once the pipeline finishes.

The agent can also upload artifacts and test results, which are also available after the pipeline completes.
State and conditions
The agent keeps track of each step's success or failure. As steps succeed or fail with issues, the job's status is updated. The job always reflects the worst outcome from each of its steps. If a step fails, the job also fails.
Before the agent runs a step, it checks that step's condition to determine whether the step should run. By default, a step only runs when the job's status is succeeded or succeeded with issues, but you can set other conditions.
Many jobs have cleanup steps that need to run no matter what else happens, so they can specify a condition of always(). Cleanup or other steps can also be set to run only on cancellation.
A successful cleanup step doesn't save the job from failing. Jobs can't return to success after failing.
Timeouts and disconnects
Each job has a timeout. If the job doesn't complete in the specified time, the server cancels the job. The server attempts to signal the agent to stop, and marks the job as canceled. On the agent side, cancellation means to cancel all remaining steps and upload any remaining results.
Jobs have a grace period called the cancel timeout in which to complete any cancellation work. You can also mark steps to run even on cancellation. After a job timeout plus a cancel timeout, if the agent doesn't report that work is stopped, the server marks the job as a failure.
Agent machines can stop responding to the server if the agent's host machine loses power or is turned off, or if there's a network failure. To help detect these conditions, the agent sends a heartbeat message once per minute to let the server know it's still operating.
If the server doesn't receive a heartbeat for five consecutive minutes, it assumes the agent is not coming back. The job is marked as a failure, letting the user know they should retry the pipeline.
Manage runs through the Azure DevOps CLI
You can manage pipeline runs by using az pipelines runs in the Azure DevOps CLI. To get started, see Get started with Azure DevOps CLI. For a complete command reference, see Azure DevOps CLI command reference.
The following examples show how to use the Azure DevOps CLI to list the pipeline runs in your project, view details about a specific run, and manage tags for pipeline runs.
Prerequisites
- Azure CLI with the Azure DevOps CLI extension installed as described in Get started with Azure DevOps CLI. Sign into Azure using az login.
- The default organization set by using az devops configure --defaults organization=<YourOrganizationURL>.
List pipeline runs
List the pipeline runs in your project with the az pipelines runs list command.
This command lists the first three pipeline runs with a status of completed and a result of succeeded, and shows the result in table format.
az pipelines runs list --status completed --result succeeded --top 3 --output table
Run ID    Number      Status     Result     Pipeline ID    Pipeline Name               Source Branch    Queued Time                 Reason
--------  ----------  ---------  ---------  -------------  --------------------------  ---------------  --------------------------  ------
125       20200124.1  completed  succeeded  12             Githubname.pipelines-java  master           2020-01-23 18:56:10.067588  manual
123       20200123.2  completed  succeeded  12             Githubname.pipelines-java  master           2020-01-23 11:55:56.633450  manual
122       20200123.1  completed  succeeded  12             Githubname.pipelines-java  master           2020-01-23 11:48:05.574742  manual
Show pipeline run details
Show the details for a pipeline run in your project with the az pipelines runs show command.
This command shows details for the pipeline run with ID 123, displays the results in table format, and opens your web browser to the Azure Pipelines build results page.
az pipelines runs show --id 122 --open --output table
Run ID    Number      Status     Result     Pipeline ID    Pipeline Name               Source Branch    Queued Time                 Reason
--------  ----------  ---------  ---------  -------------  --------------------------  ---------------  --------------------------  --------
123       20200123.2  completed  succeeded  12             Githubname.pipelines-java  master           2020-01-23 11:55:56.633450  manual
Add tag to pipeline run
Add a tag to a pipeline run in your project with the az pipelines runs tag add command.
The following command adds the tag YAML to the pipeline run with the ID 123 and returns the result in JSON format.
az pipelines runs tag add --run-id 123 --tags YAML --output json
[
  "YAML"
]
List pipeline run tags
List the tags for a pipeline run in your project with the az pipelines runs tag list command. The following command lists the tags for the pipeline run with the ID 123 and returns the result in table format.
az pipelines runs tag list --run-id 123 --output table
Tags
------
YAML
Delete tag from pipeline run
Delete a tag from a pipeline run in your project using the az pipelines runs tag delete command. This command deletes the YAML tag from the pipeline run with ID 123.
az pipelines runs tag delete --run-id 123 --tag YAML
Manage runs with the Azure DevOps MCP Server
You can manage pipeline runs in Copilot with the Azure DevOps MCP server. To get started, see Enable AI assistance with Azure DevOps MCP Server.
List pipeline runs
List the pipeline runs for a particular pipeline.
Show the three most recent runs for the Tailspin pipeline.
This prompt lists the last three pipeline runs with a link to view each run.
Show pipeline run details
Fetch the status of a specific build.
Show the status and details for build 12345678.9.
This prompt returns returns the status, result, start/finish time, and summary for a build.
Start a new pipeline run
Begin a new run of a pipeline.
Start the Tailspin pipeline and provide a direct link to the run, including the project name in the URL.
This prompt starts your pipeline and and provides a link to the pipeline run.