Skip to content

Contact sales

By filling out this form and clicking submit, you acknowledge our privacy policy.

Schedule Build Frequency Based on Criteria and Scope in Azure DevOps

Nov 18, 2020 • 6 Minute Read

Introduction

Nowadays, quality assurance (QA) teams and developers want to validate ongoing features as they become available in the source branch. Most software companies want to establish an automated process to deploy the latest changes to their environments without doing a manual intervention from a devOps engineer.

This can be done by running Azure pipelines at stipulated intervals or in a scheduled manner. It can be achieved using the triggers option provided by Azure evOps in Continuous Integration (CI) or Continuous Deployment (CD) pipelines.

This guide describes steps to set up build frequency or schedules using Triggers in the Azure DevOps pipelines.

Different Triggers in Azure Pipelines

Azure pipelines support many types of triggers. Based on the type of your pipeline, select the appropriate trigger and related option. Triggers help to run a pipeline automatically.

Continuous Integration (CI) triggers vary based on the type of repository you build in your pipeline. They include:

  • CI triggers in Azure Repos Git
  • CI triggers in GitHub
  • CI triggers in Bitbucket Cloud
  • CI triggers in Team Foundation Version Control (TFVC)

Let’s learn about the end-to-end process of configuring triggers for pipelines using the Azure Repos Git approach.

Configure Triggers in Azure Pipelines

Azure DevOps supports classic builds as well as YAML-based pipelines. Let’s take a classic build pipeline as an example and try to configure triggers with various options.

This guide assumes that you’ve already created a pipeline using classic build. If you’ve not done so, then you can create a classic build pipeline for Azure Repo Git. You can find more information about creating build pipeline documentation here.

To configure triggers in your build pipeline, navigate to the Pipelines > Pipelines option as shown in the figure below.

This fetches all the available pipelines from your project. Select a pipeline for which you want to configure a trigger, then click on the Edit button.

Navigate to the Triggers menu.

Now, it’s time to deep dive into each setting and explore the various build frequency option to configure your build pipelines. The following section will explain each trigger option in detail and give tips for scheduling build frequency in Azure pipelines.

Configure CI Triggers

Continuous Integration (CI) triggers cause a pipeline to run whenever you push an update to the specified branches or tags.

If the Enable continuous integration option is enabled, then it triggers only when new changes are uploaded to the branch.

If the Batch changes while a build is in progress option is enabled, then the system waits until the current run is completed and then queues another run of all changes that have not yet been built so far. This option is useful if a team frequently uploads a change to the branch.

Branch filters is another feature provided by Azure pipelines to trigger the build only when specified criteria are matched. Branch filters also support wildcard characters while configuring a branch specification. Example: features/pluralsight/*

Path filters is another great option if you want to trigger a build when a specific file is changed. The order of path filters doesn’t matter, and paths are case-sensitive. Be sure that you’re using the same case as a real folder's name.

Configure Schedule Triggers

Azure pipelines provide you the capability to run build on a specified schedule. This is a very useful feature for a software project team to deploy changes using nightly build. So, the next day team will have all changes deployed to their respective environments.

Let’s configure a build that runs every night at 2:00 AM at a specified time zone as shown in the figure below.

It also provides you branch filters feature-capability (same as CI triggers, explained in the previous section) to run only when a specified branch is changed.

If you wish to run scheduled build only when a branch is uploaded with new changes then be sure that you’ve checked the option Only schedule builds if the source or pipeline has changed.

Configure Build Completion

This is a practical business use case where software companies have multiple products that are dependent on each other. These products are usually built independently, but if the parent product is changed then the dependent product needs to be rebuilt or re-validated.

To configure the Build completion option, click on the Add button and select Triggering build from the dropdown.

This option also supports the branch filters feature explained in the previous section of this guide.

Conclusion

This guide demonstrated how to schedule triggers on various branches and run a build on a specified schedule at different intervals, and how to use path filters and various other options.

It helps software development project teams to get advantages including:

  • Configure an automated way to deploy or build changes as per your project requirements
  • No manual intervention needed
  • Easy to deploy or build multiple products
  • Easy to handle complex deployment

Azure pipeline trigger options can be configured using YAML-based pipelines. You can explore more on that feature to further build on this guide. Thank you for reading.

Ronika Mehta

Ronika M.

A seasoned and creative senior technical specialist, Ronika Mehta has been expanding what is possible with code and enterprise solutions to make life more efficient. I love to travel, develop enterprise-level software & cooking. I’ve been in the software industries for more than 7 years. Delivering new & innovative solutions for my clients. I’ve worked on many technologies over seven years, like Microsoft .Net Core, Azure, Azure DevOps, SignalR, Stencil JS, and other open source technologies. Currently, I’m working on a Secure Messaging App product for my client using SignalR, .Net Core, Stencil JS, and many other technologies.

More about this author