Changes for 3.3.1dev.
[rsync.git] / testsuite / duplicates.test
blob3317e72f68c0c9ee5fdfe5755475ed64b807217d
1 #!/bin/sh
3 # Copyright (C) 2002 by Martin Pool <mbp@samba.org>
5 # This program is distributable under the terms of the GNU GPL (see
6 # COPYING).
8 # Test rsync handling of duplicate filenames.
10 # It's quite possible that the user might specify the same source file
11 # more than once on the command line, perhaps through shell variables
12 # or wildcard expansions. It might cause problems for rsync if the
13 # same name occurred more than once in the file list, because we might
14 # be trying to update the first copy and generate checksums for the
15 # second copy at the same time. See clean_flist() for the implementation.
17 # We don't need to worry about hardlinks or symlinks. Because we
18 # always rename-and-replace the new copy, they can't affect us.
20 # This test is not great, because it is a timing-dependent bug.
22 . "$suitedir/rsync.fns"
24 # Build some hardlinks
26 mkdir "$fromdir"
27 name1="$fromdir/name1"
28 name2="$fromdir/name2"
29 echo "This is the file" > "$name1"
30 ln -s "$name1" "$name2" || test_fail "can't create symlink"
32 checkit "$RSYNC -avv '$fromdir/' '$fromdir/' '$fromdir/' '$fromdir/' '$fromdir/' '$fromdir/' '$fromdir/' '$fromdir/' '$fromdir/' '$fromdir/' '$todir/'" "$fromdir" "$todir" \
33 | tee "$outfile"
35 # Make sure each file was only copied once...
36 if [ `grep -c '^name1$' "$outfile"` != 1 ]; then
37 test_fail "name1 was not copied exactly once"
39 if [ `grep -c '^name2 -> ' "$outfile"` != 1 ]; then
40 test_fail "name2 was not copied exactly once"
43 # The script would have aborted on error, so getting here means we've won.
44 exit 0