X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/db9c9e27660be8672abf55886ff7226abd21004f..1ed9018e69a0d224ff59184974d9150d1cb8814d:/testsuite/devices.test diff --git a/testsuite/devices.test b/testsuite/devices.test index 51df996b..a6bfc9ee 100644 --- a/testsuite/devices.test +++ b/testsuite/devices.test @@ -14,16 +14,9 @@ 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 case "`xattr 2>&1`" in @@ -57,6 +50,18 @@ case `id -u` in ;; esac ;; +*) + 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 + test_skipped "Rsync needs root/fakeroot for device tests" + ;; + esac + ;; esac # TODO: Need to test whether hardlinks are possible on this OS/filesystem @@ -73,17 +78,17 @@ ln "$fromdir/block3" "$fromdir/block2.5" || echo "Skipping hard-linked device te mkfifo "$fromdir/fifo" || mknod "$fromdir/fifo" p || test_skipped "Can't run mkfifo" touch -r "$fromdir/block" "$fromdir/block2" -$RSYNC -ai "$fromdir/block" "$todir/block2" \ +$RSYNC -ait "$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" \ +$RSYNC -ait "$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 +97,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,15 +105,15 @@ $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 block2.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" @@ -127,15 +132,15 @@ if test -b "$fromdir/block2.5"; then $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 block2.5 +hD$allspace block3 +hD$allspace char +hD$allspace char2 +hD$allspace char3 +hS$allspace fifo EOT diff $diffopt "$chkfile" "$outfile" || test_fail "test 4 failed" fi