Rewrite PSPP output engine.
[pspp-builds.git] / tests / bugs / t-test-with-temp.sh
1 #!/bin/sh
2
3 # This program tests that the T-TEST 
4 # works ok with a TEMPORARY transformation
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
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 /ind * x * .
63 begin data.
64 1 3.5
65 1 2.0
66 1 2.0
67 2 3.5
68 2 3.0
69 2 4.0
70 end data.
71
72 t-test /groups=ind(1,2) /var x.
73 EOF
74 if [ $? -ne 0 ] ; then no_result ; fi
75
76
77 activity="run program"
78 $SUPERVISOR $PSPP --testing-mode $TESTFILE
79 if [ $? -ne 0 ] ; then no_result ; fi
80
81 activity="copy output"
82 cp $TEMPDIR/pspp.csv $TEMPDIR/first.csv
83 if [ $? -ne 0 ] ; then no_result ; fi
84
85 activity="create program 2"
86 cat > $TESTFILE <<EOF
87 data list list /ind * x * .
88 begin data.
89 1 3.5
90 1 2.0
91 1 2.0
92 2 3.5
93 2 3.0
94 2 4.0
95 2 9.0
96 end data.
97
98 TEMPORARY.
99 SELECT IF ind < 7.
100
101 t-test /groups=ind(1,2) /var x.
102 EOF
103 if [ $? -ne 0 ] ; then no_result ; fi
104
105 activity="compare output"
106 perl -pi -e 's/^\s*$//g' $TEMPDIR/pspp.csv $TEMPDIR/first.csv
107 diff -b $TEMPDIR/pspp.csv $TEMPDIR/first.csv
108 if [ $? -ne 0 ] ; then fail ; fi
109
110
111 pass