3 # Survex test suite - cavern tests
4 # Copyright (C) 1999-2004,2005,2006,2010,2012,2013,2014,2015,2016,2017 Olly Betts
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.
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.
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
18 # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
20 testdir=`echo $0 | sed 's!/[^/]*$!!' || echo '.'`
22 # allow us to run tests standalone more easily
23 : ${srcdir="$testdir"}
25 # force VERBOSE if we're run on a subset of tests
26 test -n "$*" && VERBOSE=1
28 test -x "$testdir"/../src/cavern || testdir=.
30 # Make testdir absolute, so we can cd before running cavern to get a consistent
31 # path in diagnostic messages.
32 testdir=`(cd "$testdir" && pwd)`
34 : ${CAVERN="$testdir"/../src/cavern}
35 : ${DIFFPOS="$testdir"/../src/diffpos}
36 : ${SURVEXPORT="$testdir"/../src/survexport}
38 : ${TESTS=${*:-"singlefix singlereffix oneleg midpoint noose cross firststn\
39 deltastar deltastar2 bug3 calibrate_tape nosurvey2 cartesian cartesian2\
40 lengthunits angleunits cmd_alias cmd_truncate cmd_case cmd_fix cmd_solve\
41 cmd_entrance cmd_entrance_bad cmd_sd cmd_sd_bad cmd_fix_bad cmd_set\
42 cmd_set_bad beginroot revcomplist break_replace_pfx bug0 bug1 bug2 bug4 bug5\
43 expobug require export export2 includecomment\
44 self_loop self_eq_loop reenterwarn cmd_default cmd_prefix cmd_prefix_bad\
45 cmd_begin_bad cmd_equate_bad cmd_export_bad\
46 singlefixerr singlereffixerr\
47 begin_no_end end_no_begin end_no_begin_nest require_fail\
48 exporterr1 exporterr2 exporterr3 exporterr4 exporterr5\
49 exporterr1b exporterr2b exporterr3b exporterr6 exporterr6b\
50 hanging_cpt badinc badinc2 badinc3 badinc4 nonexistent_file ONELEG\
51 stnsurvey1 stnsurvey2\
52 tapelessthandepth longname chinabug chinabug2\
53 multinormal multinormignall multidiving multicylpolar multicartesian\
54 multinosurv multinormalbad multibug\
55 cmd_title cmd_titlebad cmd_dummy cmd_infer cmd_date cmd_datebad cmd_datebad2\
56 cartes diving cylpolar normal normal_bad normignall nosurv cmd_flags\
57 bad_cmd_flags plumb unusedstation exportnakedbegin oldestyle bugdz\
58 baddatacylpolar badnewline badquantities imgoffbyone infereqtopofil 3sdfixbug\
59 omitclino back back2 bad_back\
60 notentranceorexport inferunknown inferexports bad_units_factor\
62 percent_gradient dotinsurvey leandroclino lowsd revdir gettokennullderef\
63 nosurveyhanging cmd_solve_nothing cmd_solve_nothing_implicit\
64 cmd_calibrate cmd_declination cmd_declination_auto cmd_declination_conv\
65 lech level 2fixbug dot17 3dcorner\
67 declination.dat ignore.dat backread.dat nomeasure.dat noteam.dat\
68 surfequate passage hanging_lrud equatenosuchstn surveytypo\
69 skipafterbadomit passagebad badreadingdotplus badcalibrate calibrate_clino\
70 badunits badbegin anonstn anonstnbad anonstnrev doubleinc reenterlots\
71 cs csbad csbadsdfix csfeet cslonglat omitfixaroundsolve repeatreading\
72 mixedeols utf8bom nonewlineateof\
75 # Test file stnsurvey3.svx missing: pos=fail # We exit before the error count.
83 vg_log=$testdir/vg.log
84 if [ -n "$VALGRIND" ] ; then
86 CAVERN="$VALGRIND --log-file=$vg_log --error-exitcode=$vg_error $CAVERN"
87 DIFFPOS="$VALGRIND --log-file=$vg_log --error-exitcode=$vg_error $DIFFPOS"
88 SURVEXPORT="$VALGRIND --log-file=$vg_log --error-exitcode=$vg_error $SURVEXPORT"
91 for file in $TESTS ; do
93 nonexistent_file*|ONELEG)
94 # ONELEG tests that we don't apply special handling to command line
95 # arguments, only those in *include.
97 *.*) realfile=$file ;;
98 *) realfile=$file.svx ;;
101 if [ x"$file" = xONELEG ] && [ -f "ONELEG.SVX" ] ; then
102 echo "Case insensitive filing system - skipping ONELEG testcase"
106 if [ -n "$realfile" ] && [ ! -r "$realfile" ] ; then
107 echo "Warning: don't know how to run test '$file' - skipping it"
113 # how many warnings to expect
115 # how many errors to expect
120 # .dat files can't start with a comment. All the current .dat tests
121 # have the same settings.
125 nonexistent_file*|ONELEG)
126 # We exit before the error count.
130 read header < "$realfile"
132 while shift && [ -n "$1" ] ; do
134 pos=*) pos=`expr "$1" : 'pos=\(.*\)'` ;;
135 warn=*) warn=`expr "$1" : 'warn=\(.*\)'` ;;
136 error=*) error=`expr "$1" : 'error=\(.*\)'` ;;
142 basefile=$srcdir/$file
146 basefile=`echo "$basefile"|sed 's/\.[^.]*$//'` ;;
148 input="./$file.svx" ;;
150 outfile=$basefile.out
151 posfile=$basefile.pos
152 dxffile=$basefile.dxf
156 srcdir=. $CAVERN "$input" --output="$pwd/tmp" > "$pwd/tmp.out"
159 test -n "$VERBOSE" && cat tmp.out
160 if [ -n "$VALGRIND" ] ; then
161 if [ $exitcode = "$vg_error" ] ; then
168 if test fail = "$pos" ; then
169 # success gives 0, signal (128 + <signal number>)
170 test $exitcode = 1 || exit 1
172 test $exitcode = 0 || exit 1
174 if test -n "$warn" ; then
175 w=`sed '$!d;s/^There were \([0-9]*\).*/\1/;s/^[^0-9].*$/0/' tmp.out`
176 if test x"$w" != x"$warn" ; then
177 test -n "$VERBOSE" && echo "Got $w warnings, expected $warn"
181 if test -n "$error" ; then
182 e=`sed '$!d;s/^There were .* and \([0-9][0-9]*\).*/\1/;s/^[^0-9].*$/0/' tmp.out`
183 if test x"$e" != x"$error" ; then
184 test -n "$VERBOSE" && echo "Got $e errors, expected $error"
188 # Fail if nan, NaN, etc in output (which might be followed by m for metres or
190 if egrep -q '(^|[^A-Za-z0-9])nan[ms]?($|[^A-Za-z0-9])' tmp.out ; then
191 echo "Not-a-number appears in output"
197 if test -n "$VERBOSE" ; then
198 $DIFFPOS "$posfile" tmp.3d
201 $DIFFPOS "$posfile" tmp.3d > /dev/null
204 if [ -n "$VALGRIND" ] ; then
205 if [ $exitcode = "$vg_error" ] ; then
212 [ "$exitcode" = 0 ] || exit 1
215 if test -n "$VERBOSE" ; then
216 $SURVEXPORT --defaults --surface-legs tmp.3d tmp.dxf
219 $SURVEXPORT --defaults --surface-legs tmp.3d tmp.dxf > /dev/null
222 if [ -n "$VALGRIND" ] ; then
223 if [ $exitcode = "$vg_error" ] ; then
230 [ "$exitcode" = 0 ] || exit 1
231 if test -n "$VERBOSE" ; then
232 diff "$dxffile" tmp.dxf || exit 1
234 cmp -s "$dxffile" tmp.dxf || exit 1
237 test -f tmp.3d || exit 1 ;;
239 test -f tmp.3d && exit 1
240 # Check that last line doesn't contains "Bug in program detected"
241 case `tail -n 1 tmp.out` in
242 *"Bug in program detected"*) exit 1 ;;
245 echo "Bad value for pos: '$pos'" ; exit 1 ;;
248 if test -f "$outfile" ; then
249 # Check output is as expected, working around Apple's stone-age sed.
250 if test -n "$VERBOSE" ; then
251 sed '1,/^Copyright/d;/^\(CPU \)*[Tt]ime used *[0-9][0-9.]*s$/d;s!.*/src/\(cavern: \)!\1!' tmp.out|diff "$outfile" - || exit 1
253 sed '1,/^Copyright/d;/^\(CPU \)*[Tt]ime used *[0-9][0-9.]*s$/d;s!.*/src/\(cavern: \)!\1!' tmp.out|cmp -s "$outfile" - || exit 1
258 test -n "$VERBOSE" && echo "Test passed"