]> git.ipfire.org Git - thirdparty/coreutils.git/commitdiff
tests: avoid false failure with --disable-selinux
authorPádraig Brady <P@draigBrady.com>
Mon, 11 Nov 2024 19:54:18 +0000 (19:54 +0000)
committerPádraig Brady <P@draigBrady.com>
Tue, 12 Nov 2024 11:20:47 +0000 (11:20 +0000)
* tests/ls/selinux-segfault.sh: Move recent addition to ...
* tests/ls/selinux.sh: ... this new test that uses require_selinux_
to skip appropriately when we've built without selinux support.
Also add a non root test that checks we output '.' along with the
mode for files, to indicate a security context is present.
* tests/local.mk (Reference the new test).

tests/local.mk
tests/ls/selinux-segfault.sh
tests/ls/selinux.sh [new file with mode: 0755]

index 3223b58aa7659aca7850c4ad481ca7e9e58cc9b0..f4e687fe8bffd798e0e8d9347b29e77f122df4cd 100644 (file)
@@ -647,6 +647,7 @@ all_tests =                                 \
   tests/ls/removed-directory.sh                        \
   tests/ls/root-rel-symlink-color.sh           \
   tests/ls/rt-1.sh                             \
+  tests/ls/selinux.sh                          \
   tests/ls/slink-acl.sh                                \
   tests/ls/stat-dtype.sh                       \
   tests/ls/stat-failed.sh                      \
index 9ac1d950ce5fee32057884643200b5986de35ac9..ebcfbfe13634bcc192ffd4553e4f7faad2714044 100755 (executable)
@@ -30,19 +30,4 @@ mkdir sedir || framework_failure_
 ln -sf missing sedir/broken || framework_failure_
 returns_ 1 ls -L -R -Z -m sedir > out || fail=1
 
-nl='
-'
-if sestatus=$(LC_ALL=C sestatus); then
-  sestatus_line_1=${sestatus%%$nl*}
-  case $sestatus_line_1 in
-    'SELinux status:'*' enabled')
-      ls_output=$(LC_ALL=C ls -lnZ sedir/broken) || fail=1
-      set x $ls_output
-      case $6 in
-        *:*:*:*) ;;
-        *) fail=1;
-      esac
-  esac
-fi
-
 Exit $fail
diff --git a/tests/ls/selinux.sh b/tests/ls/selinux.sh
new file mode 100755 (executable)
index 0000000..7b3ad6a
--- /dev/null
@@ -0,0 +1,40 @@
+#!/bin/sh
+# Test selinux output
+
+# Copyright (C) 2024 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 <https://www.gnu.org/licenses/>.
+
+. "${srcdir=.}/tests/init.sh"; path_prepend_ ./src
+print_ver_ ls
+require_selinux_
+
+touch f || framework_failure_
+case $(stat --printf='%C' f) in
+  *:*:*:*) ;;
+  *) skip_ 'unable to match default security context';;
+esac
+
+# ensure that ls -l output includes the "."
+test "$(ls -l f|cut -c11)" = . || fail=1
+
+# ensure that ls -lZ output includes context
+ls_output=$(LC_ALL=C ls -lnZ f) || fail=1
+set x $ls_output
+case $6 in
+  *:*:*:*) ;;
+  *) fail=1 ;;
+esac
+
+Exit $fail