mirror of
https://github.com/uutils/coreutils
synced 2025-01-05 17:59:00 +00:00
e894e40c56
* hashsum: add --no-names option from official b3sum tool The official b3sum tool has a --no-names option for only printing the hashes, omitting the filenames. This is quite handy when used from scripts because it spares the postprocessing with "cut" or "awk". Since the installed b3sum symlink would also serve as a drop-in for the official tool, the --no-names option is expected to exist for compatibility. Add a --no-names option not only for b3sum but for hashsum in general (and maybe GNU coreutils will also feel inspired to add this option). Closes https://github.com/uutils/coreutils/issues/3360
94 lines
3.2 KiB
Rust
94 lines
3.2 KiB
Rust
// spell-checker:ignore checkfile, nonames
|
|
macro_rules! get_hash(
|
|
($str:expr) => (
|
|
$str.split(' ').collect::<Vec<&str>>()[0]
|
|
);
|
|
);
|
|
|
|
macro_rules! test_digest {
|
|
($($id:ident $t:ident $size:expr)*) => ($(
|
|
|
|
mod $id {
|
|
use crate::common::util::*;
|
|
static DIGEST_ARG: &'static str = concat!("--", stringify!($t));
|
|
static BITS_ARG: &'static str = concat!("--bits=", stringify!($size));
|
|
static EXPECTED_FILE: &'static str = concat!(stringify!($id), ".expected");
|
|
static CHECK_FILE: &'static str = concat!(stringify!($id), ".checkfile");
|
|
|
|
#[test]
|
|
fn test_single_file() {
|
|
let ts = TestScenario::new("hashsum");
|
|
assert_eq!(ts.fixtures.read(EXPECTED_FILE),
|
|
get_hash!(ts.ucmd().arg(DIGEST_ARG).arg(BITS_ARG).arg("input.txt").succeeds().no_stderr().stdout_str()));
|
|
}
|
|
|
|
#[test]
|
|
fn test_stdin() {
|
|
let ts = TestScenario::new("hashsum");
|
|
assert_eq!(ts.fixtures.read(EXPECTED_FILE),
|
|
get_hash!(ts.ucmd().arg(DIGEST_ARG).arg(BITS_ARG).pipe_in_fixture("input.txt").succeeds().no_stderr().stdout_str()));
|
|
}
|
|
|
|
#[test]
|
|
fn test_nonames() {
|
|
let ts = TestScenario::new("hashsum");
|
|
// EXPECTED_FILE has no newline character at the end
|
|
assert_eq!(format!("{0}\n{0}\n", ts.fixtures.read(EXPECTED_FILE)),
|
|
ts.ucmd().arg(DIGEST_ARG).arg(BITS_ARG).arg("--no-names").arg("input.txt").arg("-").pipe_in_fixture("input.txt")
|
|
.succeeds().no_stderr().stdout_str()
|
|
);
|
|
}
|
|
|
|
#[test]
|
|
fn test_check() {
|
|
let ts = TestScenario::new("hashsum");
|
|
ts.ucmd()
|
|
.args(&[DIGEST_ARG, BITS_ARG, "--check", CHECK_FILE])
|
|
.succeeds()
|
|
.no_stderr()
|
|
.stdout_is("input.txt: OK\n");
|
|
}
|
|
|
|
#[cfg(windows)]
|
|
#[test]
|
|
fn test_text_mode() {
|
|
// TODO Replace this with hard-coded files that store the
|
|
// expected output of text mode on an input file that has
|
|
// "\r\n" line endings.
|
|
let result = new_ucmd!()
|
|
.args(&[DIGEST_ARG, BITS_ARG, "-b"])
|
|
.pipe_in("a\nb\nc\n")
|
|
.succeeds();
|
|
let expected = result.no_stderr().stdout();
|
|
// Replace the "*-\n" at the end of the output with " -\n".
|
|
// The asterisk indicates that the digest was computed in
|
|
// binary mode.
|
|
let n = expected.len();
|
|
let expected = [&expected[..n - 3], &[b' ', b'-', b'\n']].concat();
|
|
new_ucmd!()
|
|
.args(&[DIGEST_ARG, BITS_ARG, "-t"])
|
|
.pipe_in("a\r\nb\r\nc\r\n")
|
|
.succeeds()
|
|
.no_stderr()
|
|
.stdout_is(std::str::from_utf8(&expected).unwrap());
|
|
}
|
|
}
|
|
)*)
|
|
}
|
|
|
|
test_digest! {
|
|
md5 md5 128
|
|
sha1 sha1 160
|
|
sha224 sha224 224
|
|
sha256 sha256 256
|
|
sha384 sha384 384
|
|
sha512 sha512 512
|
|
sha3_224 sha3 224
|
|
sha3_256 sha3 256
|
|
sha3_384 sha3 384
|
|
sha3_512 sha3 512
|
|
shake128_256 shake128 256
|
|
shake256_512 shake256 512
|
|
b2sum b2sum 512
|
|
b3sum b3sum 256
|
|
}
|