2020-05-25 17:05:26 +00:00
use crate ::common ::util ::* ;
2020-05-07 23:01:47 +00:00
2021-06-23 10:27:01 +00:00
// spell-checker:ignore (ToDO) coreutil
2021-06-13 13:39:31 +00:00
2021-06-16 18:45:46 +00:00
// These tests run the GNU coreutils `(g)id` binary in `$PATH` in order to gather reference values.
// If the `(g)id` in `$PATH` doesn't include a coreutils version string,
// or the version is too low, the test is skipped.
// The reference version is 8.32. Here 8.30 was chosen because right now there's no
// ubuntu image for github action available with a higher version than 8.30.
2021-06-23 10:27:01 +00:00
const VERSION_MIN : & str = " 8.30 " ; // minimum Version for the reference `id` in $PATH
const VERSION_MIN_MULTIPLE_USERS : & str = " 8.31 " ; // this feature was introduced in GNU's coreutils 8.31
2021-06-13 13:39:31 +00:00
const UUTILS_WARNING : & str = " uutils-tests-warning " ;
const UUTILS_INFO : & str = " uutils-tests-info " ;
macro_rules ! unwrap_or_return {
( $e :expr ) = > {
match $e {
Ok ( x ) = > x ,
Err ( e ) = > {
println! ( " {} : test skipped: {} " , UUTILS_INFO , e ) ;
return ;
}
}
} ;
}
2021-06-11 10:00:26 +00:00
fn whoami ( ) -> String {
2021-06-16 18:45:46 +00:00
// Apparently some CI environments have configuration issues, e.g. with 'whoami' and 'id'.
//
// From the Logs: "Build (ubuntu-18.04, x86_64-unknown-linux-gnu, feat_os_unix, use-cross)"
// whoami: cannot find name for user ID 1001
// id --name: cannot find name for user ID 1001
// id --name: cannot find name for group ID 116
//
// However, when running "id" from within "/bin/bash" it looks fine:
// id: "uid=1001(runner) gid=118(docker) groups=118(docker),4(adm),101(systemd-journal)"
// whoami: "runner"
2021-06-13 13:39:31 +00:00
// Use environment variable to get current user instead of
// invoking `whoami` and fall back to user "nobody" on error.
2021-06-11 10:00:26 +00:00
std ::env ::var ( " USER " ) . unwrap_or_else ( | e | {
2021-06-13 13:39:31 +00:00
println! ( " {} : {} , using \" nobody \" instead " , UUTILS_WARNING , e ) ;
2021-06-11 10:00:26 +00:00
" nobody " . to_string ( )
} )
2020-11-21 08:52:50 +00:00
}
2020-05-07 23:01:47 +00:00
#[ test ]
2021-06-11 10:00:26 +00:00
#[ cfg(unix) ]
2021-06-13 09:11:04 +00:00
fn test_id_no_specified_user ( ) {
2021-06-11 10:00:26 +00:00
let result = new_ucmd! ( ) . run ( ) ;
2021-06-13 13:39:31 +00:00
let exp_result = unwrap_or_return! ( expected_result ( & [ ] ) ) ;
let mut _exp_stdout = exp_result . stdout_str ( ) . to_string ( ) ;
2021-06-11 10:00:26 +00:00
2021-06-13 13:39:31 +00:00
#[ cfg(target_os = " linux " ) ]
{
2021-06-16 18:45:46 +00:00
// NOTE: (SELinux NotImplemented) strip 'context' part from exp_stdout:
if let Some ( context_offset ) = exp_result . stdout_str ( ) . find ( " context= " ) {
_exp_stdout . replace_range ( context_offset .. _exp_stdout . len ( ) - 1 , " " ) ;
}
2021-06-13 13:39:31 +00:00
}
2020-05-07 23:01:47 +00:00
2021-06-11 10:00:26 +00:00
result
2021-06-13 13:39:31 +00:00
. stdout_is ( _exp_stdout )
. stderr_is ( exp_result . stderr_str ( ) )
. code_is ( exp_result . code ( ) ) ;
2021-06-11 10:00:26 +00:00
}
2021-04-05 20:03:43 +00:00
2021-06-11 10:00:26 +00:00
#[ test ]
#[ cfg(unix) ]
fn test_id_single_user ( ) {
2021-06-13 09:11:04 +00:00
let test_users = [ & whoami ( ) [ .. ] ] ;
let scene = TestScenario ::new ( util_name! ( ) ) ;
2021-06-13 13:39:31 +00:00
let mut exp_result = unwrap_or_return! ( expected_result ( & test_users ) ) ;
2021-06-13 09:11:04 +00:00
scene
. ucmd ( )
. args ( & test_users )
. run ( )
. stdout_is ( exp_result . stdout_str ( ) )
2021-06-13 13:39:31 +00:00
. stderr_is ( exp_result . stderr_str ( ) . replace ( " : Invalid argument " , " " ) )
2021-06-13 09:11:04 +00:00
. code_is ( exp_result . code ( ) ) ;
// u/g/G z/n
for & opt in & [ " --user " , " --group " , " --groups " ] {
let mut args = vec! [ opt ] ;
args . extend_from_slice ( & test_users ) ;
2021-06-13 13:39:31 +00:00
exp_result = unwrap_or_return! ( expected_result ( & args ) ) ;
2021-06-13 09:11:04 +00:00
scene
. ucmd ( )
. args ( & args )
. run ( )
. stdout_is ( exp_result . stdout_str ( ) )
2021-06-13 13:39:31 +00:00
. stderr_is ( exp_result . stderr_str ( ) . replace ( " : Invalid argument " , " " ) )
2021-06-13 09:11:04 +00:00
. code_is ( exp_result . code ( ) ) ;
args . push ( " --zero " ) ;
2021-06-13 13:39:31 +00:00
exp_result = unwrap_or_return! ( expected_result ( & args ) ) ;
2021-06-13 09:11:04 +00:00
scene
. ucmd ( )
. args ( & args )
. run ( )
. stdout_is ( exp_result . stdout_str ( ) )
2021-06-13 13:39:31 +00:00
. stderr_is ( exp_result . stderr_str ( ) . replace ( " : Invalid argument " , " " ) )
2021-06-13 09:11:04 +00:00
. code_is ( exp_result . code ( ) ) ;
args . push ( " --name " ) ;
2021-06-13 13:39:31 +00:00
exp_result = unwrap_or_return! ( expected_result ( & args ) ) ;
2021-06-13 09:11:04 +00:00
scene
. ucmd ( )
. args ( & args )
. run ( )
. stdout_is ( exp_result . stdout_str ( ) )
2021-06-13 13:39:31 +00:00
. stderr_is ( exp_result . stderr_str ( ) . replace ( " : Invalid argument " , " " ) )
2021-06-13 09:11:04 +00:00
. code_is ( exp_result . code ( ) ) ;
args . pop ( ) ;
2021-06-13 13:39:31 +00:00
exp_result = unwrap_or_return! ( expected_result ( & args ) ) ;
2021-06-13 09:11:04 +00:00
scene
. ucmd ( )
. args ( & args )
. run ( )
. stdout_is ( exp_result . stdout_str ( ) )
2021-06-13 13:39:31 +00:00
. stderr_is ( exp_result . stderr_str ( ) . replace ( " : Invalid argument " , " " ) )
2021-06-13 09:11:04 +00:00
. code_is ( exp_result . code ( ) ) ;
}
2020-05-07 23:01:47 +00:00
}
#[ test ]
2021-06-11 10:00:26 +00:00
#[ cfg(unix) ]
2021-06-13 09:11:04 +00:00
fn test_id_single_user_non_existing ( ) {
2021-06-11 10:00:26 +00:00
let args = & [ " hopefully_non_existing_username " ] ;
let result = new_ucmd! ( ) . args ( args ) . run ( ) ;
2021-06-13 13:39:31 +00:00
let exp_result = unwrap_or_return! ( expected_result ( args ) ) ;
2021-06-16 18:45:46 +00:00
// It is unknown why on macOS (and possibly others?) `id` adds "Invalid argument".
2021-06-13 13:39:31 +00:00
// coreutils 8.32: $ LC_ALL=C id foobar
// macOS: stderr: "id: 'foobar': no such user: Invalid argument"
// linux: stderr: "id: 'foobar': no such user"
2021-06-11 10:00:26 +00:00
result
2021-06-13 13:39:31 +00:00
. stdout_is ( exp_result . stdout_str ( ) )
. stderr_is ( exp_result . stderr_str ( ) . replace ( " : Invalid argument " , " " ) )
. code_is ( exp_result . code ( ) ) ;
2021-06-11 10:00:26 +00:00
}
2021-04-17 20:29:07 +00:00
2021-06-11 10:00:26 +00:00
#[ test ]
#[ cfg(unix) ]
fn test_id_name ( ) {
2021-04-17 20:29:07 +00:00
let scene = TestScenario ::new ( util_name! ( ) ) ;
2021-06-11 10:00:26 +00:00
for & opt in & [ " --user " , " --group " , " --groups " ] {
let args = [ opt , " --name " ] ;
let result = scene . ucmd ( ) . args ( & args ) . run ( ) ;
2021-06-13 13:39:31 +00:00
let exp_result = unwrap_or_return! ( expected_result ( & args ) ) ;
2021-06-11 10:00:26 +00:00
result
2021-06-13 13:39:31 +00:00
. stdout_is ( exp_result . stdout_str ( ) )
. stderr_is ( exp_result . stderr_str ( ) )
. code_is ( exp_result . code ( ) ) ;
2021-06-11 10:00:26 +00:00
if opt = = " --user " {
assert_eq! ( result . stdout_str ( ) . trim_end ( ) , whoami ( ) ) ;
}
2021-04-17 20:29:07 +00:00
}
2020-05-07 23:01:47 +00:00
}
#[ test ]
2021-06-11 10:00:26 +00:00
#[ cfg(unix) ]
fn test_id_real ( ) {
let scene = TestScenario ::new ( util_name! ( ) ) ;
for & opt in & [ " --user " , " --group " , " --groups " ] {
let args = [ opt , " --real " ] ;
let result = scene . ucmd ( ) . args ( & args ) . run ( ) ;
2021-06-13 13:39:31 +00:00
let exp_result = unwrap_or_return! ( expected_result ( & args ) ) ;
2021-06-11 10:00:26 +00:00
result
2021-06-13 13:39:31 +00:00
. stdout_is ( exp_result . stdout_str ( ) )
. stderr_is ( exp_result . stderr_str ( ) )
. code_is ( exp_result . code ( ) ) ;
2020-05-07 23:01:47 +00:00
}
}
2020-11-21 08:52:50 +00:00
#[ test ]
2021-06-11 10:00:26 +00:00
#[ cfg(all(unix, not(target_os = " linux " ))) ]
2020-11-21 08:52:50 +00:00
fn test_id_pretty_print ( ) {
2021-06-11 10:00:26 +00:00
// `-p` is BSD only and not supported on GNU's `id`
let username = whoami ( ) ;
2020-11-21 08:52:50 +00:00
2021-06-11 10:00:26 +00:00
let result = new_ucmd! ( ) . arg ( " -p " ) . run ( ) ;
2021-04-17 20:29:07 +00:00
if result . stdout_str ( ) . trim ( ) . is_empty ( ) {
// this fails only on: "MinRustV (ubuntu-latest, feat_os_unix)"
// `rustc 1.40.0 (73528e339 2019-12-16)`
// run: /home/runner/work/coreutils/coreutils/target/debug/coreutils id -p
// thread 'test_id::test_id_pretty_print' panicked at 'Command was expected to succeed.
// stdout =
// stderr = ', tests/common/util.rs:157:13
println! ( " test skipped: " ) ;
2021-06-11 10:00:26 +00:00
} else {
result . success ( ) . stdout_contains ( username ) ;
2020-11-21 08:52:50 +00:00
}
}
#[ test ]
2021-06-11 10:00:26 +00:00
#[ cfg(all(unix, not(target_os = " linux " ))) ]
2020-11-21 08:52:50 +00:00
fn test_id_password_style ( ) {
2021-06-11 10:00:26 +00:00
// `-P` is BSD only and not supported on GNU's `id`
let username = whoami ( ) ;
let result = new_ucmd! ( ) . arg ( " -P " ) . arg ( & username ) . succeeds ( ) ;
2021-04-05 20:03:43 +00:00
assert! ( result . stdout_str ( ) . starts_with ( & username ) ) ;
2020-11-21 08:52:50 +00:00
}
2021-06-05 22:03:53 +00:00
2021-06-11 10:00:26 +00:00
#[ test ]
#[ cfg(unix) ]
fn test_id_multiple_users ( ) {
2021-06-16 18:45:46 +00:00
#[ cfg(target_os = " linux " ) ]
let util_name = util_name! ( ) ;
#[ cfg(all(unix, not(target_os = " linux " ))) ]
let util_name = & format! ( " g {} " , util_name! ( ) ) ;
2021-06-23 10:27:01 +00:00
let version_check_string = check_coreutil_version ( util_name , VERSION_MIN_MULTIPLE_USERS ) ;
2021-06-16 18:45:46 +00:00
if version_check_string . starts_with ( UUTILS_WARNING ) {
println! ( " {} \n test skipped " , version_check_string ) ;
return ;
}
2021-06-23 10:27:01 +00:00
// Same typical users that GNU test suite is using.
2021-06-11 10:00:26 +00:00
let test_users = [ " root " , " man " , " postfix " , " sshd " , & whoami ( ) ] ;
2021-06-13 09:11:04 +00:00
let scene = TestScenario ::new ( util_name! ( ) ) ;
2021-06-13 13:39:31 +00:00
let mut exp_result = unwrap_or_return! ( expected_result ( & test_users ) ) ;
2021-06-13 09:11:04 +00:00
scene
. ucmd ( )
. args ( & test_users )
. run ( )
. stdout_is ( exp_result . stdout_str ( ) )
2021-06-13 13:39:31 +00:00
. stderr_is ( exp_result . stderr_str ( ) . replace ( " : Invalid argument " , " " ) )
2021-06-13 09:11:04 +00:00
. code_is ( exp_result . code ( ) ) ;
// u/g/G z/n
for & opt in & [ " --user " , " --group " , " --groups " ] {
let mut args = vec! [ opt ] ;
args . extend_from_slice ( & test_users ) ;
2021-06-13 13:39:31 +00:00
exp_result = unwrap_or_return! ( expected_result ( & args ) ) ;
2021-06-13 09:11:04 +00:00
scene
. ucmd ( )
. args ( & args )
. run ( )
. stdout_is ( exp_result . stdout_str ( ) )
2021-06-13 13:39:31 +00:00
. stderr_is ( exp_result . stderr_str ( ) . replace ( " : Invalid argument " , " " ) )
2021-06-13 09:11:04 +00:00
. code_is ( exp_result . code ( ) ) ;
args . push ( " --zero " ) ;
2021-06-13 13:39:31 +00:00
exp_result = unwrap_or_return! ( expected_result ( & args ) ) ;
2021-06-13 09:11:04 +00:00
scene
. ucmd ( )
. args ( & args )
. run ( )
. stdout_is ( exp_result . stdout_str ( ) )
2021-06-13 13:39:31 +00:00
. stderr_is ( exp_result . stderr_str ( ) . replace ( " : Invalid argument " , " " ) )
2021-06-13 09:11:04 +00:00
. code_is ( exp_result . code ( ) ) ;
args . push ( " --name " ) ;
2021-06-13 13:39:31 +00:00
exp_result = unwrap_or_return! ( expected_result ( & args ) ) ;
2021-06-13 09:11:04 +00:00
scene
. ucmd ( )
. args ( & args )
. run ( )
. stdout_is ( exp_result . stdout_str ( ) )
2021-06-13 13:39:31 +00:00
. stderr_is ( exp_result . stderr_str ( ) . replace ( " : Invalid argument " , " " ) )
2021-06-13 09:11:04 +00:00
. code_is ( exp_result . code ( ) ) ;
args . pop ( ) ;
2021-06-13 13:39:31 +00:00
exp_result = unwrap_or_return! ( expected_result ( & args ) ) ;
2021-06-13 09:11:04 +00:00
scene
. ucmd ( )
. args ( & args )
. run ( )
. stdout_is ( exp_result . stdout_str ( ) )
2021-06-13 13:39:31 +00:00
. stderr_is ( exp_result . stderr_str ( ) . replace ( " : Invalid argument " , " " ) )
2021-06-13 09:11:04 +00:00
. code_is ( exp_result . code ( ) ) ;
}
2021-06-11 10:00:26 +00:00
}
#[ test ]
#[ cfg(unix) ]
2021-06-13 09:11:04 +00:00
fn test_id_multiple_users_non_existing ( ) {
2021-06-16 18:45:46 +00:00
#[ cfg(target_os = " linux " ) ]
let util_name = util_name! ( ) ;
#[ cfg(all(unix, not(target_os = " linux " ))) ]
let util_name = & format! ( " g {} " , util_name! ( ) ) ;
2021-06-23 10:27:01 +00:00
let version_check_string = check_coreutil_version ( util_name , VERSION_MIN_MULTIPLE_USERS ) ;
2021-06-16 18:45:46 +00:00
if version_check_string . starts_with ( UUTILS_WARNING ) {
println! ( " {} \n test skipped " , version_check_string ) ;
return ;
}
2021-06-11 10:00:26 +00:00
let test_users = [
" root " ,
" hopefully_non_existing_username1 " ,
2021-06-13 09:11:04 +00:00
& whoami ( ) ,
2021-06-11 10:00:26 +00:00
" man " ,
2021-06-13 09:11:04 +00:00
" hopefully_non_existing_username2 " ,
" hopefully_non_existing_username3 " ,
2021-06-11 10:00:26 +00:00
" postfix " ,
" sshd " ,
2021-06-13 09:11:04 +00:00
" hopefully_non_existing_username4 " ,
2021-06-11 10:00:26 +00:00
& whoami ( ) ,
] ;
2021-06-13 09:11:04 +00:00
let scene = TestScenario ::new ( util_name! ( ) ) ;
2021-06-13 13:39:31 +00:00
let mut exp_result = unwrap_or_return! ( expected_result ( & test_users ) ) ;
2021-06-13 09:11:04 +00:00
scene
. ucmd ( )
. args ( & test_users )
. run ( )
. stdout_is ( exp_result . stdout_str ( ) )
2021-06-13 13:39:31 +00:00
. stderr_is ( exp_result . stderr_str ( ) . replace ( " : Invalid argument " , " " ) )
2021-06-13 09:11:04 +00:00
. code_is ( exp_result . code ( ) ) ;
// u/g/G z/n
for & opt in & [ " --user " , " --group " , " --groups " ] {
let mut args = vec! [ opt ] ;
args . extend_from_slice ( & test_users ) ;
2021-06-13 13:39:31 +00:00
exp_result = unwrap_or_return! ( expected_result ( & args ) ) ;
2021-06-13 09:11:04 +00:00
scene
. ucmd ( )
. args ( & args )
. run ( )
. stdout_is ( exp_result . stdout_str ( ) )
2021-06-13 13:39:31 +00:00
. stderr_is ( exp_result . stderr_str ( ) . replace ( " : Invalid argument " , " " ) )
2021-06-13 09:11:04 +00:00
. code_is ( exp_result . code ( ) ) ;
args . push ( " --zero " ) ;
2021-06-13 13:39:31 +00:00
exp_result = unwrap_or_return! ( expected_result ( & args ) ) ;
2021-06-13 09:11:04 +00:00
scene
. ucmd ( )
. args ( & args )
. run ( )
. stdout_is ( exp_result . stdout_str ( ) )
2021-06-13 13:39:31 +00:00
. stderr_is ( exp_result . stderr_str ( ) . replace ( " : Invalid argument " , " " ) )
2021-06-13 09:11:04 +00:00
. code_is ( exp_result . code ( ) ) ;
args . push ( " --name " ) ;
2021-06-13 13:39:31 +00:00
exp_result = unwrap_or_return! ( expected_result ( & args ) ) ;
2021-06-13 09:11:04 +00:00
scene
. ucmd ( )
. args ( & args )
. run ( )
. stdout_is ( exp_result . stdout_str ( ) )
2021-06-13 13:39:31 +00:00
. stderr_is ( exp_result . stderr_str ( ) . replace ( " : Invalid argument " , " " ) )
2021-06-13 09:11:04 +00:00
. code_is ( exp_result . code ( ) ) ;
args . pop ( ) ;
2021-06-13 13:39:31 +00:00
exp_result = unwrap_or_return! ( expected_result ( & args ) ) ;
2021-06-13 09:11:04 +00:00
scene
. ucmd ( )
. args ( & args )
. run ( )
. stdout_is ( exp_result . stdout_str ( ) )
2021-06-13 13:39:31 +00:00
. stderr_is ( exp_result . stderr_str ( ) . replace ( " : Invalid argument " , " " ) )
2021-06-13 09:11:04 +00:00
. code_is ( exp_result . code ( ) ) ;
}
}
#[ test ]
#[ cfg(unix) ]
fn test_id_default_format ( ) {
let scene = TestScenario ::new ( util_name! ( ) ) ;
for & opt1 in & [ " --name " , " --real " ] {
// id: cannot print only names or real IDs in default format
let args = [ opt1 ] ;
scene
. ucmd ( )
. args ( & args )
. fails ( )
2021-06-13 13:39:31 +00:00
. stderr_only ( unwrap_or_return! ( expected_result ( & args ) ) . stderr_str ( ) ) ;
2021-06-13 09:11:04 +00:00
for & opt2 in & [ " --user " , " --group " , " --groups " ] {
// u/g/G n/r
let args = [ opt2 , opt1 ] ;
let result = scene . ucmd ( ) . args ( & args ) . run ( ) ;
2021-06-13 13:39:31 +00:00
let exp_result = unwrap_or_return! ( expected_result ( & args ) ) ;
2021-06-13 09:11:04 +00:00
result
. stdout_is ( exp_result . stdout_str ( ) )
. stderr_is ( exp_result . stderr_str ( ) )
. code_is ( exp_result . code ( ) ) ;
}
}
for & opt2 in & [ " --user " , " --group " , " --groups " ] {
// u/g/G
let args = [ opt2 ] ;
scene
. ucmd ( )
. args ( & args )
. succeeds ( )
2021-06-13 13:39:31 +00:00
. stdout_only ( unwrap_or_return! ( expected_result ( & args ) ) . stdout_str ( ) ) ;
2021-06-13 09:11:04 +00:00
}
2021-06-11 10:00:26 +00:00
}
2021-06-05 22:03:53 +00:00
#[ test ]
2021-06-10 08:33:22 +00:00
#[ cfg(unix) ]
2021-06-05 22:03:53 +00:00
fn test_id_zero ( ) {
2021-06-09 11:24:28 +00:00
let scene = TestScenario ::new ( util_name! ( ) ) ;
2021-06-05 22:03:53 +00:00
for z_flag in & [ " -z " , " --zero " ] {
2021-06-13 09:11:04 +00:00
// id: option --zero not permitted in default format
scene
. ucmd ( )
. args ( & [ z_flag ] )
. fails ( )
2021-06-13 13:39:31 +00:00
. stderr_only ( unwrap_or_return! ( expected_result ( & [ z_flag ] ) ) . stderr_str ( ) ) ;
2021-06-09 11:24:28 +00:00
for & opt1 in & [ " --name " , " --real " ] {
// id: cannot print only names or real IDs in default format
let args = [ opt1 , z_flag ] ;
scene
. ucmd ( )
2021-06-05 22:03:53 +00:00
. args ( & args )
. fails ( )
2021-06-13 13:39:31 +00:00
. stderr_only ( unwrap_or_return! ( expected_result ( & args ) ) . stderr_str ( ) ) ;
2021-06-09 11:24:28 +00:00
for & opt2 in & [ " --user " , " --group " , " --groups " ] {
// u/g/G n/r z
let args = [ opt2 , z_flag , opt1 ] ;
let result = scene . ucmd ( ) . args ( & args ) . run ( ) ;
2021-06-13 13:39:31 +00:00
let exp_result = unwrap_or_return! ( expected_result ( & args ) ) ;
2021-06-10 08:33:22 +00:00
result
2021-06-13 09:11:04 +00:00
. stdout_is ( exp_result . stdout_str ( ) )
. stderr_is ( exp_result . stderr_str ( ) )
. code_is ( exp_result . code ( ) ) ;
2021-06-09 11:24:28 +00:00
}
2021-06-05 22:03:53 +00:00
}
2021-06-09 11:24:28 +00:00
for & opt2 in & [ " --user " , " --group " , " --groups " ] {
2021-06-13 09:11:04 +00:00
// u/g/G z
2021-06-09 11:24:28 +00:00
let args = [ opt2 , z_flag ] ;
scene
. ucmd ( )
2021-06-05 22:03:53 +00:00
. args ( & args )
. succeeds ( )
2021-06-13 13:39:31 +00:00
. stdout_only ( unwrap_or_return! ( expected_result ( & args ) ) . stdout_str ( ) ) ;
2021-06-05 22:03:53 +00:00
}
}
}
2021-06-16 18:45:46 +00:00
fn check_coreutil_version ( util_name : & str , version_expected : & str ) -> String {
// example:
// $ id --version | head -n 1
// id (GNU coreutils) 8.32.162-4eda
let scene = TestScenario ::new ( util_name ) ;
2021-06-13 13:39:31 +00:00
let version_check = scene
. cmd_keepenv ( & util_name )
2021-06-21 22:22:30 +00:00
. env ( " LC_ALL " , " C " )
2021-06-13 13:39:31 +00:00
. arg ( " --version " )
. run ( ) ;
2021-06-16 18:45:46 +00:00
version_check
2021-06-13 13:39:31 +00:00
. stdout_str ( )
. split ( '\n' )
. collect ::< Vec < _ > > ( )
. get ( 0 )
. map_or_else (
2021-06-16 18:45:46 +00:00
| | format! ( " {} : unexpected output format for reference coreutil: ' {} --version' " , UUTILS_WARNING , util_name ) ,
2021-06-13 13:39:31 +00:00
| s | {
2021-06-16 18:45:46 +00:00
if s . contains ( & format! ( " (GNU coreutils) {} " , version_expected ) ) {
2021-06-13 13:39:31 +00:00
s . to_string ( )
} else if s . contains ( " (GNU coreutils) " ) {
let version_found = s . split_whitespace ( ) . last ( ) . unwrap ( ) [ .. 4 ] . parse ::< f32 > ( ) . unwrap_or_default ( ) ;
2021-06-16 18:45:46 +00:00
let version_expected = version_expected . parse ::< f32 > ( ) . unwrap_or_default ( ) ;
2021-06-13 13:39:31 +00:00
if version_found > version_expected {
2021-06-16 18:45:46 +00:00
format! ( " {} : version for the reference coreutil ' {} ' is higher than expected; expected: {} , found: {} " , UUTILS_INFO , util_name , version_expected , version_found )
2021-06-13 13:39:31 +00:00
} else {
2021-06-16 18:45:46 +00:00
format! ( " {} : version for the reference coreutil ' {} ' does not match; expected: {} , found: {} " , UUTILS_WARNING , util_name , version_expected , version_found ) }
2021-06-13 13:39:31 +00:00
} else {
format! ( " {} : no coreutils version string found for reference coreutils ' {} --version' " , UUTILS_WARNING , util_name )
}
} ,
2021-06-16 18:45:46 +00:00
)
}
#[ allow(clippy::needless_borrow) ]
#[ cfg(unix) ]
fn expected_result ( args : & [ & str ] ) -> Result < CmdResult , String > {
#[ cfg(target_os = " linux " ) ]
let util_name = util_name! ( ) ;
#[ cfg(all(unix, not(target_os = " linux " ))) ]
let util_name = & format! ( " g {} " , util_name! ( ) ) ;
2021-06-23 10:27:01 +00:00
let version_check_string = check_coreutil_version ( util_name , VERSION_MIN ) ;
2021-06-13 13:39:31 +00:00
if version_check_string . starts_with ( UUTILS_WARNING ) {
return Err ( version_check_string ) ;
}
println! ( " {} " , version_check_string ) ;
2021-06-16 18:45:46 +00:00
let scene = TestScenario ::new ( util_name ) ;
2021-06-13 13:39:31 +00:00
let result = scene
2021-06-16 18:45:46 +00:00
. cmd_keepenv ( util_name )
2021-06-21 22:22:30 +00:00
. env ( " LC_ALL " , " C " )
2021-06-10 08:33:22 +00:00
. args ( args )
. run ( ) ;
2021-06-13 13:39:31 +00:00
let ( stdout , stderr ) : ( String , String ) = if cfg! ( target_os = " linux " ) {
(
result . stdout_str ( ) . to_string ( ) ,
result . stderr_str ( ) . to_string ( ) ,
)
} else {
// strip 'g' prefix from results:
let from = util_name . to_string ( ) + " : " ;
let to = & from [ 1 .. ] ;
(
result . stdout_str ( ) . replace ( & from , to ) ,
result . stderr_str ( ) . replace ( & from , to ) ,
)
} ;
2021-06-10 08:33:22 +00:00
2021-06-13 13:39:31 +00:00
Ok ( CmdResult ::new (
2021-06-10 08:33:22 +00:00
Some ( result . tmpd ( ) ) ,
Some ( result . code ( ) ) ,
result . succeeded ( ) ,
2021-06-13 13:39:31 +00:00
stdout . as_bytes ( ) ,
stderr . as_bytes ( ) ,
) )
2021-06-05 22:03:53 +00:00
}