Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

ci-info

watson173.4mMIT4.1.0TypeScript support: included

Get details about the current Continuous Integration environment

ci, continuous, integration, test, detect

readme

ci-info

Get details about the current Continuous Integration environment.

Please open an issue if your CI server isn't properly detected :)

npm Tests js-standard-style

Installation

npm install ci-info --save

Usage

var ci = require('ci-info')

if (ci.isCI) {
  console.log('The name of the CI server is:', ci.name)
} else {
  console.log('This program is not running on a CI server')
}

Supported CI tools

Officially supported CI servers:

Name Constant isPR
Agola CI ci.AGOLA
Appcircle ci.APPCIRCLE
AppVeyor ci.APPVEYOR
AWS CodeBuild ci.CODEBUILD
Azure Pipelines ci.AZURE_PIPELINES
Bamboo by Atlassian ci.BAMBOO 🚫
Bitbucket Pipelines ci.BITBUCKET
Bitrise ci.BITRISE
Buddy ci.BUDDY
Buildkite ci.BUILDKITE
CircleCI ci.CIRCLE
Cirrus CI ci.CIRRUS
Codefresh ci.CODEFRESH
Codeship ci.CODESHIP 🚫
Drone ci.DRONE
dsari ci.DSARI 🚫
Earthly CI ci.EARTHLY 🚫
Expo Application Services ci.EAS 🚫
Gerrit CI ci.GERRIT 🚫
GitHub Actions ci.GITHUB_ACTIONS
GitLab CI ci.GITLAB
Gitea Actions ci.GITEA_ACTIONS 🚫
GoCD ci.GOCD 🚫
Google Cloud Build ci.GOOGLE_CLOUD_BUILD 🚫
Harness CI ci.HARNESS 🚫
Heroku ci.HEROKU 🚫
Hudson ci.HUDSON 🚫
Jenkins CI ci.JENKINS
LayerCI ci.LAYERCI
Magnum CI ci.MAGNUM 🚫
Netlify CI ci.NETLIFY
Nevercode ci.NEVERCODE
Prow ci.PROW 🚫
ReleaseHub ci.RELEASEHUB 🚫
Render ci.RENDER
Sail CI ci.SAIL
Screwdriver ci.SCREWDRIVER
Semaphore ci.SEMAPHORE
Sourcehut ci.SOURCEHUT 🚫
Strider CD ci.STRIDER 🚫
TaskCluster ci.TASKCLUSTER 🚫
TeamCity by JetBrains ci.TEAMCITY 🚫
Travis CI ci.TRAVIS
Vela ci.VELA
Vercel ci.VERCEL
Visual Studio App Center ci.APPCENTER 🚫
Woodpecker ci.WOODPECKER

API

ci.name

Returns a string containing name of the CI server the code is running on. If CI server is not detected, it returns null.

Don't depend on the value of this string not to change for a specific vendor. If you find your self writing ci.name === 'Travis CI', you most likely want to use ci.TRAVIS instead.

ci.isCI

Returns a boolean. Will be true if the code is running on a CI server, otherwise false.

Some CI servers not listed here might still trigger the ci.isCI boolean to be set to true if they use certain vendor neutral environment variables. In those cases ci.name will be null and no vendor specific boolean will be set to true.

ci.isPR

Returns a boolean if PR detection is supported for the current CI server. Will be true if a PR is being tested, otherwise false. If PR detection is not supported for the current CI server, the value will be null.

ci.<VENDOR-CONSTANT>

A vendor specific boolean constant is exposed for each support CI vendor. A constant will be true if the code is determined to run on the given CI server, otherwise false.

Examples of vendor constants are ci.TRAVIS or ci.APPVEYOR. For a complete list, see the support table above.

Ports

ci-info has been ported to the following languages

Language Repository
Go https://github.com/hofstadter-io/cinful
Rust https://github.com/sagiegurari/ci_info
Kotlin https://github.com/cloudflightio/ci-info

License

MIT

changelog

Changelog

v4.1.0

  • support Appcircle PR 1d42c26
  • support AWS CodeBuild PR e6fcdd2
  • add ci.id to return vendor constant 81fd993

v4.0.0

Breaking Changes

v3.9.0

  • better support for Azure Pipelines (#116), 5ea8d85
  • detect PullRequest in Azure Pipelines 5ea8d85

v3.8.0

v3.7.1

  • ignore ci detection when CI is set to 'false' 24cc450

v3.7.0

v3.6.2

  • fix VERCEL environment detection (#98)

v3.6.1

v3.6.0

This release attempts to bring parity with @npmcli/ci-detect. See #95 for more details.

  • support gerrit (#95)
  • support google cloud build (#95)
  • support heroku (#95)
  • support anonymous CI's that exposes BUILD_ID and CI_NAME env vars (#95)
  • support more vercel environments (#95)

v3.5.0

  • support Woodpecker CI (#90)

v3.4.0

  • partial support Appflow CI (only CI detection) (#84)
  • support Codemagic CI (#85)
  • support Xcode Server CI (#86)
  • support Xcode Cloud CI (#86)

v3.3.2

  • fix: export correct typings for EAS

v3.3.1

  • fix: export EAS_BUILD constant in typings
  • Add support for nodejs v18

v3.3.0

  • support Expo Application Services (#70)

v3.2.0

  • support LayerCI (#68)
  • support Appcircle (#69)
  • support Codefresh CI (#65)
  • add support for nodejs v16

v3.1.1

Bug Fixes:

  • remove duplicate declaration in typings

v3.1.0

Features:

  • add typings

v3.0.0

Features:

  • Add support nodejs versions: 14, 15
  • support Nevercode (#30)
  • support Render CI (#36)
  • support Now CI (#37)
  • support GitLab PR (#59)
  • support Screwdriver CD (#60)
  • support Visual Studio App Center (#61)

Bug Fixes:

  • update Netlify env constant (#47)

Breaking changes:

  • Drop support for Node.js end-of-life versions: 6, 13
  • replace Zeit Now with Vercel (#55)

v2.0.0

Breaking changes:

  • Drop support for Node.js end-of-life versions: 0.10, 0.12, 4, 5, 7, and 9
  • Team Foundation Server will now be detected as Azure Pipelines. The constant ci.TFS no longer exists - use ci.AZURE_PIPELINES instead
  • Remove deprecated ci.TDDIUM constant - use ci.SOLANDO instead

New features:

  • feat: support Azure Pipelines (#23)
  • feat: support Netlify CI (#26)
  • feat: support Bitbucket pipelines PR detection (#27)

v1.6.0

  • feat: add Sail CI support
  • feat: add Buddy support
  • feat: add Bitrise support
  • feat: detect Jenkins PRs
  • feat: detect Drone PRs

v1.5.1

  • fix: use full path to vendors.json

v1.5.0

  • feat: add dsari detection (#15)
  • feat: add ci.isPR (#16)

v1.4.0

  • feat: add Cirrus CI detection (#13)
  • feat: add Shippable CI detection (#14)

v1.3.1

  • chore: reduce npm package size by not including .github folder content (#11)

v1.3.0

  • feat: add support for Strider CD
  • chore: deprecate vendor constant TDDIUM in favor of SOLANO
  • docs: add missing vendor constant to docs

v1.2.0

  • feat: detect solano-ci (#9)

v1.1.3

  • fix: fix spelling of Hunson in ci.name

v1.1.2

  • fix: no more false positive matches for Jenkins

v1.1.1

  • docs: sort lists of CI servers in README.md
  • docs: add missing AWS CodeBuild to the docs

v1.1.0

  • feat: add AWS CodeBuild to CI detection (#2)

v1.0.1

  • chore: reduce npm package size by using an .npmignore file (#3)

v1.0.0

  • Initial release