web 3d图形渲染器
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

108 lines
4.0 KiB

  1. # ci-info
  2. Get details about the current Continuous Integration environment.
  3. Please [open an
  4. issue](https://github.com/watson/ci-info/issues/new?template=ci-server-not-detected.md)
  5. if your CI server isn't properly detected :)
  6. [![npm](https://img.shields.io/npm/v/ci-info.svg)](https://www.npmjs.com/package/ci-info)
  7. [![Build status](https://travis-ci.org/watson/ci-info.svg?branch=master)](https://travis-ci.org/watson/ci-info)
  8. [![js-standard-style](https://img.shields.io/badge/code%20style-standard-brightgreen.svg?style=flat)](https://github.com/feross/standard)
  9. ## Installation
  10. ```bash
  11. npm install ci-info --save
  12. ```
  13. ## Usage
  14. ```js
  15. var ci = require('ci-info')
  16. if (ci.isCI) {
  17. console.log('The name of the CI server is:', ci.name)
  18. } else {
  19. console.log('This program is not running on a CI server')
  20. }
  21. ```
  22. ## Supported CI tools
  23. Officially supported CI servers:
  24. | Name | Constant | isPR |
  25. |------|----------|------|
  26. | [AWS CodeBuild](https://aws.amazon.com/codebuild/) | `ci.CODEBUILD` | 🚫 |
  27. | [AppVeyor](http://www.appveyor.com) | `ci.APPVEYOR` | ✅ |
  28. | [Azure Pipelines](https://azure.microsoft.com/en-us/services/devops/pipelines/) | `ci.AZURE_PIPELINES` | ✅ |
  29. | [Bamboo](https://www.atlassian.com/software/bamboo) by Atlassian | `ci.BAMBOO` | 🚫 |
  30. | [Bitbucket Pipelines](https://bitbucket.org/product/features/pipelines) | `ci.BITBUCKET` | ✅ |
  31. | [Bitrise](https://www.bitrise.io/) | `ci.BITRISE` | ✅ |
  32. | [Buddy](https://buddy.works/) | `ci.BUDDY` | ✅ |
  33. | [Buildkite](https://buildkite.com) | `ci.BUILDKITE` | ✅ |
  34. | [CircleCI](http://circleci.com) | `ci.CIRCLE` | ✅ |
  35. | [Cirrus CI](https://cirrus-ci.org) | `ci.CIRRUS` | ✅ |
  36. | [Codeship](https://codeship.com) | `ci.CODESHIP` | 🚫 |
  37. | [Drone](https://drone.io) | `ci.DRONE` | ✅ |
  38. | [dsari](https://github.com/rfinnie/dsari) | `ci.DSARI` | 🚫 |
  39. | [GitLab CI](https://about.gitlab.com/gitlab-ci/) | `ci.GITLAB` | 🚫 |
  40. | [GoCD](https://www.go.cd/) | `ci.GOCD` | 🚫 |
  41. | [Hudson](http://hudson-ci.org) | `ci.HUDSON` | 🚫 |
  42. | [Jenkins CI](https://jenkins-ci.org) | `ci.JENKINS` | ✅ |
  43. | [Magnum CI](https://magnum-ci.com) | `ci.MAGNUM` | 🚫 |
  44. | [Netlify CI](https://www.netlify.com/) | `ci.NETLIFY` | ✅ |
  45. | [Sail CI](https://sail.ci/) | `ci.SAIL` | ✅ |
  46. | [Semaphore](https://semaphoreci.com) | `ci.SEMAPHORE` | ✅ |
  47. | [Shippable](https://www.shippable.com/) | `ci.SHIPPABLE` | ✅ |
  48. | [Solano CI](https://www.solanolabs.com/) | `ci.SOLANO` | ✅ |
  49. | [Strider CD](https://strider-cd.github.io/) | `ci.STRIDER` | 🚫 |
  50. | [TaskCluster](http://docs.taskcluster.net) | `ci.TASKCLUSTER` | 🚫 |
  51. | [TeamCity](https://www.jetbrains.com/teamcity/) by JetBrains | `ci.TEAMCITY` | 🚫 |
  52. | [Travis CI](http://travis-ci.org) | `ci.TRAVIS` | ✅ |
  53. ## API
  54. ### `ci.name`
  55. Returns a string containing name of the CI server the code is running on.
  56. If CI server is not detected, it returns `null`.
  57. Don't depend on the value of this string not to change for a specific
  58. vendor. If you find your self writing `ci.name === 'Travis CI'`, you
  59. most likely want to use `ci.TRAVIS` instead.
  60. ### `ci.isCI`
  61. Returns a boolean. Will be `true` if the code is running on a CI server,
  62. otherwise `false`.
  63. Some CI servers not listed here might still trigger the `ci.isCI`
  64. boolean to be set to `true` if they use certain vendor neutral
  65. environment variables. In those cases `ci.name` will be `null` and no
  66. vendor specific boolean will be set to `true`.
  67. ### `ci.isPR`
  68. Returns a boolean if PR detection is supported for the current CI server. Will
  69. be `true` if a PR is being tested, otherwise `false`. If PR detection is
  70. not supported for the current CI server, the value will be `null`.
  71. ### `ci.<VENDOR-CONSTANT>`
  72. A vendor specific boolean constant is exposed for each support CI
  73. vendor. A constant will be `true` if the code is determined to run on
  74. the given CI server, otherwise `false`.
  75. Examples of vendor constants are `ci.TRAVIS` or `ci.APPVEYOR`. For a
  76. complete list, see the support table above.
  77. Deprecated vendor constants that will be removed in the next major
  78. release:
  79. - `ci.TDDIUM` (Solano CI) This have been renamed `ci.SOLANO`
  80. ## License
  81. [MIT](LICENSE)