| #!/bin/sh |
| |
| # A script that runs each unit test independently, with output |
| # directed to a file in OUT/$T.out. If command line arguments are |
| # given, they are tests to run; otherwise every file named |
| # Lib/test/test_* is run (via regrtest). A summary of failing, |
| # passing and skipped tests is written to stdout and to the files |
| # GOOD, BAD and SKIPPED. |
| |
| # Reset PYTHONPATH to avoid alien influences on the tests. |
| unset PYTHONPATH |
| |
| # Choose the Python binary. |
| case `uname` in |
| Darwin) PYTHON=./python.exe;; |
| *) PYTHON=./python;; |
| esac |
| |
| # Create the output directory if necessary. |
| mkdir -p OUT |
| |
| # Empty the summary files. |
| >GOOD |
| >BAD |
| >SKIPPED |
| |
| # Compute the list of tests to run. |
| case $# in |
| 0) |
| TESTS=`(cd Lib/test; ls test_*.py | sed 's/\.py//')` |
| ;; |
| *) |
| TESTS="$@" |
| ;; |
| esac |
| |
| # Run the tests. |
| for T in $TESTS |
| do |
| echo -n $T |
| if $PYTHON Lib/test/regrtest.py -uall $T >OUT/$T.out 2>&1 |
| then |
| if grep -q "1 test skipped:" OUT/$T.out |
| then |
| echo " SKIPPED" |
| echo $T >>SKIPPED |
| else |
| echo |
| echo $T >>GOOD |
| fi |
| else |
| echo " BAD" |
| echo $T >>BAD |
| fi |
| done |