I wrote:
> On Mac OS X 10.5, I see this test failure:
> 
> ../../gltests/test-faccessat.c:63: assertion 'faccessat (AT_FDCWD, BASE 
> "link2/", F_OK, 0) != 0' failed
> FAIL test-faccessat (exit status: 134)

It is now fixed by the preceding changes to access() and euidaccess().
But one can strength the unit tests a bit:


2023-10-03  Bruno Haible  <br...@clisp.org>

        faccessat tests: Strengthen tests.
        * tests/test-faccessat.c (main): Test other modes than F_OK. Check errno
        values.

diff --git a/tests/test-faccessat.c b/tests/test-faccessat.c
index 5f6ecd95d1..6a6bfeef53 100644
--- a/tests/test-faccessat.c
+++ b/tests/test-faccessat.c
@@ -45,12 +45,22 @@ main (void)
   }
 
   /* Test behavior with trailing slash.  */
+
   unlink (BASE "file");
   ASSERT (faccessat (AT_FDCWD, ".", X_OK, 0) == 0);
   ASSERT (faccessat (AT_FDCWD, "./", X_OK, 0) == 0);
   ASSERT (close (open (BASE "file", O_CREAT | O_WRONLY, 0)) == 0);
   ASSERT (faccessat (AT_FDCWD, BASE "file", F_OK, 0) == 0);
+
   ASSERT (faccessat (AT_FDCWD, BASE "file/", F_OK, 0) != 0);
+  ASSERT (errno == ENOTDIR);
+  ASSERT (faccessat (AT_FDCWD, BASE "file/", R_OK, 0) != 0);
+  ASSERT (errno == ENOTDIR);
+  ASSERT (faccessat (AT_FDCWD, BASE "file/", W_OK, 0) != 0);
+  ASSERT (errno == ENOTDIR);
+  ASSERT (faccessat (AT_FDCWD, BASE "file/", X_OK, 0) != 0);
+  ASSERT (errno == ENOTDIR);
+
   unlink (BASE "link1");
   if (symlink (".", BASE "link1") == 0)
     {
@@ -61,12 +71,27 @@ main (void)
       ASSERT (symlink (BASE "file", BASE "link2") == 0);
       ASSERT (faccessat (AT_FDCWD, BASE "link2", F_OK, 0) == 0);
       ASSERT (faccessat (AT_FDCWD, BASE "link2/", F_OK, 0) != 0);
+      ASSERT (errno == ENOTDIR);
+      ASSERT (faccessat (AT_FDCWD, BASE "link2/", R_OK, 0) != 0);
+      ASSERT (errno == ENOTDIR || errno == EACCES);
+      ASSERT (faccessat (AT_FDCWD, BASE "link2/", W_OK, 0) != 0);
+      ASSERT (errno == ENOTDIR || errno == EACCES);
+      ASSERT (faccessat (AT_FDCWD, BASE "link2/", X_OK, 0) != 0);
+      ASSERT (errno == ENOTDIR || errno == EACCES);
       unlink (BASE "link2");
 
       unlink (BASE "link3");
       ASSERT (symlink (BASE "no-such-file", BASE "link3") == 0);
       ASSERT (faccessat (AT_FDCWD, BASE "link3", F_OK, 0) != 0);
+      ASSERT (errno == ENOENT);
       ASSERT (faccessat (AT_FDCWD, BASE "link3/", F_OK, 0) != 0);
+      ASSERT (errno == ENOENT);
+      ASSERT (faccessat (AT_FDCWD, BASE "link3/", R_OK, 0) != 0);
+      ASSERT (errno == ENOENT);
+      ASSERT (faccessat (AT_FDCWD, BASE "link3/", W_OK, 0) != 0);
+      ASSERT (errno == ENOENT);
+      ASSERT (faccessat (AT_FDCWD, BASE "link3/", X_OK, 0) != 0);
+      ASSERT (errno == ENOENT);
       unlink (BASE "link3");
     }
   unlink (BASE "link1");




Reply via email to