From 2ce999c9590fadb551ba908286e348774f70a6ef Mon Sep 17 00:00:00 2001 From: Niyaz Nigmatullin Date: Sat, 17 Sep 2022 19:15:52 +0300 Subject: [PATCH] cp: fix `cp-i` GNU test `cp` in interactive mode used to write to stdout asking for overwrite. GNU version writes to stderr. Changed: write to stderr to make compatible with GNU. --- src/uu/cp/src/cp.rs | 8 ++++---- tests/by-util/test_cp.rs | 2 ++ 2 files changed, 6 insertions(+), 4 deletions(-) diff --git a/src/uu/cp/src/cp.rs b/src/uu/cp/src/cp.rs index ee598b5642d..e82399b42e2 100644 --- a/src/uu/cp/src/cp.rs +++ b/src/uu/cp/src/cp.rs @@ -35,7 +35,7 @@ use std::fs; use std::fs::File; use std::fs::OpenOptions; use std::io; -use std::io::{stdin, stdout, Write}; +use std::io::{stderr, stdin, Write}; #[cfg(unix)] use std::os::unix::ffi::OsStrExt; #[cfg(unix)] @@ -118,9 +118,9 @@ macro_rules! or_continue( /// answered yes. macro_rules! prompt_yes( ($($args:tt)+) => ({ - print!($($args)+); - print!(" [y/N]: "); - crash_if_err!(1, stdout().flush()); + eprint!($($args)+); + eprint!(" [y/N]: "); + crash_if_err!(1, stderr().flush()); let mut s = String::new(); match stdin().read_line(&mut s) { Ok(_) => match s.char_indices().next() { diff --git a/tests/by-util/test_cp.rs b/tests/by-util/test_cp.rs index 56c23fd9618..7671e31bbb4 100644 --- a/tests/by-util/test_cp.rs +++ b/tests/by-util/test_cp.rs @@ -204,6 +204,8 @@ fn test_cp_arg_interactive() { .arg("-i") .pipe_in("N\n") .succeeds() + .no_stdout() + .stderr_contains(format!("overwrite '{}'?", TEST_HOW_ARE_YOU_SOURCE)) .stderr_contains("Not overwriting"); }