1 #![allow(clippy::single_match_else)]
2 use rustc_tools_util::VersionInfo;
5 fn check_that_clippy_lints_has_the_same_version_as_clippy() {
6 let clippy_meta = cargo_metadata::MetadataCommand::new()
9 .expect("could not obtain cargo metadata");
10 std::env::set_current_dir(std::env::current_dir().unwrap().join("clippy_lints")).unwrap();
11 let clippy_lints_meta = cargo_metadata::MetadataCommand::new()
14 .expect("could not obtain cargo metadata");
15 assert_eq!(clippy_lints_meta.packages[0].version, clippy_meta.packages[0].version);
16 for package in &clippy_meta.packages[0].dependencies {
17 if package.name == "clippy_lints" {
18 assert!(package.req.matches(&clippy_lints_meta.packages[0].version));
25 fn check_that_clippy_has_the_same_major_version_as_rustc() {
26 let clippy_version = rustc_tools_util::get_version_info!();
27 let clippy_major = clippy_version.major;
28 let clippy_minor = clippy_version.minor;
29 let clippy_patch = clippy_version.patch;
31 // get the rustc version from cargo
32 // this way the rust-toolchain file version is honored
33 let rustc_version = String::from_utf8(
34 std::process::Command::new("cargo")
37 .expect("failed to run 'cargo --version'")
41 // extract "1 50 0" from "cargo 1.50.0-nightly (a3c2627fb 2020-12-14)"
42 let vsplit: Vec<&str> = rustc_version
51 match vsplit.as_slice() {
52 [rustc_major, rustc_minor, _rustc_patch] => {
53 // clippy 0.1.50 should correspond to rustc 1.50.0
55 dbg!(&clippy_version);
56 assert_eq!(clippy_major, 0); // this will probably stay the same for a long time
58 clippy_minor.to_string(),
60 "clippy minor version does not equal rustc major version"
63 clippy_patch.to_string(),
65 "clippy patch version does not equal rustc minor version"
67 // do not check rustc_patch because when a stable-patch-release is made (like 1.50.2),
68 // we don't want our tests failing suddenly
72 panic!("Failed to parse rustc version");