3edee7579cbfb6e16a8f9c324de5d7427a3bbe81
[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 perl -pi -e 's/^\s*$//g' $TEMPDIR/pspp.list
87 diff  -b $TEMPDIR/pspp.list - << EOF
88  X FILTER_$
89 -- --------
90  1     1.00 
91  3     1.00 
92  5     1.00 
93  7     1.00 
94  9     1.00 
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  X FILTER_$
108 -- --------
109  2     1.00 
110  4     1.00 
111  6     1.00 
112  8     1.00 
113 10     1.00 
114 EOF
115 if [ $? -ne 0 ] ; then fail ; fi
116
117 pass;