mirror of
https://github.com/rust-lang/rust-clippy
synced 2024-11-26 14:40:32 +00:00
Merge pull request #3148 from matthiaskrgr/rustc_tools_util_tests
rustc_tools_util: add tests
This commit is contained in:
commit
2d3298b8c4
2 changed files with 33 additions and 2 deletions
|
@ -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
|
||||||
|
|
|
@ -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");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue