Start Building for Free
CircleCI.comAcademyBlogCommunitySupport

Skip CI and cancel workflows

1 month ago2 min read
Cloud
Server v4+
On This Page

This page describes how to skip or cancel work when triggering pipelines. There are a couple of ways to do this:

  • The CI processes can be skipped for a commit, on push to your repo.

  • Workflows can be cancelled using the auto-cancel feature.

Both methods are described below.

Skip CI for a specific push

By default, CircleCI automatically triggers a pipeline whenever you push changes to your project. You can override this behavior by adding one of the following tags within the first 250 characters of the body or title of the latest commit you pushed:

  • [ci skip]

  • [skip ci]

Adding one of these tags skips pipeline execution for all the commits included in the push.

The skip CI process

When you include [ci skip] or [skip ci] in the first 250 characters of the body or title of a commit, CircleCI uses this infomation to decide not to build your project.

The skip process is different depending on your VCS integration, as follows:

  • GitHub App: A skipped pipeline will not show on the pipelines page, and no pipeline will be returned for a skipped commit using the API.

  • GitHub OAuth, GitLab, Bitbucket: A skipped pipeline will show in the CircleCI web app pipelines page with a status of NOT RUN. A pipeline will be returned for the skipped commit using the API with a status of created but the workflows and jobs will be not run.

Scope

A few points to note regarding the scope of the ci skip feature:

  • The pipeline and workflows will still exist for these commits but no jobs will be run.

  • If you push multiple commits at once, and the latest commit includes a [ci skip] or [skip ci] tag, it will skip the pipeline execution for all commits in that push.

  • This feature is not supported for fork PRs. Scheduled workflows will run even if you push a commit with [ci skip] message. Changing the config file is the way to upgrade the current schedule.

Example commit title

$ git log origin/master..HEAD

commit 63ce74221ff899955dd6258020d6cb9accede893
Author: Daniel Woelfel
Date:   Wed Jan 23 16:48:25 2017 -0800

    fix misspelling [ci skip]

When pushed to a VCS, this commit will not be built on CircleCI because of the [ci skip] in the commit title.

Example commit description

$ git log origin/master..HEAD

commit 99b4ce4d59e79cb379987b39c65f7113631f0635
Merge: 16ba8ca adc6571
Author: Daniel Woelfel
Date:   Tue Apr 25 15:56:42 2016 -0800

    A large feature with squashed commits

    [skip ci] Fix bug in feature
    Refactor feature code
    First attempt at feature

When pushed to a VCS, this commit will not be built on CircleCI because of the [ci skip] or [skip ci] in the commit description.

Auto-cancel redundant workflows

If you are frequently pushing changes to a branch, you increase the chances of queueing. This means you might have to wait for an older pipeline to complete before the most recent version starts.

To save time, you can configure CircleCI to automatically cancel any non-terminated workflows when a newer pipeline is triggered on that same branch.

Scope

A few points to note regarding the use of the auto-cancel feature:

  • Pushing to a default branch (usually main) will never auto-cancel workflows.

  • Auto-cancel affects pipelines triggered by pushes to a VCS or via the API.

  • Only workflows that are triggered when the feature is enabled will be auto-cancelled.

Enable auto-cancel

It is important to carefully consider the impact of enabling the auto-cancel feature, for example, if you have configured automated deployment jobs on non-default branches. {: class="alert alert-warning"}

  1. In the CircleCI application, go to your Project Settings.

  2. Select Advanced Settings.

  3. Toggle the switch to enable the Auto-cancel redundant workflows option.

Projects which have auto-cancel enabled will have pipelines and workflows on non-default branches cancelled when a newer build is triggered on that same branch, with the following exceptions:

  • Scheduled workflows

  • Re-run workflows


Suggest an edit to this page

Make a contribution
Learn how to contribute