mirror of
https://github.com/uutils/coreutils
synced 2024-12-12 22:32:53 +00:00
tests: disable some chgrp tests when part of the root group
Some tests failed when run using Docker because they assumed the user would never be root. This is more of a band-aid solution. An actual fix would be to test see if something like these tests were to succeed when the user is root.
This commit is contained in:
parent
8ece01d0ef
commit
d8e738c49b
5 changed files with 298 additions and 249 deletions
456
Cargo.lock
generated
456
Cargo.lock
generated
File diff suppressed because it is too large
Load diff
|
@ -252,6 +252,7 @@ unindent = "0.1.0"
|
||||||
lazy_static = "0.2.2"
|
lazy_static = "0.2.2"
|
||||||
|
|
||||||
[target.'cfg(unix)'.dev-dependencies]
|
[target.'cfg(unix)'.dev-dependencies]
|
||||||
|
rust-users = { git = "https://github.com/Arcterus/rust-users" }
|
||||||
unix_socket = "0.5.0"
|
unix_socket = "0.5.0"
|
||||||
|
|
||||||
[[bin]]
|
[[bin]]
|
||||||
|
|
|
@ -18,8 +18,11 @@ mod platform {
|
||||||
fn main() {
|
fn main() {
|
||||||
mkmain::main();
|
mkmain::main();
|
||||||
|
|
||||||
|
let manifest_dir = env::var("CARGO_MANIFEST_DIR").expect("Could not find manifest dir");
|
||||||
|
let profile = env::var("PROFILE").expect("Could not determine profile");
|
||||||
|
|
||||||
let out_dir = env::var("OUT_DIR").unwrap();
|
let out_dir = env::var("OUT_DIR").unwrap();
|
||||||
let libstdbuf = format!("{}/../../{}/{}/deps/liblibstdbuf{}", env::var("CARGO_MANIFEST_DIR").unwrap(), env::var("CARGO_TARGET_DIR").unwrap_or("target".to_string()), env::var("PROFILE").unwrap(), platform::DYLIB_EXT);
|
let libstdbuf = format!("{}/../../{}/{}/deps/liblibstdbuf{}", manifest_dir, env::var("CARGO_TARGET_DIR").unwrap_or("target".to_string()), profile, platform::DYLIB_EXT);
|
||||||
|
|
||||||
fs::copy(libstdbuf, Path::new(&out_dir).join("libstdbuf.so")).unwrap();
|
fs::copy(libstdbuf, Path::new(&out_dir).join("libstdbuf.so")).unwrap();
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
use common::util::*;
|
use common::util::*;
|
||||||
|
use rust_users::*;
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_invalid_option() {
|
fn test_invalid_option() {
|
||||||
|
@ -14,30 +14,34 @@ static DIR: &'static str = "/tmp";
|
||||||
#[test]
|
#[test]
|
||||||
fn test_invalid_group() {
|
fn test_invalid_group() {
|
||||||
new_ucmd!()
|
new_ucmd!()
|
||||||
.arg("nosuchgroup")
|
.arg("__nosuchgroup__")
|
||||||
.arg("/")
|
.arg("/")
|
||||||
.fails()
|
.fails()
|
||||||
.stderr_is("chgrp: invalid group: nosuchgroup");
|
.stderr_is("chgrp: invalid group: __nosuchgroup__");
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_1() {
|
fn test_1() {
|
||||||
new_ucmd!()
|
if get_effective_gid() != 0 {
|
||||||
.arg("bin")
|
new_ucmd!()
|
||||||
.arg(DIR)
|
.arg("bin")
|
||||||
.fails()
|
.arg(DIR)
|
||||||
.stderr_is("chgrp: changing group of '/tmp': Operation not permitted (os error 1)");
|
.fails()
|
||||||
|
.stderr_is("chgrp: changing group of '/tmp': Operation not permitted (os error 1)");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_fail_silently() {
|
fn test_fail_silently() {
|
||||||
for opt in &["-f", "--silent", "--quiet"] {
|
if get_effective_gid() != 0 {
|
||||||
new_ucmd!()
|
for opt in &["-f", "--silent", "--quiet"] {
|
||||||
.arg(opt)
|
new_ucmd!()
|
||||||
.arg("bin")
|
.arg(opt)
|
||||||
.arg(DIR)
|
.arg("bin")
|
||||||
.run()
|
.arg(DIR)
|
||||||
.fails_silently();
|
.run()
|
||||||
|
.fails_silently();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -94,13 +98,15 @@ fn test_preserve_root_symlink() {
|
||||||
#[test]
|
#[test]
|
||||||
#[cfg(target_os = "linux")]
|
#[cfg(target_os = "linux")]
|
||||||
fn test_reference() {
|
fn test_reference() {
|
||||||
new_ucmd!()
|
if get_effective_gid() != 0 {
|
||||||
.arg("-v")
|
new_ucmd!()
|
||||||
.arg("--reference=/etc/passwd")
|
.arg("-v")
|
||||||
.arg("/etc")
|
.arg("--reference=/etc/passwd")
|
||||||
.fails()
|
.arg("/etc")
|
||||||
.stderr_is("chgrp: changing group of '/etc': Operation not permitted (os error 1)\n")
|
.fails()
|
||||||
.stdout_is("failed to change group of /etc from root to root\n");
|
.stderr_is("chgrp: changing group of '/etc': Operation not permitted (os error 1)\n")
|
||||||
|
.stdout_is("failed to change group of /etc from root to root\n");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -116,23 +122,27 @@ fn test_reference() {
|
||||||
#[test]
|
#[test]
|
||||||
#[cfg(target_os = "linux")]
|
#[cfg(target_os = "linux")]
|
||||||
fn test_big_p() {
|
fn test_big_p() {
|
||||||
new_ucmd!()
|
if get_effective_gid() != 0 {
|
||||||
.arg("-RP")
|
new_ucmd!()
|
||||||
.arg("bin")
|
.arg("-RP")
|
||||||
.arg("/proc/self/cwd")
|
.arg("bin")
|
||||||
.fails()
|
.arg("/proc/self/cwd")
|
||||||
.stderr_is("chgrp: changing group of '/proc/self/cwd': Operation not permitted (os error 1)\n");
|
.fails()
|
||||||
|
.stderr_is("chgrp: changing group of '/proc/self/cwd': Operation not permitted (os error 1)\n");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
#[cfg(target_os = "linux")]
|
#[cfg(target_os = "linux")]
|
||||||
fn test_big_h() {
|
fn test_big_h() {
|
||||||
assert!(new_ucmd!()
|
if get_effective_gid() != 0 {
|
||||||
.arg("-RH")
|
assert!(new_ucmd!()
|
||||||
.arg("bin")
|
.arg("-RH")
|
||||||
.arg("/proc/self/fd")
|
.arg("bin")
|
||||||
.fails()
|
.arg("/proc/self/fd")
|
||||||
.stderr
|
.fails()
|
||||||
.lines()
|
.stderr
|
||||||
.fold(0, |acc, _| acc + 1) > 1);
|
.lines()
|
||||||
|
.fold(0, |acc, _| acc + 1) > 1);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,6 +4,9 @@ mod common;
|
||||||
#[macro_use]
|
#[macro_use]
|
||||||
extern crate lazy_static;
|
extern crate lazy_static;
|
||||||
|
|
||||||
|
#[cfg(unix)]
|
||||||
|
extern crate rust_users;
|
||||||
|
|
||||||
// For conditional compilation
|
// For conditional compilation
|
||||||
macro_rules! unix_only {
|
macro_rules! unix_only {
|
||||||
($($fea:expr, $m:ident);+) => {
|
($($fea:expr, $m:ident);+) => {
|
||||||
|
|
Loading…
Reference in a new issue