Rewrite PSPP output engine.
[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 # ensure that top_builddir  are absolute
9 if [ -z "$top_builddir" ] ; then top_builddir=. ; fi
10 if [ -z "$top_srcdir" ] ; then top_srcdir=. ; fi
11 top_builddir=`cd $top_builddir; pwd`
12 PSPP=$top_builddir/src/ui/terminal/pspp
13
14 # ensure that top_srcdir is absolute
15 top_srcdir=`cd $top_srcdir; pwd`
16
17 STAT_CONFIG_PATH=$top_srcdir/config
18 export STAT_CONFIG_PATH
19
20
21 cleanup()
22 {
23      if [ x"$PSPP_TEST_NO_CLEANUP" != x ] ; then 
24         echo "NOT cleaning $TEMPDIR" 
25         return ; 
26      fi
27      cd /
28      rm -rf $TEMPDIR
29 }
30
31
32 fail()
33 {
34     echo $activity
35     echo FAILED
36     cleanup;
37     exit 1;
38 }
39
40
41 no_result()
42 {
43     echo $activity
44     echo NO RESULT;
45     cleanup;
46     exit 2;
47 }
48
49 pass()
50 {
51     cleanup;
52     exit 0;
53 }
54
55 mkdir -p $TEMPDIR
56
57 cd $TEMPDIR
58
59 activity="create program"
60 cat > $TESTFILE << EOF
61 data list notable /X 1-2.
62 begin data.
63 1
64 2
65 3
66 4
67 5
68 6
69 7
70 8
71 9
72 10
73 end data.
74 compute FILTER_$ = mod(x,2).
75
76 filter by filter_$.
77 list.
78 filter off.
79 list.
80 compute filter_$ = 1 - filter_$.
81 filter by filter_$.
82 list.
83
84 EOF
85 if [ $? -ne 0 ] ; then no_result ; fi
86
87
88 activity="run program"
89 $SUPERVISOR $PSPP --testing-mode $TESTFILE
90 if [ $? -ne 0 ] ; then no_result ; fi
91
92
93 activity="check results"
94 diff -c $TEMPDIR/pspp.csv - << EOF
95 Table: Data List
96 X,FILTER_$
97 1,1.00
98 3,1.00
99 5,1.00
100 7,1.00
101 9,1.00
102
103 Table: Data List
104 X,FILTER_$
105 1,1.00
106 2,.00
107 3,1.00
108 4,.00
109 5,1.00
110 6,.00
111 7,1.00
112 8,.00
113 9,1.00
114 10,.00
115
116 Table: Data List
117 X,FILTER_$
118 2,1.00
119 4,1.00
120 6,1.00
121 8,1.00
122 10,1.00
123 EOF
124 if [ $? -ne 0 ] ; then fail ; fi
125
126 pass;