Rewrite PSPP output engine.
[pspp-builds.git] / tests / command / t-test-indep-missing-list.sh
1 #!/bin/sh
2
3 # This program tests that the T-TEST /GROUPS command works OK
4 # when LISTWISE missing values are involved
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 1"
61 cat > $TESTFILE <<EOF
62 data list list /id * indep * dep1 * dep2.
63 begin data.
64 1 1.0 3.5 6
65 2 1.0 2.0 5
66 3 1.0 2.0 4
67 4 2.0 3.5 3
68 5 2.0 3.0 2
69 6 2.0 4.0 1
70 end data.
71
72 t-test /group=indep /var=dep1 dep2.
73 EOF
74 if [ $? -ne 0 ] ; then no_result ; fi
75
76
77 activity="run program 1"
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/ref.csv
83 if [ $? -ne 0 ] ; then no_result ; fi
84
85 activity="create program 2"
86 cat > $TESTFILE <<EOF
87 data list list /id * indep * dep1 * dep2 *.
88 begin data.
89 1 1.0 3.5 6
90 2 1.0 2.0 5
91 3 1.0 2.0 4
92 4 2.0 3.5 3
93 5 2.0 3.0 2
94 6 2.0 4.0 1
95 7 2.0 .   0
96 end data.
97
98 t-test /missing=listwise,exclude /group=indep /var=dep1, dep2.
99 EOF
100 if [ $? -ne 0 ] ; then no_result ; fi
101
102 activity="run program 2"
103 $SUPERVISOR $PSPP --testing-mode $TESTFILE
104 if [ $? -ne 0 ] ; then no_result ; fi
105
106
107 activity="compare outputs"
108 diff $TEMPDIR/ref.csv $TEMPDIR/pspp.csv 
109 if [ $? -ne 0 ] ; then fail ; fi
110
111
112 pass