diff options
-rw-r--r-- | ChangeLog | 6 | ||||
-rwxr-xr-x | tests/cp/parent-perm | 12 |
2 files changed, 17 insertions, 1 deletions
@@ -1,3 +1,9 @@ +2008-01-31 Jim Meyering <meyering@redhat.com> + + Improve the cp/parent-perm test. + * tests/cp/parent-perm: Also check that perms of existing dest + dirs are changed to match those of corresponding src dir + 2008-01-30 Paul Eggert <eggert@cs.ucla.edu> Don't modify argv in dd due to ',' in arguments. diff --git a/tests/cp/parent-perm b/tests/cp/parent-perm index cedcac4df..1e9e8e1ea 100755 --- a/tests/cp/parent-perm +++ b/tests/cp/parent-perm @@ -24,10 +24,17 @@ fi . $srcdir/../envvar-check . $srcdir/../test-lib.sh +. $abs_srcdir/../umask-check + mkdir -p a/b/c a/b/d e || framework_failure touch a/b/c/foo a/b/d/foo || framework_failure cp -p --parent a/b/c/foo e || framework_failure +# Make permissions of e/a different, so that we exercise the +# code in cp -p --parents that propagates permissions even +# to a destination directory that it doesn't create. +chmod g-rx e/a e/a/b || framework_failure + fail=0 cp -p --parent a/b/d/foo e || fail=1 @@ -41,7 +48,10 @@ cp -p --parent a/b/d/foo e || fail=1 # so "a/" inherits that. However, when the user does not belong to # the group of the build directory, chmod ("a/e", 02755) returns 0, # yet fails to set the S_ISGID bit. -test $(stat --printf %A a|sed s/s/x/g) = $(stat --printf %A e/a|sed s/s/x/g) || +for dir in a a/b a/b/d; do + test $(stat --printf %A $dir|sed s/s/x/g) \ + = $(stat --printf %A e/$dir|sed s/s/x/g) || fail=1 +done (exit $fail); exit $fail |