Fix use of "export" to work with traditional shells.
[pspp-builds.git] / tests / command / t-test-indep-missing-anal.sh
1 #!/bin/sh
2
3 # This program tests that the T-TEST /GROUPS command works OK
4 # when ANALYSIS missing values are involved
5
6 TEMPDIR=/tmp/pspp-tst-$$
7 TESTFILE=$TEMPDIR/`basename $0`.sps
8
9 here=`pwd`;
10
11 # ensure that top_srcdir is absolute
12 cd $top_srcdir; top_srcdir=`pwd`
13
14 STAT_CONFIG_PATH=$top_srcdir/config
15 export STAT_CONFIG_PATH
16
17
18 cleanup()
19 {
20      rm -rf $TEMPDIR
21 }
22
23
24 fail()
25 {
26     echo $activity
27     echo FAILED
28     cleanup;
29     exit 1;
30 }
31
32
33 no_result()
34 {
35     echo $activity
36     echo NO RESULT;
37     cleanup;
38     exit 2;
39 }
40
41 pass()
42 {
43     cleanup;
44     exit 0;
45 }
46
47 mkdir -p $TEMPDIR
48
49 cd $TEMPDIR
50
51 activity="create program 1"
52 cat > $TESTFILE <<EOF
53 data list list /id * indep * dep1 * dep2 *.
54 begin data.
55 1  1.0 3.5 6
56 2  1.0 2.0 5
57 3  1.0 2.0 4
58 4  2.0 3.5 3
59 56 2.0 3.0 1
60 end data.
61
62 t-test /group=indep /var=dep1, dep2.
63 EOF
64 if [ $? -ne 0 ] ; then no_result ; fi
65
66
67 activity="run program 1"
68 $SUPERVISOR $here/../src/pspp -o raw-ascii $TESTFILE
69 if [ $? -ne 0 ] ; then no_result ; fi
70
71 activity="copy output"
72 cp $TEMPDIR/pspp.list $TEMPDIR/ref.list
73 if [ $? -ne 0 ] ; then no_result ; fi
74
75 activity="create program 2"
76 cat > $TESTFILE <<EOF
77 data list list /id * indep * dep1 * dep2.
78 begin data.
79 1 1.0 3.5 6
80 2 1.0 2.0 5
81 3 1.0 2.0 4
82 4 2.0 3.5 3
83 5 2.0 3.0 .
84 6 2.0 .   1
85 7  .  3.1 5
86 end data.
87
88 * Note that if the independent variable is missing, then it's implicitly 
89 * listwise missing.
90
91 t-test /missing=analysis /group=indep /var=dep1 dep2.
92 EOF
93 if [ $? -ne 0 ] ; then no_result ; fi
94
95 activity="run program 2"
96 $SUPERVISOR $here/../src/pspp -o raw-ascii $TESTFILE
97 if [ $? -ne 0 ] ; then no_result ; fi
98
99
100 activity="compare outputs"
101 diff $TEMPDIR/ref.list $TEMPDIR/pspp.list 
102 if [ $? -ne 0 ] ; then fail ; fi
103
104
105 pass