summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJim Meyering <meyering@redhat.com>2011-10-03 13:49:47 +0200
committerJim Meyering <meyering@redhat.com>2011-10-05 23:26:21 +0200
commit5f567ce4bd46e7d6a2c30f95d8e91b7296dfc6c9 (patch)
tree00a84cac60e77406de241e9374d2072a2ba74024
parent88873501cff9ed937edf969cedd693517ab0a293 (diff)
downloadcoreutils-5f567ce4bd46e7d6a2c30f95d8e91b7296dfc6c9.tar.xz
tests: add a test to exercise today's ls-lL-vs-ACL bug
* tests/ls/slink-acl: New file. * tests/Makefile.am (TESTS): Add it. * tests/init.cfg (require_setfacl_): New function. * gnulib: Update to latest, for file-has-acl changes. * NEWS (Bug fixes): Mention it. See http://thread.gmane.org/gmane.comp.lib.gnulib.bugs/28538. This ":>k; setfacl -m m::r k; ln -s k s; ls -Log s" should print e.g., -rw-r-----+ 1 0 Oct 5 19:22 s With the ls from coreutils-8.13, it would print this (with "." or nothing in place of the "+"): -rw-r-----. 1 0 Oct 5 19:22 s
-rw-r--r--NEWS3
m---------gnulib0
-rw-r--r--tests/Makefile.am1
-rw-r--r--tests/init.cfg6
-rwxr-xr-xtests/ls/slink-acl33
5 files changed, 43 insertions, 0 deletions
diff --git a/NEWS b/NEWS
index f50e61a63..293414042 100644
--- a/NEWS
+++ b/NEWS
@@ -10,6 +10,9 @@ GNU coreutils NEWS -*- outline -*-
dangling symlinks when an 'ln=target' entry is in $LS_COLORS.
[bug introduced in fileutils-4.0]
+ ls -lL symlink once again properly prints "+" when the referent has an ACL.
+ [bug introduced in coreutils-8.13]
+
** Improvements
md5sum --check now supports the -r format from the corresponding BSD tool.
diff --git a/gnulib b/gnulib
-Subproject 244794a7887f13d9cdb91fed96932cc479905b9
+Subproject d813b688732c3a0da947f91cbb19cb78a627209
diff --git a/tests/Makefile.am b/tests/Makefile.am
index 2cf409ae9..9c9a1b8c1 100644
--- a/tests/Makefile.am
+++ b/tests/Makefile.am
@@ -431,6 +431,7 @@ TESTS = \
ls/readdir-mountpoint-inode \
ls/recursive \
ls/rt-1 \
+ ls/slink-acl \
ls/stat-dtype \
ls/stat-failed \
ls/stat-free-color \
diff --git a/tests/init.cfg b/tests/init.cfg
index f6eb65159..04abe4faf 100644
--- a/tests/init.cfg
+++ b/tests/init.cfg
@@ -130,6 +130,12 @@ require_strace_()
skip_ 'strace -qe "'"$1"'" does not work'
}
+require_setfacl_()
+{
+ setfacl -m user::rwx . \
+ || skip_ "setfacl does not work on the current file system"
+}
+
# Require a controlling input `terminal'.
require_controlling_input_terminal_()
{
diff --git a/tests/ls/slink-acl b/tests/ls/slink-acl
new file mode 100755
index 000000000..f4d0a115d
--- /dev/null
+++ b/tests/ls/slink-acl
@@ -0,0 +1,33 @@
+#!/bin/sh
+# verify that ls -lL works when applied to a symlink to an ACL'd file
+
+# Copyright (C) 2011 Free Software Foundation, Inc.
+
+# 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 3 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, see <http://www.gnu.org/licenses/>.
+
+. "${srcdir=.}/init.sh"; path_prepend_ ../src
+print_ver_ ls
+
+require_setfacl_
+
+touch k || framework_failure_
+setfacl -m m::r k || framework_failure_
+ln -s k s || framework_failure_
+
+set _ $(ls -Log s); shift; link=$1
+set _ $(ls -og k); shift; reg=$1
+
+test "$link" = "$reg" || fail=1
+
+Exit $fail