]> git.saurik.com Git - apt.git/blobdiff - test/libapt/run-tests
Merge remote-tracking branch 'ajt/better-pdiffs-dk' into debian/sid
[apt.git] / test / libapt / run-tests
index 45a3157f7a98f63fbe9b2cd6d5ccd3b65a29c92c..a056f31f98d1bc4a83344f80bdfc4abb4df77306 100755 (executable)
@@ -2,11 +2,14 @@
 set -e
 
 DIR=$(readlink -f $(dirname $0))
-echo "Compiling the tests …"
-(cd $DIR && make)
-echo "Running all testcases …"
+if [ -z "$MAKELEVEL" ]; then
+       echo 'Compiling the tests …'
+       (cd $DIR && make)
+       echo 'Running all testcases …'
+fi
 LDPATH="$DIR/../../build/bin"
 EXT="_libapt_test"
+EXIT_CODE=0
 
 # detect if output is on a terminal (colorful) or better not
 if expr match "$(readlink -f /proc/$$/fd/1)" '/dev/pts/[0-9]\+' > /dev/null; then
@@ -69,9 +72,11 @@ do
                        "${tmppath}/ftp.de.debian.org_debian_dists_sid_main_i18n_Translation-tlh%5fDE"
        elif [ $name = "HashSums${EXT}" ]; then
                TMP="$(readlink -f "./${0}")"
-               echo -n "Testing with ${NAME} "
-               LD_LIBRARY_PATH=${LDPATH} ${testapp} $TMP $(md5sum $TMP | cut -d' ' -f 1) $(sha1sum $TMP | cut -d' ' -f 1) $(sha256sum $TMP | cut -d' ' -f 1) $(sha512sum $TMP | cut -d' ' -f 1) && echo "$TESTOKAY" || echo "$TESTFAIL"
-               continue
+               tmppath="$TMP"
+               tmppath="${tmppath} $(md5sum $TMP | cut -d' ' -f 1)"
+               tmppath="${tmppath} $(sha1sum $TMP | cut -d' ' -f 1)"
+               tmppath="${tmppath} $(sha256sum $TMP | cut -d' ' -f 1)"
+               tmppath="${tmppath} $(sha512sum $TMP | cut -d' ' -f 1)"
        elif [ $name = "CompareVersion${EXT}" ]; then
                tmppath="${DIR}/versions.lst"
        elif [ $name = "CdromFindPackages${EXT}" ]; then
@@ -106,9 +111,15 @@ do
        fi
 
        echo -n "Testing with ${NAME} "
-       LD_LIBRARY_PATH=${LDPATH} ${testapp} ${tmppath} && echo "$TESTOKAY" || echo "$TESTFAIL"
+       if MALLOC_PERTURB_=21 MALLOC_CHECK_=2 LD_LIBRARY_PATH=${LDPATH} ${testapp} ${tmppath} ; then
+               echo "$TESTOKAY"
+       else
+               echo "$TESTFAIL"
+               EXIT_CODE=1
+       fi
 
        if [ -n "$tmppath" -a -d "$tmppath" ]; then
                rm -rf "$tmppath"
        fi
 done
+exit $EXIT_CODE