mirror of
https://github.com/uutils/coreutils
synced 2025-01-20 17:14:21 +00:00
139 lines
3 KiB
Rust
139 lines
3 KiB
Rust
use crate::common::util::*;
|
||
use std::ffi::OsStr;
|
||
|
||
#[test]
|
||
fn test_help() {
|
||
for help_flg in vec!["-h", "--help"] {
|
||
new_ucmd!()
|
||
.arg(&help_flg)
|
||
.succeeds()
|
||
.no_stderr()
|
||
.stdout_contains("USAGE:");
|
||
}
|
||
}
|
||
|
||
#[test]
|
||
fn test_version() {
|
||
for version_flg in vec!["-V", "--version"] {
|
||
assert!(new_ucmd!()
|
||
.arg(&version_flg)
|
||
.succeeds()
|
||
.no_stderr()
|
||
.stdout_str()
|
||
.starts_with("basename"));
|
||
}
|
||
}
|
||
|
||
#[test]
|
||
fn test_directory() {
|
||
new_ucmd!()
|
||
.args(&["/root/alpha/beta/gamma/delta/epsilon/omega/"])
|
||
.succeeds()
|
||
.stdout_only("omega\n");
|
||
}
|
||
|
||
#[test]
|
||
fn test_file() {
|
||
new_ucmd!()
|
||
.args(&["/etc/passwd"])
|
||
.succeeds()
|
||
.stdout_only("passwd\n");
|
||
}
|
||
|
||
#[test]
|
||
fn test_remove_suffix() {
|
||
new_ucmd!()
|
||
.args(&["/usr/local/bin/reallylongexecutable.exe", ".exe"])
|
||
.succeeds()
|
||
.stdout_only("reallylongexecutable\n");
|
||
}
|
||
|
||
#[test]
|
||
fn test_dont_remove_suffix() {
|
||
new_ucmd!()
|
||
.args(&["/foo/bar/baz", "baz"])
|
||
.succeeds()
|
||
.stdout_only("baz\n");
|
||
}
|
||
|
||
#[test]
|
||
fn test_multiple_param() {
|
||
for multiple_param in vec!["-a", "--multiple"] {
|
||
let path = "/foo/bar/baz";
|
||
new_ucmd!()
|
||
.args(&[multiple_param, path, path])
|
||
.succeeds()
|
||
.stdout_only("baz\nbaz\n");
|
||
}
|
||
}
|
||
|
||
#[test]
|
||
fn test_suffix_param() {
|
||
for suffix_param in vec!["-s", "--suffix"] {
|
||
let path = "/foo/bar/baz.exe";
|
||
new_ucmd!()
|
||
.args(&[suffix_param, ".exe", path, path])
|
||
.succeeds()
|
||
.stdout_only("baz\nbaz\n");
|
||
}
|
||
}
|
||
|
||
#[test]
|
||
fn test_zero_param() {
|
||
for zero_param in vec!["-z", "--zero"] {
|
||
let path = "/foo/bar/baz";
|
||
new_ucmd!()
|
||
.args(&[zero_param, "-a", path, path])
|
||
.succeeds()
|
||
.stdout_only("baz\0baz\0");
|
||
}
|
||
}
|
||
|
||
fn expect_error(input: Vec<&str>) {
|
||
assert!(new_ucmd!().args(&input).fails().no_stdout().stderr().len() > 0);
|
||
}
|
||
|
||
#[test]
|
||
fn test_invalid_option() {
|
||
let path = "/foo/bar/baz";
|
||
expect_error(vec!["-q", path]);
|
||
}
|
||
|
||
#[test]
|
||
fn test_no_args() {
|
||
expect_error(vec![]);
|
||
}
|
||
|
||
#[test]
|
||
fn test_no_args_output() {
|
||
new_ucmd!()
|
||
.fails()
|
||
.stderr_is("basename: error: missing operand\nTry 'basename --help' for more information.");
|
||
}
|
||
|
||
#[test]
|
||
fn test_too_many_args() {
|
||
expect_error(vec!["a", "b", "c"]);
|
||
}
|
||
|
||
#[test]
|
||
fn test_too_many_args_output() {
|
||
new_ucmd!().args(&["a", "b", "c"]).fails().stderr_is(
|
||
"basename: error: extra operand 'c'\nTry 'basename --help' for more information.",
|
||
);
|
||
}
|
||
|
||
fn test_invalid_utf8_args(os_str: &OsStr) {
|
||
let test_vec = vec![os_str.to_os_string()];
|
||
new_ucmd!().args(&test_vec).succeeds().stdout_is("fo<EFBFBD>o\n");
|
||
}
|
||
|
||
#[cfg(any(unix, target_os = "redox"))]
|
||
#[test]
|
||
fn invalid_utf8_args_unix() {
|
||
use std::os::unix::ffi::OsStrExt;
|
||
|
||
let source = [0x66, 0x6f, 0x80, 0x6f];
|
||
let os_str = OsStr::from_bytes(&source[..]);
|
||
test_invalid_utf8_args(os_str);
|
||
}
|