X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/db9c9e27660be8672abf55886ff7226abd21004f..58663df4323991bde024ffe4436b67e53f56e52b:/testsuite/devices.test diff --git a/testsuite/devices.test b/testsuite/devices.test index 51df996b..bb3ab93d 100644 --- a/testsuite/devices.test +++ b/testsuite/devices.test @@ -14,18 +14,11 @@ outfile="$scratchdir/rsync.out" # Build some hardlinks -case `id -u` in -'') ;; # If "id" failed, try to continue... -0) ;; -*) if [ -f /usr/bin/fakeroot ]; then - echo "Let's try re-running the script under fakeroot..." - exec /usr/bin/fakeroot /bin/sh $RUNSHFLAGS "$0" - fi - - # If we can't test the real device code, try to test --fake-super instead - $RSYNC --version | grep ", xattrs" >/dev/null || test_skipped "Rsync needs root/fakeroot/--fake-super for device tests" +case $0 in +*fake*) + $RSYNC --version | grep ", xattrs" >/dev/null || test_skipped "Rsync needs xattrs for fake device tests" RSYNC="$RSYNC --fake-super" - TLS_ARGS=--fake-super + TLS_ARGS="$TLS_ARGS --fake-super" case "`xattr 2>&1`" in *--list:*) mknod() { @@ -57,6 +50,18 @@ case `id -u` in ;; esac ;; +*) + case `get_testuid` in + '') ;; # If "id" failed, try to continue... + 0) ;; + *) if [ -f /usr/bin/fakeroot ]; then + echo "Let's try re-running the script under fakeroot..." + exec /usr/bin/fakeroot /bin/sh $RUNSHFLAGS "$0" + fi + test_skipped "Rsync needs root/fakeroot for device tests" + ;; + esac + ;; esac # TODO: Need to test whether hardlinks are possible on this OS/filesystem @@ -69,21 +74,22 @@ mknod "$fromdir/char3" c 42 69 || test_skipped "Can't create char device node" mknod "$fromdir/block" b 42 69 || test_skipped "Can't create block device node" mknod "$fromdir/block2" b 42 73 || test_skipped "Can't create block device node" mknod "$fromdir/block3" b 105 73 || test_skipped "Can't create block device node" -ln "$fromdir/block3" "$fromdir/block2.5" || echo "Skipping hard-linked device test..." +ln "$fromdir/block3" "$fromdir/block3.5" || echo "Skipping hard-linked device test..." mkfifo "$fromdir/fifo" || mknod "$fromdir/fifo" p || test_skipped "Can't run mkfifo" -touch -r "$fromdir/block" "$fromdir/block2" +# Work around time rounding/truncating issue by touching both files. +touch -r "$fromdir/block" "$fromdir/block" "$fromdir/block2" $RSYNC -ai "$fromdir/block" "$todir/block2" \ | tee "$outfile" cat <"$chkfile" -cD+++++++++ block +cD$all_plus block EOT diff $diffopt "$chkfile" "$outfile" || test_fail "test 1 failed" $RSYNC -ai "$fromdir/block2" "$todir/block" \ | tee "$outfile" cat <"$chkfile" -cD+++++++++ block2 +cD$all_plus block2 EOT diff $diffopt "$chkfile" "$outfile" || test_fail "test 2 failed" @@ -92,7 +98,7 @@ sleep 1 $RSYNC -Di "$fromdir/block3" "$todir/block" \ | tee "$outfile" cat <"$chkfile" -cD..T...... block3 +cDc.T.$dots block3 EOT diff $diffopt "$chkfile" "$outfile" || test_fail "test 3 failed" @@ -100,18 +106,18 @@ $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 +.d..t.$dots ./ +cDc.t.$dots block +cDc...$dots block2 +cD$all_plus block3 +hD$all_plus block3.5 => block3 +cD$all_plus char +cD$all_plus char2 +cD$all_plus char3 +cS$all_plus fifo EOT -if test ! -r "$fromdir/block2.5"; then - sed -e '/block2\.5/d' <"$chkfile" >"$chkfile.new" +if test ! -r "$fromdir/block3.5"; then + grep -v block3.5 <"$chkfile" >"$chkfile.new" mv "$chkfile.new" "$chkfile" fi diff $diffopt "$chkfile" "$outfile" || test_fail "test 4 failed" @@ -122,22 +128,22 @@ echo "" ( cd "$todir" && rsync_ls_lR . ) > "$tmpdir/ls-to" diff $diffopt "$tmpdir/ls-from" "$tmpdir/ls-to" -if test -b "$fromdir/block2.5"; then +if test -r "$fromdir/block3.5"; then set -x $RSYNC -aii --link-dest="$todir" "$fromdir/" "$chkdir/" \ | tee "$outfile" cat <"$chkfile" -cd ./ -hD block -hD block2 -hD block2.5 -hD block3 -hD char -hD char2 -hD char3 -hS fifo +cd$allspace ./ +hD$allspace block +hD$allspace block2 +hD$allspace block3 +hD$allspace block3.5 +hD$allspace char +hD$allspace char2 +hD$allspace char3 +hS$allspace fifo EOT - diff $diffopt "$chkfile" "$outfile" || test_fail "test 4 failed" + diff $diffopt "$chkfile" "$outfile" || test_fail "test 5 failed" fi # The script would have aborted on error, so getting here means we've won.