From 86c17772053b10431531101686aec64d76a08122 Mon Sep 17 00:00:00 2001 From: sharkdp Date: Fri, 1 Jun 2018 00:33:39 +0200 Subject: [PATCH] Skip snapshot test if Git is not available closes #161 --- Cargo.toml | 2 +- tests/tester.rs | 2 +- tests/tests.rs | 12 ++++++++++++ 3 files changed, 14 insertions(+), 2 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index a2fd53e7..acd2ed86 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -7,7 +7,7 @@ license = "MIT/Apache-2.0" name = "bat" readme = "README.md" repository = "https://github.com/sharkdp/bat" -version = "0.4.0" +version = "0.4.1" exclude = [ "assets/syntaxes/*", "assets/themes/*", diff --git a/tests/tester.rs b/tests/tester.rs index 9865cbc1..404e8342 100644 --- a/tests/tester.rs +++ b/tests/tester.rs @@ -11,7 +11,7 @@ pub struct BatTester { impl BatTester { pub fn new() -> Self { modify_sample_file(); - // Lifted from fd :) + let root = env::current_exe() .expect("tests executable") .parent() diff --git a/tests/tests.rs b/tests/tests.rs index 0f14ae15..2bf07906 100644 --- a/tests/tests.rs +++ b/tests/tests.rs @@ -1,5 +1,6 @@ mod tester; +use std::process::{Command, Stdio}; use tester::BatTester; static STYLES: &'static [&'static str] = &[ @@ -24,6 +25,17 @@ static STYLES: &'static [&'static str] = &[ #[test] fn test_snapshots() { + let status = Command::new("git") + .arg("rev-parse") + .stdout(Stdio::null()) + .stderr(Stdio::null()) + .status(); + + if !status.map(|s| s.success()).unwrap_or(false) { + // Git not available or not a git repository. Skipping snapshot test. + return; + } + let bat_tester = BatTester::new(); for style in STYLES {