#provider #env #ci

ci_env

Detect CI information from the environment

8 releases

new 0.4.1 Jan 24, 2026
0.4.0 Feb 1, 2025
0.3.0 Apr 11, 2024
0.2.2 Mar 26, 2024
0.1.1 Mar 16, 2023

#231 in Testing

Download history 353/week @ 2025-10-04 372/week @ 2025-10-11 200/week @ 2025-10-18 149/week @ 2025-10-25 236/week @ 2025-11-01 177/week @ 2025-11-08 233/week @ 2025-11-15 160/week @ 2025-11-22 228/week @ 2025-11-29 179/week @ 2025-12-06 203/week @ 2025-12-13 178/week @ 2025-12-20 203/week @ 2025-12-27 201/week @ 2026-01-03 442/week @ 2026-01-10 214/week @ 2026-01-17

1,068 downloads per month

MIT license

42KB
988 lines

ci_env

Crates.io Crates.io

Detects CI (continuous integration) information from the current environment.

Usage

To start, detect if in a CI environment.

ci_env::is_ci();

Or detect which CI provider is being used.

ci_env::detect_provider(); // GithubActions

And most importantly, extract information about the CI environment and CI provider. This includes branch, commit, and pull request information.

use ci_env::get_environment;

if let Some(ci) = get_environment() {
	println!("Provider: {:?}", ci.provider);
	println!("Branch: {}", ci.branch);
	println!("Commit: {}", ci.revision);

	if let Some(pr_number) = ci.request_id {
		println!("PR #: {}", pr_number);
	}
}

This library will properly take into account source and target branches when a pull request is involved. Do note though that not all providers provide this information.

Dependencies

~0.3–1MB
~21K SLoC