/* * * Copyright (c) International Business Machines Corp., 2002 * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See * the GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */ /* 10/31/2002 Port to LTP robbiew@us.ibm.com */ /* 06/30/2001 Port to Linux nsharoff@us.ibm.com */ /* * NAME * test.c - Test functions for nftw() */ #include "nftw.h" extern int callback(const char *path); extern pathdata pathdat[]; extern struct list mnem[], badlist[]; extern char *dirlist[NDIRLISTENTS], *goodlist[]; extern int npathdats, ngoods, nbads, nmnem, visit, s2, next_fd[4]; extern FILE *temp; /* * void test1A() - tests the assertion: * A call to int nftw(const char *path, int (*fn)(const char *, const * struct stat *, int, struct FTW *), int depth, int flags) shall * recursively descend the directory hierarchy rooted in path until it * has traversed the whole tree, calling the function fn for each object * in the directory tree, and return 0. */ void test1A(void) { int i, j, ret; temp = stderr; #ifdef DEBUG fprintf(temp, "TEST: nftw() succeeds\n"); #endif visit = 0; if ((ret = nftw("./tmp/data/dirh", test_func1, MAX_FD, 0)) == -1) { perror("ERROR: nftw failed"); cleanup_function(); fail_exit(); } if (ret == 999) { cleanup_function(); fail_exit(); } #ifdef DEBUG fprintf(temp, "TEST: Whole tree traversed\n"); #endif if (visit != ngoods) { fprintf(temp, "ERROR: Count of objects visited incorrect\n"); fprintf(temp, " Expected %d, Received %d\n", ngoods, visit); cleanup_function(); fail_exit(); } for (i = 0; i < visit; i++) { for (j = 0; j < ngoods; j++) { if (strcmp(dirlist[i], goodlist[j]) == 0) { free(dirlist[i]); dirlist[i] = NULL; break; } } } for (i = 0; i < visit; i++) { if (dirlist[i] != NULL) { free(dirlist[i]); fprintf(temp, "ERROR: Unexpected visit to %s\n", dirlist[i]); cleanup_function(); fail_exit(); } } } /* * void test2A() - tests the assertion: * A call to int nftw(const char *path, int (*fn)(const char *, const * struct stat *, int, struct FTW *), int depth, int flags) when flags * contains FTW_PHYS shall not traverse symbolic links. */ void test2A(void) { int i, ret; temp = stderr; #ifdef DEBUG fprintf(temp, "TEST: nftw with FTW_PHYS does not follow symbolic links\n"); #endif visit = 0; if ((ret = nftw("./tmp/data/dirl", test_func1, MAX_FD, FTW_PHYS)) == -1) { perror("nftw"); cleanup_function(); fail_exit(); } if (ret == 999) { cleanup_function(); fail_exit(); } if (visit != NO_LINK_CNT) { fprintf(temp, "ERROR: Expected %d files to be visited. nftw() visited %d\n", NO_LINK_CNT, visit); cleanup_function(); fail_exit(); } for (i = 0; i < visit; i++) { if (dirlist[i] != NULL) free(dirlist[i]); } } /* * void test3A() - tests the assertion: * A call to int nftw(const char *path, int (*fn)(const char *, const * struct stat *, int, struct FTW *), int depth, int flags) when flags * does not contain FTW_PHYS shall follow links instead of reporting * them and shall not report the same file twice. */ void test3A(void) { int ret; #ifdef DEBUG fprintf(temp, "TEST: nftw without FTW_PHYS follows symbolic links\n"); #endif visit = 0; if ((ret = nftw("./tmp/data/dirl", test_func3, MAX_FD, 0)) == -1) { perror("nftw"); cleanup_function(); fail_exit(); } if (ret == 999) { cleanup_function(); fail_exit(); } if (visit != LINK_CNT - 1) { fprintf(temp, "ERROR: Expected %d files to be visited. nftw() visited %d\n", LINK_CNT - 1, visit); cleanup_function(); fail_exit(); } } /* * void test4A() - tests the assertion: * A call to int nftw(const char *path, int (*fn)(const char *, const * struct stat *, int, struct FTW *), int depth, int flags) when flags * contains FTW_DEPTH shall report all files in a directory before * reporting the directory. */ void test4A(void) { char path[] = "./tmp/data/d777"; int ret_val; #ifdef DEBUG fprintf(temp, "TEST: Verify traversal with FTW_DEPTH set\n"); #endif visit = 0; if ((ret_val = nftw(path, test_func4, MAX_FD, FTW_DEPTH)) == -1) { perror("nftw"); cleanup_function(); fail_exit(); } if (ret_val != 999) { fprintf(temp, "ERROR: %s never visited\n", path); cleanup_function(); fail_exit(); } if (visit != 2) { fprintf(temp, "ERROR: Visited directory before contents\n"); cleanup_function(); fail_exit(); } } /* * void test5A() - tests the assertion: * A call to int nftw(const char *path, int (*fn)(const char *, const * struct stat *, int, struct FTW *), int depth, int flags) when flags * does not contain FTW_DEPTH shall report a directory before reporting * the files in that directory. */ void test5A(void) { char path[] = "./tmp/data/d777"; int ret_val; #ifdef DEBUG fprintf(temp, "TEST: Verify traversal without FTW_DEPTH set\n"); #endif visit = 0; if ((ret_val = nftw(path, test_func4, MAX_FD, 0)) == -1) { perror("nftw"); cleanup_function(); fail_exit(); } if (ret_val != 999) { fprintf(temp, "ERROR: %s never visited\n", path); cleanup_function(); fail_exit(); } if (visit != 1) { fprintf(temp, "ERROR: Visited contents before directory\n"); cleanup_function(); fail_exit(); } } /* * void test6A() - tests the assertion: * A call to int nftw(const char *path, int (*fn)(const char *, const * struct stat *, int, struct FTW *), int depth, int flags) when flags * contains FTW_CHDIR shall change the current working directory to each * directory as it reports files in that directory. */ void test6A(void) { char path[PATH_MAX + NAME_MAX]; int ret_val; if (getcwd(path, sizeof(path)) == NULL) { perror("getcwd"); cleanup_function(); fail_exit(); } (void)strcat(path, "/tmp/data/dirh"); #ifdef DEBUG fprintf(temp, "TEST: nftw with FTW_CHDIR changes to each dir before reporting files in it\n"); #endif ret_val = nftw(path, test_func5, MAX_FD, FTW_CHDIR); if (ret_val == -1) { perror("nftw"); cleanup_function(); fail_exit(); } if ((ret_val == 998) || (ret_val == 999)) { cleanup_function(); fail_exit(); } } /* * void test7A() - tests the assertion: * A call to int nftw(const char *path, int (*fn)(const char *, const * struct stat *, int, struct FTW *), int depth, int flags) shall pass * the path-name of the current object as the first argument of the * function fn. */ void test7A(void) { int ret; #ifdef DEBUG fprintf(temp, "TEST: nftw passes pathname as first argument to fn()\n"); #endif if ((ret = nftw("./tmp/data/dirg", test_func7, MAX_FD, 0)) == -1) { perror("nftw"); cleanup_function(); fail_exit(); } if (ret == 999) { cleanup_function(); fail_exit(); } } /* * void test8A() - tests the assertion: * A call to int nftw(const char *path, int (*fn)(const char *, const * struct stat *, int, struct FTW *), int depth, int flags) shall pass a * pointer to a stat structure containing information about the current * object as the second argument to fn. */ void test8A(void) { int ret; #ifdef DEBUG fprintf(temp, "TEST: nftw passes stat struct as second argument to fn()\n"); #endif if ((ret = nftw("./tmp/data/dirg", test_func8, MAX_FD, 0)) == -1) { perror("nftw"); cleanup_function(); fail_exit(); } if (ret == 999) { cleanup_function(); fail_exit(); } } /* * void test9A() - tests the assertion: * A call to int nftw(const char *path, int (*fn)(const char *, const * struct stat *, int, struct FTW *), int depth, int flags) shall pass * FTW_F as the third argument of the function fn when the object is a * file */ void test9A(void) { int ret; #ifdef DEBUG fprintf(temp, "TEST: nftw passes FTW_F as third arg to fn() for files\n"); #endif if ((ret = nftw("./tmp/data/dirg", test_func9, MAX_FD, FTW_PHYS)) == -1) { perror("nftw"); cleanup_function(); fail_exit(); } if (ret == 999) { cleanup_function(); fail_exit(); } } /* * void test10A() - tests the assertion: * A call to int nftw(const char *path, int (*fn)(const char *, const * struct stat *, int, struct FTW *), int depth, int flags) shall pass * FTW_D as the third argument of the function fn when the object is a * directory. */ void test10A(void) { int ret; #ifdef DEBUG fprintf(temp, "TEST: nftw passes FTW_D as third arg to fn() when file is directory\n"); #endif if ((ret = nftw("./tmp/data/dirg", test_func10, MAX_FD, FTW_PHYS)) == -1) { perror("nftw"); cleanup_function(); fail_exit(); } if (ret == 999) { cleanup_function(); fail_exit(); } } /* * void test11A() - tests the assertion: * A call to int nftw(const char *path, int (*fn)(const char *, const * struct stat *, int, struct FTW *), int depth, int flags) shall pass * FTW_DP as the third argument of the function fn when the object is a * directory and subdirectories have been visited. */ void test11A(void) { int i, ret; for (i = 0; i < nbads; i++) if (badlist[i].i == FTW_D) badlist[i].i = FTW_DP; #ifdef DEBUG fprintf(temp, "TEST: nftw passes FTW_DP when file is directory and subdirs already visited\n"); #endif if ((ret = nftw("./tmp/data/dirg", test_func11, MAX_FD, FTW_DEPTH | FTW_PHYS)) == -1) { perror("nftw"); cleanup_function(); fail_exit(); } if (ret == 999) { cleanup_function(); fail_exit(); } } /* * void test12A() - tests the assertion: * A call to int nftw(const char *path, int (*fn)(const char *, const * struct stat *, int, struct FTW *), int depth, int flags) shall pass * FTW_SL as the third argument of the function fn when the object is a * symbolic link. */ void test12A(void) { int ret; #ifdef DEBUG fprintf(temp, "TEST: nftw wth FTW_PHYS passes FTW_SL when file is symlink\n"); #endif if ((ret = nftw("./tmp/data/dirg", test_func12, MAX_FD, FTW_PHYS)) == -1) { perror("nftw"); cleanup_function(); fail_exit(); } if (ret == 999) { cleanup_function(); fail_exit(); } } /* * void test13A() - tests the assertion: * A call to int nftw(const char *path, int (*fn)(const char *, const * struct stat *, int, struct FTW *), int depth, int flags) shall pass * FTW_SLN as the third argument of the function fn when the object is a * symbolic link that does not name an existing file. */ void test13A(void) { int i, ret; if (unlink("./tmp/byebye") == -1) { perror("unlink"); cleanup_function(); fail_exit(); } for (i = 0; i < nbads; i++) if (badlist[i].i == FTW_SL) badlist[i].i = FTW_SLN; #ifdef DEBUG fprintf(temp, "TEST: nftw with FTW_PHYS passes FTW_SLN when file"); fprintf(temp, " is symlink pointing \n to non-existent file\n"); #endif if ((ret = nftw("./tmp/data/dirg", test_func13, MAX_FD, FTW_PHYS)) == -1) { perror("nftw"); cleanup_function(); fail_exit(); } if (ret == 999) { cleanup_function(); fail_exit(); } } /* * void test14A() - tests the assertion: * A call to int nftw(const char *path, int (*fn)(const char *, const * struct stat *, int, struct FTW *), int depth, int flags) shall pass * FTW_DNR as the third argument of the function fn when the object is a * directory that cannot be read. */ void test14A(void) { int ret; #ifdef DEBUG fprintf(temp, "TEST: nftw passes FTW_DNR when file is directory that cannot be read\n"); #endif if ((ret = nftw("./tmp/data/d333", test_func14, MAX_FD, 0)) == -1) { perror("nftw"); cleanup_function(); fail_exit(); } if (ret == 999) { cleanup_function(); fail_exit(); } } /* * void test15A() - tests the assertion: * A call to int nftw(const char *path, int (*fn)(const char *, const * struct stat *, int, struct FTW *), int depth, int flags) shall pass * FTW_NS as the third argument of the function fn when stat() failed on * the object because of lack of appropriate permission. */ void test15A(void) { int ret; #ifdef DEBUG fprintf(temp, "TEST: nftw(path, fn, depth, FTW_PHYS) passes FTW_NS when dir unsearchable\n"); #endif if ((ret = nftw("./tmp/data/d666", test_func15, MAX_FD, FTW_PHYS)) == -1) { perror("nftw"); cleanup_function(); fail_exit(); } if (ret == 999) { cleanup_function(); fail_exit(); } } /* * void test16A() - tests the assertion: * A call to int nftw(const char *path, int (*fn)(const char *, const * struct stat *, int, struct FTW *), int depth, int flags) shall pass a * structure which contains the offset into the pathname of the object * and the depth relative to the root of the walk starting from 0 as the * fourth argument of the function fn. */ void test16A(void) { char path[PATH_MAX + NAME_MAX]; char orig[PATH_MAX]; if (getcwd(orig, sizeof(orig)) == NULL) { perror("getcwd on original wd"); cleanup_function(); fail_exit(); } strcpy(path, orig); (void)strcat(path, "/tmp/data/dirg"); #ifdef DEBUG fprintf(temp, "TEST: nftw with absolute pathname %s\n", path); #endif if ((s2 = nftw(path, test_func16, MAX_FD, 0)) == -1) { perror("nftw"); cleanup_function(); fail_exit(); } if (s2 == 999) { cleanup_function(); fail_exit(); } (void)strcpy(path, "./tmp/data/dirg"); #ifdef DEBUG fprintf(temp, "TEST: nftw with relative pathname %s\n", path); #endif if ((s2 = nftw(path, test_func16, MAX_FD, 0)) == -1) { perror("nftw"); cleanup_function(); fail_exit(); } if (s2 == 999) { cleanup_function(); fail_exit(); } } /* * void test17A() - tests the assertion: * A call to int nftw(const char *path, int (*fn)(const char *, const * struct stat *, int, struct FTW *), int depth, int flags) shall pass * FTW_SL as the third argument to the function fn if and only if the * FTW_PHYS flag is included in flags. */ void test17A(void) { int ret; visit = 0; #ifdef DEBUG fprintf(temp, "TEST: nftw with FTW_PHYS passes FTW_SL for symlink\n"); #endif if ((ret = nftw("./tmp/data/dirl", test_func17, MAX_FD, FTW_PHYS)) == -1) { perror("nftw"); cleanup_function(); fail_exit(); } if (ret != 999) { fprintf(temp, "ERROR: nftw() failed to find symbolic link\n"); cleanup_function(); fail_exit(); } visit = 0; #ifdef DEBUG fprintf(temp, "TEST: nftw without FTW_PHYS does not pass FTW_SL for symlink\n"); #endif if ((ret = nftw("./tmp/data/dirl", test_func17, MAX_FD, 0)) == -1) { perror("nftw"); cleanup_function(); fail_exit(); } if (ret == 999) { fprintf(temp, "ERROR: nftw() found symbolic link\n"); cleanup_function(); fail_exit(); } } /* * void test18A() - tests the assertion: * A call to int nftw(const char *path, int (*fn)(const char *, const * struct stat *, int, struct FTW *), int depth, int flags) shall pass * FTW_SLN as the third argument to the function fn if and only if the * FTW_PHYS flag is not included in flags. */ void test18A(void) { int ret; unlink("./tmp/byebye"); visit = 0; #ifdef DEBUG fprintf(temp, "TEST: nftw with FTW_PHYS does not pass FTW_SLN\n"); #endif if ((ret = nftw("./tmp/data/dirg", test_func18, MAX_FD, FTW_PHYS)) == -1) { perror("nftw"); cleanup_function(); fail_exit(); } if (ret == 999) { fprintf(temp, "ERROR: nftw() passed FTW_SLN\n"); cleanup_function(); fail_exit(); } visit = 0; #ifdef DEBUG fprintf(temp, "TEST: nftw without FTW_PHYS passes FTW_SLN\n"); #endif if ((ret = nftw("./tmp/data/dirg", test_func18, MAX_FD, 0)) == -1) { perror("nftw"); cleanup_function(); fail_exit(); } if (visit == 1) { if (ret == 999) { /* Test is passed */ return; } else { fprintf(temp, "ERROR: nftw passed FTW_SLN but did"); fprintf(temp, "not return value returned by fn()\n"); cleanup_function(); fail_exit(); } } else { fprintf(temp, "ERROR: nftw() did not pass FTW_SLN\n"); cleanup_function(); fail_exit(); } } /* * void test19A() - tests the assertion: * On a call to int nftw(const char *path, int (*fn)(const char *, const * struct stat *, int, struct FTW *), int depth, int flags) when the * third argument passed to the function fn is FTW_DNR then the * descendants of the directory shall not be processed. */ void test19A(void) { int ret_val; #ifdef DEBUG fprintf(temp, "TEST: Can not traverse directory with no read permission\n"); #endif visit = 0; ret_val = nftw("./tmp/data/d333", test_func19, MAX_FD, 0); if (ret_val == -1) { perror("nftw"); cleanup_function(); fail_exit(); } if (ret_val == 999) { cleanup_function(); fail_exit(); } #ifdef DEBUG fprintf(temp, "TEST: fn only be called once\n"); #endif if (visit != 1) { fprintf(temp, "ERROR: %s", "Directory without read permission allows traversing\n"); fprintf(temp, " Visited %d files\n", visit); cleanup_function(); fail_exit(); } } /* * void test20A() - tests the assertion: * A call to int nftw(const char *path, int (*fn)(const char *, const * struct stat *, int, struct FTW *), int depth, int flags) shall close * any file descriptors or directory streams used to traverse the * directory tree. */ void test20A(void) { int fd, nfd; #ifdef DEBUG fprintf(temp, "TEST: File descriptors used in traversal are closed\n"); #endif if ((fd = open("./tmp/data/dirh", O_RDONLY)) == -1) { perror("close"); cleanup_function(); fail_exit(); } if (close(fd) == -1) { perror("close"); cleanup_function(); fail_exit(); } if (nftw("./tmp/data/dirh", test_func20, 1, 0) == -1) { perror("nftw"); cleanup_function(); fail_exit(); } if ((nfd = open("./tmp/data/dirh", O_RDONLY)) == -1) { perror("open"); cleanup_function(); fail_exit(); } if (nfd != fd) { fprintf(temp, "ERROR: %s,fd == %d ofd = %d", "nftw did not close all file descriptors used in traversal\n", nfd, fd); cleanup_function(); fail_exit(); } if (close(nfd) == -1) { perror("close"); cleanup_function(); fail_exit(); } } /* * void test21A() - tests the assertion: * On a call to int nftw(const char *path, int (*fn)(const char *, const * struct stat *, int, struct FTW *), int depth, int flags) shall * be the maximum number of file descriptors used for the search. */ void test21A(void) { char path[] = "./tmp/data/dirh"; int ret_val; #ifdef DEBUG fprintf(temp, "TEST: No more than depth file descriptors used in traversal\n"); #endif /*this is the fd we expect if 0 are used */ if ((next_fd[0] = open(path, O_RDONLY)) == -1) { perror("open next_fd[0]"); cleanup_function(); fail_exit(); } /*this is the fd we expect if 1 is used */ if ((next_fd[1] = open(path, O_RDONLY)) == -1) { perror("open next_fd[1]"); cleanup_function(); fail_exit(); } if (close(next_fd[0]) == -1) { perror("close next_fd[0]"); cleanup_function(); fail_exit(); } if (close(next_fd[1]) == -1) { perror("close next_fd[1]"); cleanup_function(); fail_exit(); } visit = 0; ret_val = nftw(path, test_func21, 1, 0); if (ret_val == -1) { perror("nftw"); cleanup_function(); fail_exit(); } if (ret_val == 999) { cleanup_function(); fail_exit(); } } /* * void test22A() - tests the assertion: * A call to int nftw(const char *path, int (*fn)(const char *, const * struct stat *, int, struct FTW *), int depth, int flags) shall use at * most one file descriptor for each directory level. */ void test22A(void) { char path[] = "./tmp/data/dirh"; int ret_val, i; for (i = 0; i < 4; i++) { if ((next_fd[i] = open(path, O_RDONLY)) == -1) { perror("open"); cleanup_function(); fail_exit(); } } for (i = 0; i < 4; i++) { if (close(next_fd[i]) == -1) { perror("close"); cleanup_function(); fail_exit(); } } visit = 0; #ifdef DEBUG fprintf(temp, "TEST: No more than 1 fd per level is used in traversal\n"); #endif ret_val = nftw(path, test_func22, MAX_FD, 0); if (ret_val == -1) { perror("nftw"); cleanup_function(); fail_exit(); } if (ret_val == 999) { cleanup_function(); fail_exit(); } } /* * void test23A() - tests the assertion: * A call to int nftw(const char *path, int (*fn)(const char *, const * struct stat *, int, struct FTW *), int depth, int flags) when the * function fn returns a non-zero value shall stop and return the value * returned by fn. */ void test23A(void) { int ret; visit = 0; #ifdef DEBUG fprintf(temp, "TEST: The function nftw should return with value set by fn\n"); #endif if ((ret = nftw("./tmp/data/dirh", test_func23, MAX_FD, FTW_PHYS)) == -1) { perror("nftw"); cleanup_function(); fail_exit(); } if (ret != 999) { fprintf(temp, "ERROR: nftw did not return value returned by fn()\n"); cleanup_function(); fail_exit(); } if (visit != 4) { fprintf(temp, "ERROR: nftw() did not return immediately on non-zero fn() return\n"); cleanup_function(); fail_exit(); } } /* * void test24A() - tests the assertion: * ENAMETOOLONG in errno and return -1 on a call to int nftw(const char * *path, int (*fn)(const char *, const struct stat *, int, struct FTW * *), int depth, int flags) when the length of path exceeds PATH_MAX. */ void test24A(void) { test_ENAMETOOLONG_path("nftw", callback, -1); } /* * void test25A() - tests the assertion: * ENAMETOOLONG in errno and return -1 on a call to int nftw(const char * *path, int (*fn)(const char *, const struct stat *, int, struct FTW * *), int depth, int flags) when a component of path exceeds NAME_MAX. */ void test25A(void) { test_ENAMETOOLONG_name("nftw", callback, -1); } /* * void test26A() - tests the assertion: * ENOENT in errno and return -1 on a call to int nftw(const char *path, * int (*fn)(const char *, const struct stat *, int, struct FTW *), int * depth, int flags) when path points to a file which does not exist. */ void test26A(void) { #ifdef DEBUG fprintf(temp, "TEST: [ENOENT] && -1 returned by nftw\n"); #endif test_ENOENT_nofile("nftw", callback, -1); } /* * void test27A() - tests the assertion: * ENOENT in errno and return -1 on a call to int nftw(const char *path, * int (*fn)(const char *, const struct stat *, int, struct FTW *), int * depth, int flags) when path points to an empty string. */ void test27A(void) { #ifdef DEBUG fprintf(temp, "TEST: The function nftw should return with a -1\n"); #endif test_ENOENT_empty("nftw", callback, -1); } /* * void test28A() - tests the assertion: * ENOTDIR in errno and return -1 on a call to int nftw(const char * *path, int (*fn)(const char *, const struct stat *, int, struct FTW * *), int depth, int flags) when path is not a directory. */ void test28A(void) { #ifdef DEBUG fprintf(temp, "TEST: [ENOTDIR] && -1 returned by nftw\n"); #endif test_ENOTDIR("nftw", callback, -1); } /* * void test29A() - tests the assertion: * EACCES in errno and return -1 on a call to int nftw(const char *path, * int (*fn)(const char *, const struct stat *, int, struct FTW *), int * depth, int flags) when search permission is denied for any component * of path. */ void test29A(void) { if (chmod("./tmp/data/d333", (mode_t) S_IRUSR) == -1) { perror("chmod"); cleanup_function(); fail_exit(); } #ifdef DEBUG fprintf(temp, "TEST: [EACCES] && -1 returned by nftw\n"); #endif test_ENOTDIR("nftw", callback, -1); } /* * void test30A() - tests the assertion: * EACCES in errno and return -1 on a call to int nftw(const char *path, * int (*fn)(const char *, const struct stat *, int, struct FTW *), int * depth, int flags) when read permission is denied for path. */ void test30A(void) { if (chmod("./tmp/data/d333", (mode_t) S_IXUSR) == -1) { perror("chmod"); cleanup_function(); fail_exit(); } #ifdef DEBUG fprintf(temp, "TEST: [EACCES] && -1 returned by nftw\n"); #endif test_ENOTDIR("nftw", callback, -1); }