Merge pull request #3148 from matthiaskrgr/rustc_tools_util_tests

rustc_tools_util: add tests
This commit is contained in:
Oliver S̶c̶h̶n̶e̶i̶d̶e̶r Scherer 2018-09-09 13:17:13 +02:00 committed by GitHub
commit 2d3298b8c4
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 33 additions and 2 deletions

View file

@ -8,6 +8,7 @@ remark -f *.md > /dev/null
cargo build --features debugging cargo build --features debugging
cargo test --features debugging cargo test --features debugging
cd clippy_lints && cargo test && cd .. cd clippy_lints && cargo test && cd ..
cd rustc_tools_util && cargo test && cd ..
mkdir -p ~/rust/cargo/bin mkdir -p ~/rust/cargo/bin
cp target/debug/cargo-clippy ~/rust/cargo/bin/cargo-clippy cp target/debug/cargo-clippy ~/rust/cargo/bin/cargo-clippy
cp target/debug/clippy-driver ~/rust/cargo/bin/clippy-driver cp target/debug/clippy-driver ~/rust/cargo/bin/clippy-driver

View file

@ -1,3 +1,4 @@
#![feature(test)]
#![feature(tool_lints)] #![feature(tool_lints)]
use std::env; use std::env;
@ -8,6 +9,7 @@ macro_rules! get_version_info {
let major = env!("CARGO_PKG_VERSION_MAJOR").parse::<u8>().unwrap(); let major = env!("CARGO_PKG_VERSION_MAJOR").parse::<u8>().unwrap();
let minor = env!("CARGO_PKG_VERSION_MINOR").parse::<u8>().unwrap(); let minor = env!("CARGO_PKG_VERSION_MINOR").parse::<u8>().unwrap();
let patch = env!("CARGO_PKG_VERSION_PATCH").parse::<u16>().unwrap(); let patch = env!("CARGO_PKG_VERSION_PATCH").parse::<u16>().unwrap();
let crate_name = String::from(env!("CARGO_PKG_NAME"));
let host_compiler = $crate::get_channel(); let host_compiler = $crate::get_channel();
let commit_hash = option_env!("GIT_HASH").map(|s| s.to_string()); let commit_hash = option_env!("GIT_HASH").map(|s| s.to_string());
@ -20,6 +22,7 @@ macro_rules! get_version_info {
host_compiler, host_compiler,
commit_hash, commit_hash,
commit_date, commit_date,
crate_name,
} }
}}; }};
} }
@ -32,6 +35,7 @@ pub struct VersionInfo {
pub host_compiler: Option<String>, pub host_compiler: Option<String>,
pub commit_hash: Option<String>, pub commit_hash: Option<String>,
pub commit_date: Option<String>, pub commit_date: Option<String>,
pub crate_name: String,
} }
impl std::fmt::Display for VersionInfo { impl std::fmt::Display for VersionInfo {
@ -40,7 +44,8 @@ impl std::fmt::Display for VersionInfo {
Some(_) => { Some(_) => {
write!( write!(
f, f,
"clippy {}.{}.{} ({} {})", "{} {}.{}.{} ({} {})",
self.crate_name,
self.major, self.major,
self.minor, self.minor,
self.patch, self.patch,
@ -49,7 +54,7 @@ impl std::fmt::Display for VersionInfo {
)?; )?;
}, },
None => { None => {
write!(f, "clippy {}.{}.{}", self.major, self.minor, self.patch)?; write!(f, "{} {}.{}.{}", self.crate_name, self.major, self.minor, self.patch)?;
}, },
}; };
Ok(()) Ok(())
@ -80,3 +85,28 @@ pub fn get_commit_date() -> Option<String> {
.ok() .ok()
.and_then(|r| String::from_utf8(r.stdout).ok()) .and_then(|r| String::from_utf8(r.stdout).ok())
} }
#[cfg(test)]
mod test {
use super::*;
#[test]
fn test_struct_local() {
let vi = get_version_info!();
assert_eq!(vi.major, 0);
assert_eq!(vi.minor, 1);
assert_eq!(vi.patch, 0);
assert_eq!(vi.crate_name, "rustc_tools_util");
// hard to make positive tests for these since they will always change
assert!(vi.commit_hash.is_none());
assert!(vi.commit_date.is_none());
}
#[test]
fn test_display_local() {
let vi = get_version_info!();
let fmt = format!("{}", vi);
assert_eq!(fmt, "rustc_tools_util 0.1.0");
}
}