tests: fix failing tests on M1

pull/10394/head
Delyan Angelov 2021-06-07 13:32:55 +03:00
parent 3c56532ecb
commit 4772146a7e
2 changed files with 12 additions and 8 deletions

View File

@ -561,29 +561,30 @@ fn test_posix_set_bit() {
} $else { } $else {
fpath := '/tmp/permtest' fpath := '/tmp/permtest'
os.create(fpath) or { panic("Couldn't create file") } os.create(fpath) or { panic("Couldn't create file") }
os.chmod(fpath, 0o7777) os.chmod(fpath, 0o0777)
c_fpath := &char(fpath.str) c_fpath := &char(fpath.str)
mut s := C.stat{} mut s := C.stat{}
unsafe { unsafe {
C.stat(c_fpath, &s) C.stat(c_fpath, &s)
} }
// Take the permissions part of the mode // Take the permissions part of the mode
mut mode := u32(s.st_mode) & 0o7777 mut mode := u32(s.st_mode) & 0o0777
assert mode == 0o7777 assert mode == 0o0777
// `chmod u-r` // `chmod u-r`
os.posix_set_permission_bit(fpath, os.s_irusr, false) os.posix_set_permission_bit(fpath, os.s_irusr, false)
unsafe { unsafe {
C.stat(c_fpath, &s) C.stat(c_fpath, &s)
} }
mode = u32(s.st_mode) & 0o7777 mode = u32(s.st_mode) & 0o0777
assert mode == 0o7377 assert mode == 0o0377
// `chmod u+r` // `chmod u+r`
os.posix_set_permission_bit(fpath, os.s_irusr, true) os.posix_set_permission_bit(fpath, os.s_irusr, true)
unsafe { unsafe {
C.stat(c_fpath, &s) C.stat(c_fpath, &s)
} }
mode = u32(s.st_mode) & 0o7777 mode = u32(s.st_mode) & 0o0777
assert mode == 0o7777 assert mode == 0o0777
// NB: setting the sticky bit is platform dependend
// `chmod -s -g -t` // `chmod -s -g -t`
os.posix_set_permission_bit(fpath, os.s_isuid, false) os.posix_set_permission_bit(fpath, os.s_isuid, false)
os.posix_set_permission_bit(fpath, os.s_isgid, false) os.posix_set_permission_bit(fpath, os.s_isgid, false)
@ -591,7 +592,7 @@ fn test_posix_set_bit() {
unsafe { unsafe {
C.stat(c_fpath, &s) C.stat(c_fpath, &s)
} }
mode = u32(s.st_mode) & 0o7777 mode = u32(s.st_mode) & 0o0777
assert mode == 0o0777 assert mode == 0o0777
// `chmod g-w o-w` // `chmod g-w o-w`
os.posix_set_permission_bit(fpath, os.s_iwgrp, false) os.posix_set_permission_bit(fpath, os.s_iwgrp, false)

View File

@ -9,6 +9,9 @@ fn test_native() {
$if !amd64 { $if !amd64 {
return return
} }
$if aarch64 {
return
}
// some tests are running fine in macos // some tests are running fine in macos
if os.user_os() != 'linux' && os.user_os() != 'macos' { if os.user_os() != 'linux' && os.user_os() != 'macos' {
eprintln('native tests only run on Linux and macOS for now.') eprintln('native tests only run on Linux and macOS for now.')