From eecd8afd696055cf39ef934208724bfe850c5760 Mon Sep 17 00:00:00 2001 From: Bruno Haible Date: Fri, 10 Feb 2023 13:46:22 +0100 Subject: chown, lchown, fchownat tests: Avoid test failure on macOS 12. * tests/test-chown.h (test_chown): Skip some assertions if getgid() == (gid_t)-1. * tests/test-lchown.h (test_lchown): Likewise. --- tests/test-chown.h | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) (limited to 'tests/test-chown.h') diff --git a/tests/test-chown.h b/tests/test-chown.h index e8c3d49ff9..4c7b6eec33 100644 --- a/tests/test-chown.h +++ b/tests/test-chown.h @@ -72,7 +72,10 @@ test_chown (int (*func) (char const *, uid_t, gid_t), bool print) ASSERT (stat (BASE "dir/file", &st1) == 0); ASSERT (st1.st_uid != (uid_t) -1); ASSERT (st1.st_gid != (gid_t) -1); - ASSERT (st1.st_gid == getegid ()); + /* On macOS 12, when logged in through ssh, getgid () and getegid () are both + == (gid_t) -1. */ + if (getgid () != (gid_t) -1) + ASSERT (st1.st_gid == getegid ()); /* Sanity check of error cases. */ errno = 0; @@ -132,7 +135,8 @@ test_chown (int (*func) (char const *, uid_t, gid_t), bool print) if (1 < gids_count) { ASSERT (gids[1] != st1.st_gid); - ASSERT (gids[1] != (gid_t) -1); + if (getgid () != (gid_t) -1) + ASSERT (gids[1] != (gid_t) -1); ASSERT (lstat (BASE "dir/link", &st2) == 0); ASSERT (st1.st_uid == st2.st_uid); ASSERT (st1.st_gid == st2.st_gid); @@ -156,7 +160,8 @@ test_chown (int (*func) (char const *, uid_t, gid_t), bool print) ASSERT (func (BASE "dir/link2", -1, gids[1]) == 0); ASSERT (stat (BASE "dir/file", &st2) == 0); ASSERT (st1.st_uid == st2.st_uid); - ASSERT (gids[1] == st2.st_gid); + if (getgid () != (gid_t) -1) + ASSERT (gids[1] == st2.st_gid); ASSERT (lstat (BASE "dir/link", &st2) == 0); ASSERT (st1.st_uid == st2.st_uid); ASSERT (st1.st_gid == st2.st_gid); -- cgit v1.2.1