bug-coreutils
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: coreutils-6.3 on Linux 2.4 kernel


From: Paul Eggert
Subject: Re: coreutils-6.3 on Linux 2.4 kernel
Date: Thu, 05 Oct 2006 15:11:34 -0700
User-agent: Gnus/5.1008 (Gnus v5.10.8) Emacs/21.4 (gnu/linux)

Bruno Haible <address@hidden> writes:

> 2) ls/stat-dtype fails:
>
> out exp differ: char 2, line 1
> 1c1
> < s
> ---
>> s@

Thanks for reporting this.  I installed this in an attempt to fix the
testsuite problem.  It's not an ideal fix, but it's the best I could
think of offhand.

2006-10-05  Paul Eggert  <address@hidden>

        * tests/ls/stat-dtype: Use a dynamic test to decide whether the
        current file system has useful d_type info.

--- tests/ls/stat-dtype 24 Sep 2006 07:27:01 -0000      1.8
+++ tests/ls/stat-dtype 5 Oct 2006 22:09:31 -0000
@@ -30,33 +30,6 @@

 . $srcdir/../envvar-check

-# Skip this test unless "." is on a file system with useful d_type info.
-# FIXME: use a more dynamic test for this, since whether d_type is useful
-# depends on much more than the file system type.  For example, with
-# linux-2.6.15, at least tmpfs and ext3 work, but reiserfs and xfs don't.
-# Also, tmpfs on Solaris 10 lacks d_type support.
-skip=yes
-fs_type=`stat -f --printf %T .`
-
-linux_2_6_or_newer=0
-case `uname -r` in
-  [01].*) ;;
-  2.[0-5]*) ;;
-  *) linux_2_6_or_newer=1 ;;
-esac
-
-test `uname -s` = Linux \
-  && test $linux_2_6_or_newer = 1 \
-  && test $fs_type = tmpfs \
-  && skip=no
-test $fs_type = ext2/ext3 && skip=no
-test $skip = yes &&
-  {
-    echo "$0: '.' is not on a suitable file system for this test" 1>&2
-    echo "$0: skipping this test" 1>&2
-    (exit 77); exit 77
-  }
-
 pwd=`pwd`
 t0=`echo "$0"|sed 's,.*/,,'`.tmp; tmp=$t0/$$
 trap 'status=$?; cd $pwd; chmod -R u+rwx $t0; rm -rf $t0 && exit $status' 0
@@ -66,6 +39,17 @@
 mkdir -p $tmp || framework_failure=1
 cd $tmp || framework_failure=1

+# Skip this test unless "." is on a file system with useful d_type info.
+# FIXME: This uses "ls -p" to decide whether to test "ls" with other options,
+# but if ls's d_type code is buggy then "ls -p" might be buggy too.
+mkdir -p c/d || framework_failure=1
+chmod a-x c || framework_failure=1
+if test "X`ls -p c 2>&1`" != Xd/; then
+  echo "$0: '.' is not on a suitable file system for this test" 1>&2
+  echo "$0: skipping this test" 1>&2
+  (exit 77); exit 77
+fi
+
 mkdir d || framework_failure=1
 ln -s / d/s || framework_failure=1
 chmod 600 d || framework_failure=1




reply via email to

[Prev in Thread] Current Thread [Next in Thread]