##// END OF EJS Templates
Fix up version module name and command conflict...
Fix up version module name and command conflict -----BEGIN PGP SIGNED MESSAGE----- Hash: SHA1 Fix up version module name and command conflict This unties the command name from the function name manifest hash: 926d097f75cbb5eb2464bb253e9a89050c6208bd -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.4.0 (GNU/Linux) iD8DBQFCvRLnywK+sNU5EO8RAvryAJ9RU0PLFOXjjtQjs8UVyOC9wde69gCgrV+G 8jYfMyWwvwsmOM7wMblPGqM= =Acyk -----END PGP SIGNATURE-----

File last commit:

r429:688d03d6 merge default
r470:0ab093b4 default
Show More
run-tests
77 lines | 1.2 KiB | text/plain | TextLexer
mpm@selenic.com
Add a simple testing framework...
r331 #!/bin/bash
set -e
tests=0
failed=0
H=$PWD
mpm@selenic.com
From: Andrew Thompson <andrewkt@aktzero.com>...
r397 TESTPATH=$PWD/install/bin
export PATH=$TESTPATH:$PATH
export PYTHONPATH=$PWD/install/lib/python
rm -rf install
cd ..
mpm@selenic.com
Quiet successful test install in run-tests...
r398 ${PYTHON:-python} setup.py install --home=tests/install > tests/install.err
if [ $? != 0 ] ; then
cat tests/install.err
fi
mpm@selenic.com
From: Andrew Thompson <andrewkt@aktzero.com>...
r397 cd $H
mpm@selenic.com
Quiet successful test install in run-tests...
r398 rm install.err
mpm@selenic.com
From: Andrew Thompson <andrewkt@aktzero.com>...
r397
mpm@selenic.com
run-tests: run tests given on the command line...
r362 function run_one
{
mpm@selenic.com
Delete error logs one test at a time...
r399 rm -f $1.err
mpm@selenic.com
test suite: fix timezone problems and port collision problem...
r382 export TZ=GMT
mpm@selenic.com
Add a simple testing framework...
r331 D=`mktemp -d`
if [ "$D" == "" ] ; then
echo mktemp failed!
fi
cd $D
fail=0
mpm@selenic.com
run-tests: run tests given on the command line...
r362
mpm@selenic.com
Delete error logs one test at a time...
r399 if ! $H/$1 > .out 2>&1 ; then
echo $1 failed with error code $?
mpm@selenic.com
Add a simple testing framework...
r331 fail=1
fi
mpm@selenic.com
run-tests: run tests given on the command line...
r362
mpm@selenic.com
Delete error logs one test at a time...
r399 if [ -s .out -a ! -r $H/$1.out ] ; then
echo $1 generated unexpected output:
mpm@selenic.com
Add a simple testing framework...
r331 cat .out
mpm@selenic.com
Delete error logs one test at a time...
r399 cp .out $H/$1.err
mpm@selenic.com
Add a simple testing framework...
r331 fail=1
mpm@selenic.com
Delete error logs one test at a time...
r399 elif [ -r $H/$1.out ] && ! diff -u $H/$1.out .out > /dev/null ; then
echo $1 output changed:
diff -u $H/$1.out .out && true
cp .out $H/$1.err
mpm@selenic.com
run-tests: actually mark changed output as failure...
r341 fail=1
mpm@selenic.com
Add a simple testing framework...
r331 fi
cd $H
rm -r $D
mpm@selenic.com
run-tests: run tests given on the command line...
r362 return $fail
}
mpm@selenic.com
Add a simple testing framework...
r331
mpm@selenic.com
run-tests: run tests given on the command line...
r362 TESTS=$@
if [ "$TESTS" == "" ] ; then
TESTS=`ls test-* | grep -Ev "\.|~"`
fi
for f in $TESTS ; do
echo -n "."
if ! run_one $f ; then
failed=$[$failed + 1]
fi
mpm@selenic.com
Add a simple testing framework...
r331 tests=$[$tests + 1]
done
mpm@selenic.com
From: Andrew Thompson <andrewkt@aktzero.com>...
r397 rm -rf install
mpm@selenic.com
Add a simple testing framework...
r331 echo
echo Ran $tests tests, $failed failed
if [ $failed -gt 0 ] ; then
exit 1
fi