#provider #info #ci #env

ci_env

Detect CI information from the environment

7 unstable releases

0.4.0 Feb 1, 2025
0.3.0 Apr 11, 2024
0.2.2 Mar 26, 2024
0.2.1 Sep 22, 2023
0.1.1 Mar 16, 2023

#180 in Testing

Download history 137/week @ 2024-12-29 245/week @ 2025-01-05 127/week @ 2025-01-12 182/week @ 2025-01-19 406/week @ 2025-01-26 376/week @ 2025-02-02 325/week @ 2025-02-09 293/week @ 2025-02-16 205/week @ 2025-02-23 635/week @ 2025-03-02 603/week @ 2025-03-09 249/week @ 2025-03-16 324/week @ 2025-03-23 362/week @ 2025-03-30 292/week @ 2025-04-06 260/week @ 2025-04-13

1,249 downloads per month

MIT license

42KB
990 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–0.9MB
~20K SLoC