Checkin of new directory structure.
[pspp-builds.git] / 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
14 # ensure that top_srcdir is absolute
15 top_srcdir=`cd $top_srcdir; pwd`
16
17 STAT_CONFIG_PATH=$top_srcdir/config
18 export STAT_CONFIG_PATH
19
20
21 cleanup()
22 {
23      cd /
24      rm -rf $TEMPDIR
25 }
26
27
28 fail()
29 {
30     echo $activity
31     echo FAILED
32     cleanup;
33     exit 1;
34 }
35
36
37 no_result()
38 {
39     echo $activity
40     echo NO RESULT;
41     cleanup;
42     exit 2;
43 }
44
45 pass()
46 {
47     cleanup;
48     exit 0;
49 }
50
51 mkdir -p $TEMPDIR
52
53 cd $TEMPDIR
54
55 activity="create program"
56 cat > $TESTFILE <<EOF
57 data list list /ID * ABC *.
58 begin data.
59 1 3.5
60 2 2.0
61 3 2.0
62 4 3.5
63 5 3.0
64 6 4.0
65 7 5.0
66 end data.
67
68 TEMPORARY.
69 SELECT IF id < 7 .
70
71 DESCRIPTIVES
72         /VAR=abc.
73 EOF
74 if [ $? -ne 0 ] ; then no_result ; fi
75
76 $SUPERVISOR $top_builddir/src/pspp -o raw-ascii $TESTFILE
77 if [ $? -ne 0 ] ; then no_result ; fi
78
79
80 perl -pi -e 's/^\s*$//g' $TEMPDIR/pspp.list
81 diff -b  -w $TEMPDIR/pspp.list - << EOF
82 1.1 DATA LIST.  Reading free-form data from INLINE.
83 +--------+------+
84 |Variable|Format|
85 #========#======#
86 |ID      |F8.0  |
87 |ABC     |F8.0  |
88 +--------+------+
89 2.1 DESCRIPTIVES.  Valid cases = 6; cases with missing value(s) = 0.
90 +--------#-+-----+-------+-------+-------+
91 |Variable#N| Mean|Std Dev|Minimum|Maximum|
92 #========#=#=====#=======#=======#=======#
93 |ABC     #6|3.000|   .837|  2.000|  4.000|
94 +--------#-+-----+-------+-------+-------+
95 EOF
96 if [ $? -ne 0 ] ; then fail ; fi
97
98 pass;