LOOP: Convert tests to Autotest framework.
[pspp] / tests / bugs / multipass.sh
1 #!/bin/sh
2
3 # This program tests for a bug which caused UNIFORM(x) to always return zero.
4
5
6 TEMPDIR=/tmp/pspp-tst-$$
7 TESTFILE=$TEMPDIR/`basename $0`.sps
8
9 # ensure that top_builddir  are absolute
10 if [ -z "$top_builddir" ] ; then top_builddir=. ; fi
11 if [ -z "$top_srcdir" ] ; then top_srcdir=. ; fi
12 top_builddir=`cd $top_builddir; pwd`
13 PSPP=$top_builddir/src/ui/terminal/pspp$EXEEXT
14
15 # ensure that top_srcdir is absolute
16 top_srcdir=`cd $top_srcdir; pwd`
17
18 STAT_CONFIG_PATH=$top_srcdir/config
19 export STAT_CONFIG_PATH
20
21
22 cleanup()
23 {
24      if [ x"$PSPP_TEST_NO_CLEANUP" != x ] ; then 
25         echo "NOT cleaning $TEMPDIR" 
26         return ; 
27      fi
28      cd /
29      rm -rf $TEMPDIR
30 }
31
32
33 fail()
34 {
35     echo $activity
36     echo FAILED
37     cleanup;
38     exit 1;
39 }
40
41
42 no_result()
43 {
44     echo $activity
45     echo NO RESULT;
46     cleanup;
47     exit 2;
48 }
49
50 pass()
51 {
52     cleanup;
53     exit 0;
54 }
55
56 mkdir -p $TEMPDIR
57
58 cd $TEMPDIR
59
60 activity="create program"
61 cat > $TESTFILE <<EOF
62 data list list /ID * ABC *.
63 begin data.
64 1 3.5
65 2 2.0
66 3 2.0
67 4 3.5
68 5 3.0
69 6 4.0
70 7 5.0
71 end data.
72
73 TEMPORARY.
74 SELECT IF id < 7 .
75
76 DESCRIPTIVES
77         /VAR=abc.
78 EOF
79 if [ $? -ne 0 ] ; then no_result ; fi
80
81 $SUPERVISOR $PSPP -o pspp.csv $TESTFILE
82 if [ $? -ne 0 ] ; then no_result ; fi
83
84
85 diff -c $TEMPDIR/pspp.csv - << EOF
86 Table: Reading free-form data from INLINE.
87 Variable,Format
88 ID,F8.0
89 ABC,F8.0
90
91 Table: Valid cases = 6; cases with missing value(s) = 0.
92 Variable,N,Mean,Std Dev,Minimum,Maximum
93 ABC,6,3.00,.84,2.00,4.00
94 EOF
95 if [ $? -ne 0 ] ; then fail ; fi
96
97 pass;