X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/8f5b554f0b564972a4ce5dcd3e809b3e764ff0f7..503f163446bf4ba8a8cd0f521a24e5ef1e6c872e:/testsuite/devices.test diff --git a/testsuite/devices.test b/testsuite/devices.test index 5212dd3a..84086d4b 100644 --- a/testsuite/devices.test +++ b/testsuite/devices.test @@ -9,6 +9,9 @@ . "$suitedir/rsync.fns" +chkfile="$scratchdir/rsync.chk" +outfile="$scratchdir/rsync.out" + # Build some hardlinks case `id -u` in @@ -25,16 +28,66 @@ esac # TODO: Need to test whether hardlinks are possible on this OS/filesystem mkdir "$fromdir" +mkdir "$todir" mknod "$fromdir/char" c 41 67 || test_skipped "Can't create char device node unless root" mknod "$fromdir/char2" c 42 68 || test_skipped "Can't create char device node unless root" mknod "$fromdir/char3" c 42 69 || test_skipped "Can't create char device node unless root" mknod "$fromdir/block" b 42 69 || test_skipped "Can't create block device node unless root" mknod "$fromdir/block2" b 42 73 || test_skipped "Can't create block device node unless root" mknod "$fromdir/block3" b 105 73 || test_skipped "Can't create block device node unless root" -ln "$fromdir/block3" "$fromdir/block3dup" || echo "Skipping hard-linked device test..." +ln "$fromdir/block3" "$fromdir/block2.5" || echo "Skipping hard-linked device test..." mkfifo "$fromdir/fifo" || test_skipped "Can't run mkfifo" +touch -r "$fromdir/block" "$fromdir/block2" + +$RSYNC -ai "$fromdir/block" "$todir/block2" \ + | tee "$outfile" +cat <"$chkfile" +cD+++++++ block +EOT +diff $diffopt "$chkfile" "$outfile" || test_fail "test 1 failed" + +$RSYNC -ai "$fromdir/block2" "$todir/block" \ + | tee "$outfile" +cat <"$chkfile" +cD+++++++ block2 +EOT +diff $diffopt "$chkfile" "$outfile" || test_fail "test 2 failed" + +sleep 1 + +$RSYNC -Di "$fromdir/block3" "$todir/block" \ + | tee "$outfile" +cat <"$chkfile" +cD..T.... block3 +EOT +diff $diffopt "$chkfile" "$outfile" || test_fail "test 3 failed" + +$RSYNC -aiHvv "$fromdir/" "$todir/" \ + | tee "$outfile" +filter_outfile +cat <"$chkfile" +.d..t.... ./ +cD..t.... block +cD....... block2 +cD+++++++ block3 +hD+++++++ block2.5 => block3 +cD+++++++ char +cD+++++++ char2 +cD+++++++ char3 +cS+++++++ fifo +EOT +if test ! -b "$fromdir/block2.5"; then + sed -e '/block2\.5/d' \ + <"$chkfile" >"$chkfile.new" + mv "$chkfile.new" "$chkfile" +fi +diff $diffopt "$chkfile" "$outfile" || test_fail "test 4 failed" -checkit "$RSYNC -aHvv \"$fromdir/\" \"$todir/\"" "$fromdir" "$todir" skip_file_diff +echo "check how the directory listings compare with diff:" +echo "" +( cd "$fromdir" && rsync_ls_lR . ) > "$tmpdir/ls-from" +( cd "$todir" && rsync_ls_lR . ) > "$tmpdir/ls-to" +diff $diffopt "$tmpdir/ls-from" "$tmpdir/ls-to" # The script would have aborted on error, so getting here means we've won. exit 0