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