X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/408aa7b24c7ee02d530e05852fd8eb0f5abfc3fd..434e77193cfb17e92a70e6519fd091700a2ec5a4:/testsuite/exclude.test diff --git a/testsuite/exclude.test b/testsuite/exclude.test index d314941d..1aa33e32 100644 --- a/testsuite/exclude.test +++ b/testsuite/exclude.test @@ -1,8 +1,8 @@ #! /bin/sh -# Copyright (C) 2003 by Wayne Davison +# Copyright (C) 2003, 2004, 2005 by Wayne Davison -# This program is distributable under the terms of the GNU GPL see +# This program is distributable under the terms of the GNU GPL (see # COPYING). # Test rsync handling of exclude/include directives. @@ -12,63 +12,65 @@ . "$suitedir/rsync.fns" -set -x - -HOME="$scratchdir" CVSIGNORE='*.junk' -export HOME CVSIGNORE +export CVSIGNORE # Build some files/dirs/links to copy makepath "$fromdir/foo/down/to/you" +makepath "$fromdir/foo/sub" makepath "$fromdir/bar/down/to/foo/too" makepath "$fromdir/bar/down/to/bar/baz" makepath "$fromdir/mid/for/foo/and/that/is/who" -cat >"$fromdir/.excl" <"$fromdir/.filt" <"$fromdir/foo/file1" +echo filtered-1 >"$fromdir/foo/file1" echo removed >"$fromdir/foo/file2" echo cvsout >"$fromdir/foo/file2.old" -cat >"$fromdir/foo/.excl" <"$fromdir/foo/.filt" <"$fromdir/bar/.excl" <"$fromdir/foo/sub/file1" +cat >"$fromdir/bar/.filt" <"$fromdir/bar/down/to/home-cvs-exclude" -cat >"$fromdir/bar/down/to/.excl2" <"$fromdir/bar/down/to/.filt2" <"$fromdir/bar/down/to/foo/.excl2" <"$fromdir/bar/down/to/foo/.filt2" <"$fromdir/bar/down/to/foo/file1" echo cvsout >"$fromdir/bar/down/to/foo/file1.bak" echo gone >"$fromdir/bar/down/to/foo/file3" echo lost >"$fromdir/bar/down/to/foo/file4" +echo weird >"$fromdir/bar/down/to/foo/+ file3" echo cvsout-but-filtin >"$fromdir/bar/down/to/foo/file4.junk" echo smashed >"$fromdir/bar/down/to/foo/to" -cat >"$fromdir/bar/down/to/bar/.excl2" <"$fromdir/bar/down/to/bar/.filt2" <"$fromdir/bar/down/to/bar/baz/file5.deep" # This one should be ineffectual -cat >"$fromdir/mid/.excl2" <"$fromdir/mid/.filt2" <"$fromdir/mid/one-in-one-out" echo one-in-one-out >"$fromdir/mid/.cvsignore" echo cvsin >"$fromdir/mid/one-for-all" -cat >"$fromdir/mid/.excl" <"$fromdir/mid/.filt" <"$fromdir/mid/for/one-in-one-out" @@ -86,8 +88,12 @@ cat >"$excl" <"$todir"/bar/down/to/bar/baz/nodel.deep cp -p "$todir"/bar/down/to/bar/baz/nodel.deep "$chkdir"/bar/down/to/bar/baz -$RSYNC -av --existing --include='*/' --exclude='*' "$fromdir/" "$chkdir/" +$RSYNC -av --existing --filter='-! */' "$fromdir/" "$chkdir/" # Now, test if rsync excludes the same files, this time with a merge-exclude # file. checkit "sed '/!/d' \"$excl\" | - $RSYNC -avv -f :_.excl -f ._- \ + $RSYNC -avv -f dir-merge_.filt -f merge_- \ --delete-during \"$fromdir/\" \"$todir/\"" "$chkdir" "$todir" -# Remove the files that --delete-excluded will delete. +# Remove the files that will be deleted. -rm "$chkdir"/.excl -rm "$chkdir"/bar/.excl -rm "$chkdir"/bar/down/to/.excl2 -rm "$chkdir"/bar/down/to/foo/.excl2 -rm "$chkdir"/bar/down/to/bar/.excl2 -rm "$chkdir"/mid/.excl -rm "$chkdir"/bar/down/to/bar/baz/nodel.deep +rm "$chkdir"/.filt +rm "$chkdir"/bar/.filt +rm "$chkdir"/bar/down/to/.filt2 +rm "$chkdir"/bar/down/to/foo/.filt2 +rm "$chkdir"/bar/down/to/bar/.filt2 +rm "$chkdir"/mid/.filt -$RSYNC -av --existing --include='*/' --exclude='*' "$fromdir/" "$chkdir/" +$RSYNC -av --protocol=28 --existing --include='*/' --exclude='*' "$fromdir/" "$chkdir/" -# Finally, try the prior command with --delete-before and --delete-excluded. +# Now, try the prior command with --delete-before and some side-specific +# rules. checkit "sed '/!/d' \"$excl\" | - $RSYNC -avv -f :_.excl -f ._- --delete-excluded \ + $RSYNC -avv -f :s_.filt -f .s_- -f P_nodel.deep \ --delete-before \"$fromdir/\" \"$todir/\"" "$chkdir" "$todir" +# Next, we'll test some rule-restricted filter files. + +cat >"$fromdir/bar/down/.excl" <"$fromdir/bar/down/to/foo/.excl" <