[58f02ae] | 1 | #!/bin/sh |
---|
[d4ea980] | 2 | # |
---|
| 3 | # Survex test suite - 3dtopos tests |
---|
[bbe0a27] | 4 | # Copyright (C) 1999-2003,2005,2010,2012 Olly Betts |
---|
[d4ea980] | 5 | # |
---|
| 6 | # This program is free software; you can redistribute it and/or modify |
---|
| 7 | # it under the terms of the GNU General Public License as published by |
---|
| 8 | # the Free Software Foundation; either version 2 of the License, or |
---|
| 9 | # (at your option) any later version. |
---|
| 10 | # |
---|
| 11 | # This program is distributed in the hope that it will be useful, |
---|
| 12 | # but WITHOUT ANY WARRANTY; without even the implied warranty of |
---|
| 13 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
---|
| 14 | # GNU General Public License for more details. |
---|
| 15 | # |
---|
| 16 | # You should have received a copy of the GNU General Public License |
---|
| 17 | # along with this program; if not, write to the Free Software |
---|
[cc49471] | 18 | # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA |
---|
[58f02ae] | 19 | |
---|
| 20 | testdir=`echo $0 | sed 's!/[^/]*$!!' || echo '.'` |
---|
| 21 | |
---|
| 22 | # allow us to run tests standalone more easily |
---|
| 23 | : ${srcdir="$testdir"} |
---|
| 24 | |
---|
| 25 | # force VERBOSE if we're run on a subset of tests |
---|
| 26 | test -n "$*" && VERBOSE=1 |
---|
| 27 | |
---|
[87681b8] | 28 | test -x "$testdir"/../src/cavern || testdir=. |
---|
| 29 | |
---|
[58f02ae] | 30 | : ${DIFFPOS="$testdir"/../src/diffpos} |
---|
| 31 | : ${TDTOPOS="$testdir"/../src/3dtopos} |
---|
| 32 | |
---|
[e0c8f98] | 33 | : ${TESTS=${*:-"pos.pos v0 v0b v1 v2 v3"}} |
---|
[58f02ae] | 34 | |
---|
[38c4c5c] | 35 | vg_error=123 |
---|
| 36 | vg_log=vg.log |
---|
| 37 | if [ -n "$VALGRIND" ] ; then |
---|
| 38 | rm -f "$vg_log" |
---|
| 39 | TDTOPOS="$VALGRIND --log-file=$vg_log --error-exitcode=$vg_error $TDTOPOS" |
---|
| 40 | DIFFPOS="$VALGRIND --log-file=$vg_log --error-exitcode=$vg_error $DIFFPOS" |
---|
| 41 | fi |
---|
| 42 | |
---|
[58f02ae] | 43 | for file in $TESTS ; do |
---|
| 44 | echo $file |
---|
[de10f8d] | 45 | case $file in |
---|
[d4ea980] | 46 | *.pos) input="$srcdir/$file" ;; |
---|
| 47 | *) input="$srcdir/$file.3d" ;; |
---|
| 48 | esac |
---|
[87681b8] | 49 | rm -f tmp.pos diffpos.tmp |
---|
[38c4c5c] | 50 | $TDTOPOS "$input" tmp.pos |
---|
| 51 | exitcode=$? |
---|
| 52 | if [ -n "$VALGRIND" ] ; then |
---|
| 53 | if [ $exitcode = "$vg_error" ] ; then |
---|
| 54 | cat "$vg_log" |
---|
| 55 | rm "$vg_log" |
---|
| 56 | exit 1 |
---|
| 57 | fi |
---|
| 58 | rm "$vg_log" |
---|
| 59 | fi |
---|
| 60 | test $exitcode = 0 || exit 1 |
---|
[d4ea980] | 61 | $DIFFPOS "$input" tmp.pos > diffpos.tmp |
---|
[38c4c5c] | 62 | exitcode=$? |
---|
[58f02ae] | 63 | if test -n "$VERBOSE" ; then |
---|
[87681b8] | 64 | cat diffpos.tmp |
---|
[58f02ae] | 65 | fi |
---|
[38c4c5c] | 66 | if [ -n "$VALGRIND" ] ; then |
---|
| 67 | if [ $exitcode = "$vg_error" ] ; then |
---|
| 68 | cat "$vg_log" |
---|
| 69 | rm "$vg_log" |
---|
| 70 | exit 1 |
---|
| 71 | fi |
---|
| 72 | rm "$vg_log" |
---|
| 73 | fi |
---|
[87681b8] | 74 | test -s diffpos.tmp && exit 1 |
---|
| 75 | rm -f tmp.pos diffpos.tmp |
---|
[58f02ae] | 76 | done |
---|
[bbe0a27] | 77 | test -n "$VERBOSE" && echo "Test passed" |
---|
[58f02ae] | 78 | exit 0 |
---|