X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/346402ddbf731b87ec1c068f771c0838f5e22876..9a338344dafdb9342204125c615a7742b859c74d:/testsuite/exclude.test diff --git a/testsuite/exclude.test b/testsuite/exclude.test index 56b612a4..cd462dd3 100644 --- a/testsuite/exclude.test +++ b/testsuite/exclude.test @@ -24,51 +24,52 @@ makepath "$fromdir/foo/down/to/you" 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 removed >"$fromdir/foo/file2" echo cvsout >"$fromdir/foo/file2.old" -cat >"$fromdir/foo/.excl" <"$fromdir/foo/.filt" <"$fromdir/bar/.excl" <"$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" @@ -129,12 +130,12 @@ rm "$chkdir"/bar/down/to/foo/*.junk rm "$chkdir"/bar/down/to/home-cvs-exclude rm "$chkdir"/mid/one-in-one-out -$RSYNC -av --existing --filter='-! */' "$fromdir/" "$chkdir/" +$RSYNC -av --existing --filter='exclude,! */' "$fromdir/" "$chkdir/" # Now, test if rsync excludes the same files, this time with --cvs-exclude # and --delete-excluded. -checkit "$RSYNC -avvC --filter=\". $excl\" --delete-excluded \ +checkit "$RSYNC -avvC --filter=\"merge $excl\" --delete-excluded \ --delete-during \"$fromdir/\" \"$todir/\"" "$chkdir" "$todir" # Modify the chk dir for our merge-exclude test and then tweak the dir times. @@ -144,8 +145,7 @@ rm "$chkdir"/bar/down/to/bar/baz/*.deep cp -p "$fromdir"/bar/down/to/foo/*.junk "$chkdir"/bar/down/to/foo cp -p "$fromdir"/bar/down/to/foo/to "$chkdir"/bar/down/to/foo -$RSYNC -av --existing --delete-excluded \ - --include='.excl*' --filter='-! */' "$fromdir/" "$todir/" +$RSYNC -av --existing -f 'show .filt*' -f 'hide,! */' --del "$fromdir/" "$todir/" echo retained >"$todir"/bar/down/to/bar/baz/nodel.deep cp -p "$todir"/bar/down/to/bar/baz/nodel.deep "$chkdir"/bar/down/to/bar/baz @@ -156,26 +156,45 @@ $RSYNC -av --existing --filter='-! */' "$fromdir/" "$chkdir/" # 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 --filter='-! */' "$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" <