X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/0154b302ce36e9ee8889005c732fba21c9d4d881..952cf8f4f34feba3d40f2cda90d2453f70aa2b3a:/testsuite/rsync.fns diff --git a/testsuite/rsync.fns b/testsuite/rsync.fns index 369d38c8..c5017187 100644 --- a/testsuite/rsync.fns +++ b/testsuite/rsync.fns @@ -21,13 +21,19 @@ TMP="$scratchdir" FROM=${TMP}/from TO=${TMP}/to -F1=text1 LOG=${TMP}/log RSYNC="$rsync_bin" runtest() { echo $ECHO_N "Test $1: $ECHO_C" - eval "$2" + if eval "$2" + then + echo "${ECHO_T} done." + return 0 + else + echo "${ECHO_T} failed!" + return 1 + fi } printmsg() { @@ -39,6 +45,10 @@ printmsg() { # Build test directories TO and FROM, with FROM full of files. hands_setup() { + # Clean before creation + rm -rf $FROM + rm -rf $TO + [ -d $FROM ] || mkdir $FROM [ -d $TO ] || mkdir $TO @@ -56,23 +66,50 @@ hands_setup() { touch ${FROM}/empty mkdir ${FROM}/emptydir - # a few hundred lines of test - ls -lR / | head -200 > ${FROM}/filelist + # a hundred lines of text or so + ls -lR ${srcdir} > ${FROM}/filelist # This might fail on systems that don't have -n echo $ECHO_N "This file has no trailing lf$ECHO_C" > ${FROM}/nolf umask 0 ln -s nolf ${FROM}/nolf-symlink - umask 077 + umask 022 - cat $srcdir/*.c | head -2000 > ${FROM}/${F1} + cat $srcdir/*.c > ${FROM}/text mkdir ${FROM}/dir - cp ${FROM}/${F1} ${FROM}/dir + cp ${FROM}/text ${FROM}/dir mkdir ${FROM}/dir/subdir mkdir ${FROM}/dir/subdir/subsubdir ls -ltr /etc > ${FROM}/dir/subdir/subsubdir/etc-ltr-list mkdir ${FROM}/dir/subdir/subsubdir2 ls -lt /bin > ${FROM}/dir/subdir/subsubdir2/bin-lt-list + + echo testing head: + ls -lR ${srcdir} | head -10 || echo failed +} + + + + +#################### +# Many machines do not have "mkdir -p", so we have to build up long paths. +# How boring. +makepath () { + p="$1" + ( + # Absolut Unix. + if echo $p | grep '^/' >/dev/null + then + cd / + fi + + # This will break if $1 contains a space. + for c in `echo $p | tr '/' ' '` + do + [ -d "$c" ] || mkdir "$c" || return $? + cd "$c" || return $? + done + ) } @@ -106,11 +143,9 @@ checkit() { ( cd $3 ; ls -laR ) > ${TMP}/ls-to 2>>${log} diff -c ${TMP}/ls-from ${TMP}/ls-to >>${log} 2>&1 || failed=YES if [ -z "${failed}" ] ; then - echo "${ECHO_T} done." rm $log return 0 else - echo "${ECHO_T} failed!" cat ${log} rm ${log} return 1