coreutils/tests/by-util/test_basenc.rs
2024-10-05 08:17:10 -05:00

254 lines
5.7 KiB
Rust

// This file is part of the uutils coreutils package.
//
// For the full copyright and license information, please view the LICENSE
// file that was distributed with this source code.
// spell-checker: ignore (encodings) lsbf msbf
use crate::common::util::TestScenario;
#[test]
fn test_z85_not_padded_decode() {
// The z85 crate deviates from the standard in some cases; we have to catch those
new_ucmd!()
.args(&["--z85", "-d"])
.pipe_in("##########")
.fails()
.stderr_only("basenc: error: invalid input\n");
}
#[test]
fn test_z85_not_padded_encode() {
// The z85 crate deviates from the standard in some cases; we have to catch those
new_ucmd!()
.args(&["--z85"])
.pipe_in("123")
.fails()
.stderr_only("basenc: error: invalid input (length must be multiple of 4 characters)\n");
}
#[test]
fn test_invalid_input() {
let error_message = if cfg!(windows) {
"basenc: .: Permission denied\n"
} else {
"basenc: read error: Is a directory\n"
};
new_ucmd!()
.args(&["--base32", "."])
.fails()
.stderr_only(error_message);
}
#[test]
fn test_base64() {
new_ucmd!()
.arg("--base64")
.pipe_in("to>be?")
.succeeds()
.stdout_only("dG8+YmU/\n");
}
#[test]
fn test_base64_decode() {
new_ucmd!()
.args(&["--base64", "-d"])
.pipe_in("dG8+YmU/")
.succeeds()
.stdout_only("to>be?");
}
#[test]
fn test_base64url() {
new_ucmd!()
.arg("--base64url")
.pipe_in("to>be?")
.succeeds()
.stdout_only("dG8-YmU_\n");
}
#[test]
fn test_base64url_decode() {
new_ucmd!()
.args(&["--base64url", "-d"])
.pipe_in("dG8-YmU_")
.succeeds()
.stdout_only("to>be?");
}
#[test]
fn test_base32() {
new_ucmd!()
.arg("--base32")
.pipe_in("nice>base?")
.succeeds()
.stdout_only("NZUWGZJ6MJQXGZJ7\n"); // spell-checker:disable-line
}
#[test]
fn test_base32_decode() {
new_ucmd!()
.args(&["--base32", "-d"])
.pipe_in("NZUWGZJ6MJQXGZJ7") // spell-checker:disable-line
.succeeds()
.stdout_only("nice>base?");
}
#[test]
fn test_base32hex() {
new_ucmd!()
.arg("--base32hex")
.pipe_in("nice>base?")
.succeeds()
.stdout_only("DPKM6P9UC9GN6P9V\n"); // spell-checker:disable-line
}
#[test]
fn test_base32hex_decode() {
new_ucmd!()
.args(&["--base32hex", "-d"])
.pipe_in("DPKM6P9UC9GN6P9V") // spell-checker:disable-line
.succeeds()
.stdout_only("nice>base?");
}
#[test]
fn test_base16() {
new_ucmd!()
.arg("--base16")
.pipe_in("Hello, World!")
.succeeds()
.stdout_only("48656C6C6F2C20576F726C6421\n");
}
#[test]
fn test_base16_decode() {
new_ucmd!()
.args(&["--base16", "-d"])
.pipe_in("48656C6C6F2C20576F726C6421")
.succeeds()
.stdout_only("Hello, World!");
}
#[test]
fn test_base2msbf() {
new_ucmd!()
.arg("--base2msbf")
.pipe_in("msbf")
.succeeds()
.stdout_only("01101101011100110110001001100110\n");
}
#[test]
fn test_base2msbf_decode() {
new_ucmd!()
.args(&["--base2msbf", "-d"])
.pipe_in("01101101011100110110001001100110")
.succeeds()
.stdout_only("msbf");
}
#[test]
fn test_base2lsbf() {
new_ucmd!()
.arg("--base2lsbf")
.pipe_in("lsbf")
.succeeds()
.stdout_only("00110110110011100100011001100110\n");
}
#[test]
fn test_base2lsbf_decode() {
new_ucmd!()
.args(&["--base2lsbf", "-d"])
.pipe_in("00110110110011100100011001100110")
.succeeds()
.stdout_only("lsbf");
}
#[test]
fn test_choose_last_encoding_z85() {
new_ucmd!()
.args(&[
"--base2lsbf",
"--base2msbf",
"--base16",
"--base32hex",
"--base64url",
"--base32",
"--base64",
"--z85",
])
.pipe_in("Hello, World")
.succeeds()
.stdout_only("nm=QNz.92jz/PV8\n");
}
#[test]
fn test_choose_last_encoding_base64() {
new_ucmd!()
.args(&[
"--base2msbf",
"--base2lsbf",
"--base64url",
"--base32hex",
"--base32",
"--base16",
"--z85",
"--base64",
])
.pipe_in("Hello, World!")
.succeeds()
.stdout_only("SGVsbG8sIFdvcmxkIQ==\n"); // spell-checker:disable-line
}
#[test]
fn test_choose_last_encoding_base2lsbf() {
new_ucmd!()
.args(&[
"--base64url",
"--base16",
"--base2msbf",
"--base32",
"--base64",
"--z85",
"--base32hex",
"--base2lsbf",
])
.pipe_in("lsbf")
.succeeds()
.stdout_only("00110110110011100100011001100110\n");
}
#[test]
fn test_base32_decode_repeated() {
new_ucmd!()
.args(&[
"--ignore",
"--wrap=80",
"--base32hex",
"--z85",
"--ignore",
"--decode",
"--z85",
"--base32",
"-w",
"10",
])
.pipe_in("NZUWGZJ6MJQXGZJ7") // spell-checker:disable-line
.succeeds()
.stdout_only("nice>base?");
}
// The restriction that input length has to be divisible by 4 only applies to data being encoded with Z85, not to the
// decoding of Z85-encoded data
#[test]
fn test_z85_length_check() {
new_ucmd!()
.args(&["--decode", "--z85"])
// Input has length 10, not divisible by 4
// spell-checker:disable-next-line
.pipe_in("f!$Kwh8WxM")
.succeeds()
.stdout_only("12345678");
}