# ci_info [![crates.io](https://img.shields.io/crates/v/ci_info.svg)](https://crates.io/crates/ci_info) [![CI](https://github.com/sagiegurari/ci_info/workflows/CI/badge.svg?branch=master)](https://github.com/sagiegurari/ci_info/actions) [![codecov](https://codecov.io/gh/sagiegurari/ci_info/branch/master/graph/badge.svg)](https://codecov.io/gh/sagiegurari/ci_info)
[![license](https://img.shields.io/crates/l/ci_info.svg)](https://github.com/sagiegurari/ci_info/blob/master/LICENSE) [![Libraries.io for GitHub](https://img.shields.io/librariesio/github/sagiegurari/ci_info.svg)](https://libraries.io/cargo/ci_info) [![Documentation](https://docs.rs/ci_info/badge.svg)](https://docs.rs/crate/ci_info/) [![downloads](https://img.shields.io/crates/d/ci_info.svg)](https://crates.io/crates/ci_info)
[![Built with cargo-make](https://sagiegurari.github.io/cargo-make/assets/badges/cargo-make.svg)](https://sagiegurari.github.io/cargo-make) > Provides current CI environment information. * [Overview](#overview) * [Usage](#usage) * [Installation](#installation) * [API Documentation](https://sagiegurari.github.io/ci_info/) * [Contributing](.github/CONTRIBUTING.md) * [Release History](CHANGELOG.md) * [License](#license) ## Overview This library main goal is to provide development/build tools such as [cargo-make](https://sagiegurari.github.io/cargo-make/) the needed information on the current CI environment.
Inspired by the [ci-info](https://github.com/watson/ci-info) npm module. ## Usage Simply include the library and invoke the get function to pull all info as follows: ### Fetching Info ```rust fn main() { // Just check if a CI environment is detected. let ci = ci_info::is_ci(); println!("Is CI: {}", ci); // Get CI environment information let info = ci_info::get(); println!("Is CI: {}", info.ci); if let Some(vendor) = info.vendor { println!("Vendor: {:#?}", vendor); println!("Name: {:#?}", info.name.unwrap()); } if let Some(pr) = info.pr { println!("Is PR: {:#?}", pr); } if let Some(branch_name) = info.branch_name { println!("Branch Name: {:#?}", branch_name); } } ``` ### Mocking CI environment ```rust use ci_info::types::{CiInfo, Vendor}; fn main() { // create the CI info manually let mut mock_info = CiInfo::new(); mock_info.vendor = Some(Vendor::TravisCI); mock_info.ci = true; mock_info.pr = Some(true); mock_info.branch_name = Some("dev_branch".to_string()); // mock environment ci_info::mock_ci(&mock_info); let info = ci_info::get(); assert!(info.ci); assert!(info.pr.unwrap()); assert_eq!(info.vendor.unwrap(), Vendor::TravisCI); assert_eq!(info.name.unwrap(), "Travis CI"); assert_eq!(info.branch_name.unwrap(), "dev_branch"); // clear CI environment mock_info = CiInfo::new(); ci_info::mock_ci(&mock_info); let info = ci_info::get(); assert!(!info.ci); } ``` ## Installation In order to use this library, just add it as a dependency: ```ini [dependencies] ci_info = "^0.14.14" ``` There is optional `serde` support that can be enabled via the `serde-1` feature: ```ini [dependencies] ci_info = { version = "*", features = ["serde-1"] } ``` ## API Documentation See full docs at: [API Docs](https://sagiegurari.github.io/ci_info/) ## Contributing See [contributing guide](.github/CONTRIBUTING.md) ## Release History See [Changelog](CHANGELOG.md) ## License Developed by Sagie Gur-Ari and licensed under the Apache 2 open source license.