Skip to content

cucumber/ci-environment

Folders and files

NameName
Last commit message
Last commit date

Latest commit

5bb726d · Apr 12, 2025
Mar 11, 2025
Jan 2, 2022
Nov 23, 2024
Apr 11, 2025
Apr 12, 2025
Sep 8, 2024
Nov 5, 2024
Jul 13, 2023
Jul 13, 2023
Jul 7, 2023
Dec 8, 2021
Nov 23, 2024
Dec 8, 2021
Apr 24, 2023
Feb 23, 2024
Nov 7, 2024
Nov 15, 2021
Nov 7, 2024

Repository files navigation

CiEnvironment

test-java test-javascript test-ruby test-go

This library detects the CI environment based on environment variables defined by CI servers.

If a CI server is detected, a CiEnvironment.json struct is returned:

{
  "name": "...",
  "url": "...",
  "buildNumber": "...", // optional
  "git": {              // optional
    "remote": "...",
    "revision": "...",
    "branch": "...",    // optional
    "tag": "..."        // optional
  }
}

Note that some fields are optional (they may not be set if the corresponding environment variables are not defined).

Some CI servers expose usernames and passwords in the environment variable that is used to detect git.remote. For security reasons, this library removes the username and password from the git.remote field in the CiEnvironment.json struct.

TypeScript

npm install @cucumber/ci-environment
import detectCiEnvironment from '@cucumber/ci-environment'

const ciEnvironment = detectCiEnvironment(process.env)
console.log(JSON.stringify(ciEnvironment, null, 2))

Java

<dependency>
    <groupId>io.cucumber</groupId>
    <artifactId>ci-environment</artifactId>
</dependency>
import static io.cucumber.cienvironment.DetectCiEnvironment.detectCiEnvironment;

public class CiEnvironmentExample {
    public static void main(String[] args) {
        CiEnvironment ciEnvironment = detectCiEnvironment(System.getenv()).orElseThrow(() -> new RuntimeException("No CI environment detected"));
        System.out.println("ciEnvironment = " + ciEnvironment);
    }
}

Ruby

gem 'cucumber-ci-environment'
require 'cucumber/ci_environment'

ci_environment = Cucumber::CiEnvironment.detect_ci_environment(ENV)
p ci_environment

Go

go get github.com/cucumber/ci-environment/go@latest
import (
  "fmt"
	cienvironment "github.com/cucumber/ci-environment/go"
)

func main() {
  ci := cienvironment.DetectCIEnvironment()
  if ci == nil {
    fmt.Println("No CI environment detected")
  }
}
import os
from ci_environment import detect_ci_environment

ci_environment = detect_ci_environment(os.environ)

Supported CI servers

Contributing

Please see CONTRIBUTING.md for more information.