Sat Jul 30 21:54:23 2005 Ben Pfaff <blp@gnu.org>
[pspp-builds.git] / tests / command / filter.sh
1 #!/bin/sh
2
3 # This program tests ....
4
5 TEMPDIR=/tmp/pspp-tst-$$
6 TESTFILE=$TEMPDIR/`basename $0`.sps
7
8 here=`pwd`;
9
10 # ensure that top_srcdir is absolute
11 cd $top_srcdir; top_srcdir=`pwd`
12
13 STAT_CONFIG_PATH=$top_srcdir/config
14 export STAT_CONFIG_PATH
15
16
17 cleanup()
18 {
19      cd /
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"
52 cat > $TESTFILE << EOF
53 data list notable /X 1-2.
54 begin data.
55 1
56 2
57 3
58 4
59 5
60 6
61 7
62 8
63 9
64 10
65 end data.
66 compute FILTER_$ = mod(x,2).
67
68 filter by filter_$.
69 list.
70 filter off.
71 list.
72 compute filter_$ = 1 - filter_$.
73 filter by filter_$.
74 list.
75
76 EOF
77 if [ $? -ne 0 ] ; then no_result ; fi
78
79
80 activity="run program"
81 $SUPERVISOR $here/../src/pspp --testing-mode -o raw-ascii $TESTFILE
82 if [ $? -ne 0 ] ; then no_result ; fi
83
84
85 activity="check results"
86 diff -B -b $TEMPDIR/pspp.list - << EOF
87  X FILTER_$
88 -- --------
89  1     1.00 
90  3     1.00 
91  5     1.00 
92  7     1.00 
93  9     1.00 
94
95  X FILTER_$
96 -- --------
97  1     1.00 
98  2      .00 
99  3     1.00 
100  4      .00 
101  5     1.00 
102  6      .00 
103  7     1.00 
104  8      .00 
105  9     1.00 
106 10      .00 
107
108  X FILTER_$
109 -- --------
110  2     1.00 
111  4     1.00 
112  6     1.00 
113  8     1.00 
114 10     1.00 
115
116 EOF
117 if [ $? -ne 0 ] ; then fail ; fi
118
119 pass;