From e6d3f340ad40635425a63a2edceb7c4a833e048e Mon Sep 17 00:00:00 2001
From: =?utf-8?q?Ond=C5=99ej=20Va=C5=A1=C3=ADk?=
Date: Mon, 27 Apr 2009 17:20:23 +0200
Subject: [PATCH] tests: add tests for xattr diagnostics on file system without xattr support
* tests/Makefile.am: add new root-only test
* tests/cp/cp-mv-enotsup-xattr: check if xattr diagnostics are displayed
correctly on filesystem without xattr support
---
tests/Makefile.am | 1 +
tests/cp/cp-mv-enotsup-xattr | 90 ++++++++++++++++++++++++++++++++++++++++++
2 files changed, 91 insertions(+), 0 deletions(-)
create mode 100755 tests/cp/cp-mv-enotsup-xattr
diff --git a/tests/Makefile.am b/tests/Makefile.am
index 3a15a87..5591331 100644
--- a/tests/Makefile.am
+++ b/tests/Makefile.am
@@ -24,6 +24,7 @@ root_tests = \
cp/cp-a-selinux \
cp/preserve-gid \
cp/special-bits \
+ cp/cp-mv-enotsup-xattr \
dd/skip-seek-past-dev \
install/install-C-root \
ls/capability \
diff --git a/tests/cp/cp-mv-enotsup-xattr b/tests/cp/cp-mv-enotsup-xattr
new file mode 100755
index 0000000..d7f15d7
--- /dev/null
+++ b/tests/cp/cp-mv-enotsup-xattr
@@ -0,0 +1,90 @@
+#!/bin/sh
+# Ensure that mv, cp -a and cp --preserve=xattr(all) options do work
+# as expected on filesystem without their support and do show correct
+# diagnostics when required
+
+# Copyright (C) 2009 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 .
+
+if test "$VERBOSE" = yes; then
+ set -x
+ cp --version
+ mv --version
+fi
+
+. $srcdir/test-lib.sh
+require_root_
+
+cwd=`pwd`
+cleanup_() { cd /; umount "$cwd/mnt"; }
+
+# Create a file system without user xattr support, then mount it.
+dd if=/dev/zero of=blob bs=8192 count=200 > /dev/null 2>&1 \
+ || framework_failure
+mkdir mnt || framework_failure
+mkfs -t ext2 -F blob ||
+ skip_test_ "failed to create ext2 file system"
+
+mount -oloop,nouser_xattr blob mnt || framework_failure
+echo test > mnt/f || framework_failure
+test -s mnt/f || framework_failure
+
+# testing xattr name-value pair
+xattr_name="user.foo"
+xattr_value="bar"
+xattr_pair="$xattr_name=\"$xattr_value\""
+
+echo test > a || framework_failure
+getfattr -d a >out_a || skip_test_ "failed to get xattr of file"
+grep -F "$xattr_pair" out_a >/dev/null && framework_failure
+setfattr -n "$xattr_name" -v "$xattr_value" a >out_a \
+ || skip_test_ "failed to set xattr of file"
+getfattr -d a >out_a || skip_test_ "failed to get xattr of file"
+grep -F "$xattr_pair" out_a >/dev/null \
+ || skip_test_ "failed to set xattr of file"
+
+fail=0 || framework_failure
+
+
+#This should pass without diagnostics
+cp -a a mnt/ 2>err || fail=1
+test -s mnt/a || fail=1 #destination file must not be empty
+test -s err && fail=1 #there must be no stderr output
+
+rm -f err mnt/a
+
+#This should pass without diagnostics
+cp --preserve=all a mnt/ 2>err || fail=1
+test -s mnt/a || fail=1 #destination file must not be empty
+test -s err && fail=1 #there must be no stderr output
+
+rm -f err mnt/a
+
+#This should fail with coresponding diagnostics
+cp -a --preserve=xattr a mnt/ 2>err && fail=1
+cat <<\EOF > exp || fail=1
+cp: setting attributes for `mnt/a': Operation not supported
+EOF
+
+compare err exp || fail=1
+
+rm -f err mnt/a
+
+#This should pass without diagnostics
+mv a mnt/ 2>err || fail=1
+test -s mnt/a || fail=1 #destination file must not be empty
+test -s err && fail=1 #there must be no stderr output
+
+Exit $fail
--
1.5.6.1.156.ge903b