Skip to content

Commit

Permalink
test: migrate clean to snapbox
Browse files Browse the repository at this point in the history
  • Loading branch information
dieterplex committed Jun 18, 2024
1 parent d899ce7 commit b278ca7
Showing 1 changed file with 103 additions and 94 deletions.
197 changes: 103 additions & 94 deletions tests/testsuite/clean.rs
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
//! Tests for the `cargo clean` command.
#![allow(deprecated)]

use cargo_test_support::paths::CargoPathExt;
use cargo_test_support::prelude::*;
use cargo_test_support::registry::Package;
use cargo_test_support::str;
use cargo_test_support::{
basic_bin_manifest, basic_manifest, git, main_file, project, project_in, rustc_host,
};
Expand Down Expand Up @@ -38,7 +38,7 @@ fn different_dir() {

p.cargo("clean")
.cwd("src")
.with_stderr("[REMOVED] [..]")
.with_stderr_data("[REMOVED] 11 files, [FILE_SIZE]B total\n")
.run();
assert!(!p.build_dir().is_dir());
}
Expand Down Expand Up @@ -88,7 +88,7 @@ fn clean_multiple_packages() {

p.cargo("clean -p d1 -p d2")
.cwd("src")
.with_stderr("[REMOVED] [..]")
.with_stderr_data("[REMOVED] 16 files, [FILE_SIZE]B total\n")
.run();
assert!(p.bin("foo").is_file());
assert!(!d1_path.is_file());
Expand Down Expand Up @@ -235,17 +235,16 @@ fn clean_release() {

p.cargo("clean -p foo").run();
p.cargo("build --release")
.with_stderr("[FINISHED] [..]")
.with_stderr_data("[FINISHED] `release` profile [optimized] target(s) in [ELAPSED]s\n")
.run();

p.cargo("clean -p foo --release").run();
p.cargo("build --release")
.with_stderr(
"\
[COMPILING] foo v0.0.1 ([..])
[FINISHED] `release` profile [optimized] target(s) in [..]
",
)
.with_stderr_data(str![[r#"
[COMPILING] foo v0.0.1 ([ROOT]/foo)
[FINISHED] `release` profile [optimized] target(s) in [ELAPSED]s
"#]])
.run();

p.cargo("build").run();
Expand Down Expand Up @@ -283,7 +282,9 @@ fn clean_doc() {

assert!(doc_path.is_dir());

p.cargo("clean --doc").with_stderr("[REMOVED] [..]").run();
p.cargo("clean --doc")
.with_stderr_data("[REMOVED] 47 files, [FILE_SIZE]B total\n")
.run();

assert!(!doc_path.is_dir());
assert!(p.build_dir().is_dir());
Expand Down Expand Up @@ -326,15 +327,14 @@ fn build_script() {
p.cargo("build").env("FIRST", "1").run();
p.cargo("clean -p foo").run();
p.cargo("build -v")
.with_stderr(
"\
[COMPILING] foo v0.0.1 ([..])
.with_stderr_data(str![[r#"
[COMPILING] foo v0.0.1 ([ROOT]/foo)
[RUNNING] `rustc [..] build.rs [..]`
[RUNNING] `[..]build-script-build`
[RUNNING] `[ROOT]/foo/target/debug/build/foo-[HASH]/build-script-build`
[RUNNING] `rustc [..] src/main.rs [..]`
[FINISHED] `dev` profile [unoptimized + debuginfo] target(s) in [..]
",
)
[FINISHED] `dev` profile [unoptimized + debuginfo] target(s) in [ELAPSED]s
"#]])
.run();
}

Expand Down Expand Up @@ -367,7 +367,9 @@ fn clean_git() {
.build();

p.cargo("build").run();
p.cargo("clean -p dep").with_stderr("[REMOVED] [..]").run();
p.cargo("clean -p dep")
.with_stderr_data("[REMOVED] 7 files, [FILE_SIZE]B total\n")
.run();
p.cargo("build").run();
}

Expand All @@ -393,7 +395,9 @@ fn registry() {
Package::new("bar", "0.1.0").publish();

p.cargo("build").run();
p.cargo("clean -p bar").with_stderr("[REMOVED] [..]").run();
p.cargo("clean -p bar")
.with_stderr_data("[REMOVED] 7 files, [FILE_SIZE]B total\n")
.run();
p.cargo("build").run();
}

Expand All @@ -420,21 +424,24 @@ fn clean_verbose() {
p.cargo("build").run();
let mut expected = String::from(
"\
[REMOVING] [..]target/debug/.fingerprint/bar[..]
[REMOVING] [..]target/debug/deps/libbar[..].rlib
[REMOVING] [..]target/debug/deps/bar-[..].d
[REMOVING] [..]target/debug/deps/libbar[..].rmeta
[REMOVING] [ROOT]/foo/target/debug/.fingerprint/bar-[HASH]
[REMOVING] [ROOT]/foo/target/debug/deps/libbar-[HASH].rlib
[REMOVING] [ROOT]/foo/target/debug/deps/bar-[HASH].d
[REMOVING] [ROOT]/foo/target/debug/deps/libbar-[HASH].rmeta
",
);
if cfg!(target_os = "macos") {
// Rust 1.69 has changed so that split-debuginfo=unpacked includes unpacked for rlibs.
for obj in p.glob("target/debug/deps/bar-*.o") {
expected.push_str(&format!("[REMOVING] [..]{}\n", obj.unwrap().display()));
expected.push_str(&format!(
"[REMOVING] [ROOT]/foo/{}\n",
obj.unwrap().display()
));
}
}
expected.push_str("[REMOVED] [..] files, [..] total\n");
expected.push_str("[REMOVED] 7 files, [FILE_SIZE]B total\n");
p.cargo("clean -p bar --verbose")
.with_stderr_unordered(&expected)
.with_stderr_data(&expected.unordered())
.run();
p.cargo("build").run();
}
Expand Down Expand Up @@ -614,21 +621,20 @@ fn clean_spec_version() {
// Check suggestion for bad pkgid.
p.cargo("clean -p baz")
.with_status(101)
.with_stderr(
"\
error: package ID specification `baz` did not match any packages
.with_stderr_data(str![[r#"
[ERROR] package ID specification `baz` did not match any packages
<tab>Did you mean `bar`?
",
)
Did you mean `bar`?
"#]])
.run();

p.cargo("clean -p bar:0.1.0")
.with_stderr(
"warning: version qualifier in `-p bar:0.1.0` is ignored, \
cleaning all versions of `bar` found\n\
[REMOVED] [..] files, [..] total",
)
.with_stderr_data(str![[r#"
[WARNING] version qualifier in `-p bar:0.1.0` is ignored, cleaning all versions of `bar` found
[REMOVED] 14 files, [FILE_SIZE]B total
"#]])
.run();
let mut walker = walkdir::WalkDir::new(p.build_dir())
.into_iter()
Expand Down Expand Up @@ -670,21 +676,20 @@ fn clean_spec_partial_version() {
// Check suggestion for bad pkgid.
p.cargo("clean -p baz")
.with_status(101)
.with_stderr(
"\
error: package ID specification `baz` did not match any packages
.with_stderr_data(str![[r#"
[ERROR] package ID specification `baz` did not match any packages
<tab>Did you mean `bar`?
",
)
Did you mean `bar`?
"#]])
.run();

p.cargo("clean -p bar:0.1")
.with_stderr(
"warning: version qualifier in `-p bar:0.1` is ignored, \
cleaning all versions of `bar` found\n\
[REMOVED] [..] files, [..] total",
)
.with_stderr_data(str![[r#"
[WARNING] version qualifier in `-p bar:0.1` is ignored, cleaning all versions of `bar` found
[REMOVED] 14 files, [FILE_SIZE]B total
"#]])
.run();
let mut walker = walkdir::WalkDir::new(p.build_dir())
.into_iter()
Expand Down Expand Up @@ -726,21 +731,20 @@ fn clean_spec_partial_version_ambiguous() {
// Check suggestion for bad pkgid.
p.cargo("clean -p baz")
.with_status(101)
.with_stderr(
"\
error: package ID specification `baz` did not match any packages
.with_stderr_data(str![[r#"
[ERROR] package ID specification `baz` did not match any packages
<tab>Did you mean `bar`?
",
)
Did you mean `bar`?
"#]])
.run();

p.cargo("clean -p bar:0")
.with_stderr(
"warning: version qualifier in `-p bar:0` is ignored, \
cleaning all versions of `bar` found\n\
[REMOVED] [..] files, [..] total",
)
.with_stderr_data(str![[r#"
[WARNING] version qualifier in `-p bar:0` is ignored, cleaning all versions of `bar` found
[REMOVED] 14 files, [FILE_SIZE]B total
"#]])
.run();
let mut walker = walkdir::WalkDir::new(p.build_dir())
.into_iter()
Expand Down Expand Up @@ -794,16 +798,15 @@ fn clean_spec_reserved() {

// This should not rebuild bar.
p.cargo("build -v --all-targets")
.with_stderr(
"\
.with_stderr_data(str![[r#"
[FRESH] bar v1.0.0
[COMPILING] foo v0.1.0 [..]
[RUNNING] `rustc [..]
[RUNNING] `rustc [..]
[RUNNING] `rustc [..]
[FINISHED] [..]
",
)
[COMPILING] foo v0.1.0 ([ROOT]/foo)
[RUNNING] `rustc [..]`
[RUNNING] `rustc [..]`
[RUNNING] `rustc [..]`
[FINISHED] `dev` profile [unoptimized + debuginfo] target(s) in [ELAPSED]s
"#]])
.run();
}

Expand All @@ -829,32 +832,39 @@ fn clean_dry_run() {

// Start with no files.
p.cargo("clean --dry-run")
.with_stdout("")
.with_stderr(
"[SUMMARY] 0 files\n\
[WARNING] no files deleted due to --dry-run",
)
.with_stdout_data("")
.with_stderr_data(str![[r#"
[SUMMARY] 0 files
[WARNING] no files deleted due to --dry-run
"#]])
.run();
p.cargo("check").run();
let before = p.build_dir().ls_r();
p.cargo("clean --dry-run")
.with_stderr(
"[SUMMARY] [..] files, [..] total\n\
[WARNING] no files deleted due to --dry-run",
)
.with_stderr_data(str![[r#"
[SUMMARY] 15 files, [FILE_SIZE]B total
[WARNING] no files deleted due to --dry-run
"#]])
.run();
// Verify it didn't delete anything.
let after = p.build_dir().ls_r();
assert_eq!(before, after);
let expected = itertools::join(before.iter().map(|p| p.to_str().unwrap()), "\n");
let path_stringify = |p: &PathBuf| format!("{}\n", p.to_str().unwrap());
let files = itertools::join(before.iter().map(path_stringify), "");
let re = regex::Regex::new("/(?<head>[a-z0-9\\-_]+)-([0-9a-f]{16})(?<tail>.*)").unwrap();
let expected = re.replace_all(&files, "/$head-[HASH]$tail");
let expected = expected.replace(p.build_dir().to_str().unwrap(), "[ROOT]/foo/target");
eprintln!("{expected}");
// Verify the verbose output.
p.cargo("clean --dry-run -v")
.with_stdout_unordered(expected)
.with_stderr(
"[SUMMARY] [..] files, [..] total\n\
[WARNING] no files deleted due to --dry-run",
)
.with_stdout_data(expected.unordered())
.with_stderr_data(str![[r#"
[SUMMARY] 15 files, [FILE_SIZE]B total
[WARNING] no files deleted due to --dry-run
"#]])
.run();
}

Expand All @@ -864,7 +874,7 @@ fn doc_with_package_selection() {
let p = project().file("src/lib.rs", "").build();
p.cargo("clean --doc -p foo")
.with_status(101)
.with_stderr("error: --doc cannot be used with -p")
.with_stderr_data("[ERROR] --doc cannot be used with -p\n")
.run();
}

Expand All @@ -879,17 +889,16 @@ fn quiet_does_not_show_summary() {

p.cargo("check").run();
p.cargo("clean --quiet --dry-run")
.with_stdout("")
.with_stderr("")
.with_stdout_data("")
.with_stderr_data("")
.run();
// Verify exact same command without -q would actually display something.
p.cargo("clean --dry-run")
.with_stdout("")
.with_stderr(
"\
[SUMMARY] [..] files, [..] total
.with_stdout_data("")
.with_stderr_data(str![[r#"
[SUMMARY] 9 files, [FILE_SIZE]B total
[WARNING] no files deleted due to --dry-run
",
)
"#]])
.run();
}

0 comments on commit b278ca7

Please sign in to comment.