X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/9439c0cb5a4b020b9bfcfe0351e33c17b9c53b54..5b385336b93019fef963a0141f6cf94107f2ef23:/testsuite/devices.test diff --git a/testsuite/devices.test b/testsuite/devices.test index b25fa6ea..8df0be62 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" - export RSYNC_FAKE_SUPER=1 + TLS_ARGS="$TLS_ARGS --fake-super" case "`xattr 2>&1`" in *--list:*) mknod() { @@ -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 @@ -76,14 +81,14 @@ touch -r "$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 +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