Fixed numerous memory leaks. Changed many of the test cases to use a canonical
[pspp-builds.git] / tests / command / t-test-1-sample-missing-list.sh
1 #!/bin/sh
2
3 # This program tests that the T-TEST /TESTVAL command works OK
4 # when there are listwise missing values 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 export STAT_CONFIG_PATH=$top_srcdir/config
15
16
17 cleanup()
18 {
19      rm -rf $TEMPDIR
20 }
21
22
23 fail()
24 {
25     echo $activity
26     echo FAILED
27     cleanup;
28     exit 1;
29 }
30
31
32 no_result()
33 {
34     echo $activity
35     echo NO RESULT;
36     cleanup;
37     exit 2;
38 }
39
40 pass()
41 {
42     cleanup;
43     exit 0;
44 }
45
46 mkdir -p $TEMPDIR
47
48 cd $TEMPDIR
49
50 activity="create program 1"
51 cat > $TEMPDIR/out.stat <<EOF
52 data list list /id * x1 * x2.
53 begin data.
54 1 3.5 34
55 2 2.0 10
56 3 2.0 23
57 4 3.5 98
58 5 3.0 23
59 end data.
60
61 t-test /testval=3.0 /var=x1 x2.
62 EOF
63 if [ $? -ne 0 ] ; then no_result ; fi
64
65
66 activity="run program 1"
67 $SUPERVISOR $here/../src/pspp -o raw-ascii $TEMPDIR/out.stat
68 if [ $? -ne 0 ] ; then no_result ; fi
69
70 activity="copy output"
71 cp $TEMPDIR/pspp.list $TEMPDIR/ref.list
72 if [ $? -ne 0 ] ; then no_result ; fi
73
74
75 activity="create program 2"
76 cat > $TEMPDIR/out.stat <<EOF
77 data list list /id * x1 * x2.
78 begin data.
79 1 3.5 34
80 2 2.0 10
81 3 2.0 23
82 4 3.5 98
83 5 3.0 23
84 6 4.0 99
85 end data.
86
87 MISSING VALUES x2(99).
88
89 t-test /missing=listwise /testval=3.0 /var=x1 x2.
90 EOF
91 if [ $? -ne 0 ] ; then no_result ; fi
92
93 activity="run program 2"
94 $SUPERVISOR $here/../src/pspp -o raw-ascii $TEMPDIR/out.stat
95 if [ $? -ne 0 ] ; then no_result ; fi
96
97 activity="compare outputs"
98 diff $TEMPDIR/ref.list $TEMPDIR/pspp.list
99 if [ $? -ne 0 ] ; then fail ; fi
100
101
102 pass