source: git/tests/smoke.tst @ a948c08

Last change on this file since a948c08 was a948c08, checked in by Olly Betts <olly@…>, 2 months ago

Improve handling of VERBOSE in tests

Previously VERBOSE showed output from all testcases, even ones which
passed. Now we only show output from testcases which fail for
VERBOSE=1. Other non-empty values of VERBOSE continue to show all
output for cavern.tst and smoke.tst, but have the same effect as
VERBOSE=1 for other tests.

  • Property mode set to 100755
File size: 2.3 KB
Line 
1#!/bin/sh
2#
3# Survex test suite - smoke tests
4# Copyright (C) 1999-2025 Olly Betts
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
18# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
19
20testdir=`echo $0 | sed 's!/[^/]*$!!' || echo '.'`
21
22# allow us to run tests standalone more easily
23: ${srcdir="$testdir"}
24if [ -z "$SURVEXLIB" ] ; then
25  SURVEXLIB=`cd "$srcdir/../lib" && pwd`
26  export SURVEXLIB
27fi
28
29test -x "$testdir"/../src/cavern || testdir=.
30
31# Ensure that --version and --help work without an X display.
32DISPLAY=
33export DISPLAY
34
35PROGS="cavern diffpos extend sorterr survexport aven"
36
37# Suppress checking for leaks on exit if we're build with lsan - we don't
38# generally waste effort to free all allocations as the OS will reclaim
39# memory on exit.
40LSAN_OPTIONS=leak_check_at_exit=0
41export LSAN_OPTIONS
42
43vgrun=
44vg_error=123
45vg_log=vg.log
46if [ -n "$VALGRIND" ] ; then
47  rm -f "$vg_log"
48  vgrun="$VALGRIND --log-file=$vg_log --error-exitcode=$vg_error"
49fi
50
51for p in ${PROGS}; do
52  echo $p
53  for o in version help ; do
54    if test "$VERBOSE" = 1; then
55      $vgrun "$testdir/../src/$p" --$o > stdout.log
56      exitcode=$?
57      test $exitcode = 0 || cat stdout.log
58      rm stdout.log
59    elif test -n "$VERBOSE"; then
60      $vgrun "$testdir/../src/$p" --$o
61      exitcode=$?
62    else
63      $vgrun "$testdir/../src/$p" --$o > /dev/null
64      exitcode=$?
65    fi 2> stderr.log
66    if [ -s stderr.log ] ; then
67      echo "$p --$o produced output on stderr:"
68      cat stderr.log
69      rm stderr.log
70      exit 1
71    fi
72    rm stderr.log
73    if [ -n "$VALGRIND" ] ; then
74      if [ $exitcode = "$vg_error" ] ; then
75        cat "$vg_log"
76        rm "$vg_log"
77        exit 1
78      fi
79      rm "$vg_log"
80    fi
81    [ "$exitcode" = 0 ] || exit 1
82  done
83done
84
85test -n "$VERBOSE" && echo "Test passed"
86exit 0
Note: See TracBrowser for help on using the repository browser.