Migrate your Classic pipeline to YAML
Azure DevOps Services
Get started with Azure Pipelines by converting your existing Classic pipeline to use YAML. With a YAML-based pipeline, you can implement your CI/CD strategy as code and see its history, compare versions, blame, annotate, and so on.
When you convert your Classic pipeline, the end product is two pipelines. You'll have one new YAML pipeline and a Classic pipeline that can be retired. Your Classic pipeline's run history remains in the Classic pipeline.
Note
You can only export a YAML file from an existing Classic pipeline created with the classic build designer. If you don't see the option to export to JSON or YAML, then your pipeline doesn't support exporting. Classic release pipelines don't have the export to YAML option. You can export a classic release pipeline by exporting each individual task.
Prerequisites
Make sure you have the following items before you begin.
- An Azure account with an active subscription. Create an account for free.
- An active Azure DevOps organization. Sign up for Azure Pipelines.
- A working pipeline that uses the Classic user interface (UI) editor.
- A sample YAML pipeline file in your code. Create a sample YAML pipeline in the following section.
Create a sample YAML pipeline
Do the following steps to create a sample YAML pipeline, which you'll update later with your exported code from the Classic UI editor.
Sign in to your organization (
https://dev.azure.com/{yourorganization}
) and select your project.Select Pipelines, and then New pipeline.
Select the location for your source code as either GitHub or Azure Repos Git.
Select a repository.
On the Configure your pipeline page, select Starter pipeline.
Select Save and run.
Enter your commit message, select Commit directly to the main branch, and then choose Save and run again. A new run starts and it's committed to the repository. Wait for the run to finish.
Export your Classic pipeline
Sign in to your Azure DevOps organization, and then go to your project.
Select Pipelines > Pipelines.
Select your Classic pipeline definition, select the ellipses icon, and then select Export to YAML. Make sure you're in the pipeline definition view, not a specific run, to see the Export to YAML option.
Open the downloaded YAML file in your code editor.
If your YAML pipeline includes variables defined in the Classic UI, define the variables again in your pipeline settings UI or in your YAML file. For more information, see Define variables.
Review any
cron
schedules in your YAML file. By default,cron
schedules in YAML are in UTC. In Classic pipelines, they are in the organization's timezone. For more information, see Configure schedules for pipelines.Use the Task Assistant to make any other changes to the YAML file. The Task Assistant is a pane on the right side of the screen, which helps you correctly create and modify YAML steps.
Save and run your pipeline.
Clean up resources
If you're not going to use this sample pipeline anymore, delete it from your project. Deletion is permanent and includes all builds and associated artifacts.
Select the ellipses (...) and select Delete.
Enter the name of your pipeline to permanently delete it, and then select Delete.
FAQ
Is there a task in YAML pipelines to create work items when there's a build failure?
YAML pipelines don't have a Create work item on failure setting like classic build pipelines. You have a couple of options for creating this functionality yourself.
- You can use a script or PowerShell task and call the REST API.
- You can use Azure CLI to call az boards work-item create in your pipeline. See an example of using the CLI to create a bug on failure.
Next steps
Learn about the feature differences between YAML and Classic pipelines.