On 10/30/2014 06:24 PM, Jack Howarth wrote: > On Thu, Oct 30, 2014 at 12:01:17AM +0000, Pádraig Brady wrote: >> On 10/29/2014 11:13 PM, Jack Howarth wrote: >>> I am finding that the single failure seen on Mavericks for the >>> coreutils 8.23 testsuite... >>> >>> FAIL: test-getcwd.sh >>> >>> ===================================================== >>> GNU coreutils 8.23: gnulib-tests/test-suite.log >>> ===================================================== >> >> The above gnulib issue may occur on Yosemite too but was not run >> due to the new failures below >> >>> when run as sudo, is replaced by two new errors and two new failures >>> under Yosemite as sudo. >>> >>> ERROR: tests/cp/link-deref.sh >>> FAIL: tests/cp/link-no-deref.sh >>> >>> FAIL: tests/cp/link-symlink.sh >>> >>> ERROR: tests/ln/hard-to-sym.sh >>> >>> ============================================================================ >>> Testsuite summary for GNU coreutils 8.23 >>> ============================================================================ >>> # TOTAL: 563 >>> # PASS: 397 >>> # SKIP: 162 >>> # XFAIL: 0 >>> # FAIL: 2 >>> # XPASS: 0 >>> # ERROR: 2 >> >> All these failures and errors are due to trying to create >> a hardlink to a symlink and getting an "Operation not supported" error. >> >> Can you send the output of this command? >> $ grep -E "(LINK_F|LINKAT)" lib/config.h > > On x86_64-apple-darwin13 which doesn't show these failures, I see... > > #define GNULIB_AREADLINKAT 1 > #define GNULIB_TEST_LINKAT 1 > #define GNULIB_TEST_READLINKAT 1 > #define GNULIB_TEST_SYMLINKAT 1 > #define GNULIB_TEST_UNLINKAT 1 > /* #undef HAVE_LINKAT */ > /* #undef HAVE_READLINKAT */ > /* #undef HAVE_SYMLINKAT */ > /* #undef HAVE_UNLINKAT */ > /* #undef LINKAT_TRAILING_SLASH_BUG */ > #define LINK_FOLLOWS_SYMLINKS 1 > > whereas on x86_64-apple-darwin14, I get... > > #define GNULIB_AREADLINKAT 1 > #define GNULIB_TEST_LINKAT 1 > #define GNULIB_TEST_READLINKAT 1 > #define GNULIB_TEST_SYMLINKAT 1 > #define GNULIB_TEST_UNLINKAT 1 > #define HAVE_LINKAT 1 > #define HAVE_READLINKAT 1 > #define HAVE_SYMLINKAT 1 > #define HAVE_UNLINKAT 1 > /* #undef LINKAT_TRAILING_SLASH_BUG */ > #define LINK_FOLLOWS_SYMLINKS 1 > >> >> What file system type are you running this one? > > Both filesystems are > > File System Personality: Journaled HFS+ > Type (Bundle): hfs > Name (User Visible): Mac OS Extended (Journaled) > Journal: Journal size 81920 KB at offset 0x1d1c000 > Owners: Enabled > >> >> I suspect that this might help? >> >> diff --git a/lib/linkat.c b/lib/linkat.c >> index 6ee30fb..fd6bd1c 100644 >> --- a/lib/linkat.c >> +++ b/lib/linkat.c >> @@ -329,7 +329,8 @@ rpl_linkat (int fd1, char const *file1, int fd2, char >> const *file2, int flag) >> if (0 <= have_follow_really) >> { >> int result = linkat (fd1, file1, fd2, file2, flag); >> - if (!(result == -1 && errno == EINVAL)) >> + if (!(result == -1 && (errno == EINVAL || errno == ENOTSUP >> + || errno == EOPNOTSUPP))) >> { >> have_follow_really = 1; >> return result; > > Unfortunately, with this patch, I still see the failures on > x86_64-apple-darwin14.
Ah right, that code path is only for older Linux kernels with AT_SYMLINK_FOLLOW specified, which is not the case here. Please drop this patch. > link-deref.sh: set-up failure: > ERROR: tests/cp/link-deref.sh > FAIL: tests/cp/link-no-deref.sh > FAIL: tests/cp/link-symlink.sh > hard-to-sym.sh: set-up failure: > ERROR: tests/ln/hard-to-sym.sh So linkat() is now available but doesn't support hardlinks to symlinks contrary to the POSIX spec. So it would be best we consider linkat() unavailable, which can be done manually like: ac_cv_func_linkat=no ./configure We'll have to augment the gnulib linkat check to actually check that linkat() works, rather than just being available. Attached is an ancillary patch to coreutils to convert the Last ERROR above to the more correct FAILs, which you don't need to apply. thanks, Pádraig.
>From 0ba224ec5cd102773086137b7097ec91d1538e49 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?P=C3=A1draig=20Brady?= <p...@draigbrady.com> Date: Fri, 31 Oct 2014 02:25:02 +0000 Subject: [PATCH] tests: ln/hard-to-sym FAIL rather than ERROR when ln fails * tests/ln/hard-to-sym.sh: Only call framework_failure_ when ln returns success. --- tests/ln/hard-to-sym.sh | 36 +++++++++++++++++++++--------------- 1 files changed, 21 insertions(+), 15 deletions(-) diff --git a/tests/ln/hard-to-sym.sh b/tests/ln/hard-to-sym.sh index 995d3cf..f3ac8ba 100755 --- a/tests/ln/hard-to-sym.sh +++ b/tests/ln/hard-to-sym.sh @@ -29,24 +29,30 @@ ln -s -L -P symlink2 symlink3 || fail=1 # =================================================== # ensure that -L follows symlinks, and overrides -P -ln -P -L symlink3 hard-to-a || fail=1 -ls=$(ls -lG hard-to-a)x -case "$ls" in - *'hard-to-ax') ;; - *'hard-to-a -> '*x) fail=1 ;; - *) framework_failure_ ;; -esac +if ln -P -L symlink3 hard-to-a; then + ls=$(ls -lG hard-to-a)x + case "$ls" in + *'hard-to-ax') ;; + *'hard-to-a -> '*x) fail=1 ;; + *) framework_failure_ ;; + esac +else + fail=1 +fi # =================================================== # ensure that -P links (or at least duplicates) symlinks, and overrides -L -ln -L -P symlink3 hard-to-3 || fail=1 -ls=$(ls -lG hard-to-3)x -case "$ls" in - *'hard-to-3 -> symlink2x') ;; - *'hard-to-3x') fail=1 ;; - *'hard-to-3 -> '*x) fail=1 ;; - *) framework_failure_ ;; -esac +if ln -L -P symlink3 hard-to-3; then + ls=$(ls -lG hard-to-3)x + case "$ls" in + *'hard-to-3 -> symlink2x') ;; + *'hard-to-3x') fail=1 ;; + *'hard-to-3 -> '*x) fail=1 ;; + *) framework_failure_ ;; + esac +else + fail=1 +fi # =================================================== # Create a hard link to a dangling symlink. -- 1.7.7.6