Add another expression test and fix the bugs it found.
[pspp-builds.git] / tests / expressions / variables.sh
1 #!/bin/sh
2
3 # This program tests use of variables in expressions.
4
5 TEMPDIR=/tmp/pspp-tst-$$
6
7 here=`pwd`;
8
9 # ensure that top_srcdir is absolute
10 cd $top_srcdir; top_srcdir=`pwd`
11
12 export STAT_CONFIG_PATH=$top_srcdir/config
13
14
15 cleanup()
16 {
17      rm -rf $TEMPDIR
18 }
19
20
21 fail()
22 {
23     echo $activity
24     echo FAILED
25     cleanup;
26     exit 1;
27 }
28
29
30 no_result()
31 {
32     echo $activity
33     echo NO RESULT;
34     cleanup;
35     exit 2;
36 }
37
38 pass()
39 {
40     cleanup;
41     exit 0;
42 }
43
44 mkdir -p $TEMPDIR
45
46 cd $TEMPDIR
47
48 activity="create program"
49 cat > $TEMPDIR/variables.stat <<EOF
50 SET MXERR 1000.
51 SET MXWARN 1000.
52
53 DATA LIST /N1 TO N5 1-5.
54 MISSING VALUES N1 TO N5 (3 THRU 5, 1).
55 BEGIN DATA.
56 12345
57 6789 
58 END DATA.
59
60 COMPUTE P1=N1.
61 COMPUTE P2=N2.
62 COMPUTE P3=N3.
63 COMPUTE P4=N4.
64 COMPUTE P5=N5.
65
66 COMPUTE MC=NMISS(N1 TO N5).
67 COMPUTE VC=NVALID(N1 TO N5).
68
69 COMPUTE S1=SYSMIS(N1).
70 COMPUTE S2=SYSMIS(N2).
71 COMPUTE S3=SYSMIS(N3).
72 COMPUTE S4=SYSMIS(N4).
73 COMPUTE S5=SYSMIS(N5).
74
75 COMPUTE M1=MISSING(N1).
76 COMPUTE M2=MISSING(N2).
77 COMPUTE M3=MISSING(N3).
78 COMPUTE M4=MISSING(N4).
79 COMPUTE M5=MISSING(N5).
80
81 COMPUTE V1=VALUE(N1).
82 COMPUTE V2=VALUE(N2).
83 COMPUTE V3=VALUE(N3).
84 COMPUTE V4=VALUE(N4).
85 COMPUTE V5=VALUE(N5).
86
87 FORMATS ALL (F1).
88
89 LIST.
90 EOF
91 if [ $? -ne 0 ] ; then no_result ; fi
92
93 activity="run program"
94 $SUPERVISOR $here/../src/pspp -o raw-ascii $TEMPDIR/variables.stat > $TEMPDIR/variables.err 2> $TEMPDIR/variables.out
95 if [ $? -ne 0 ] ; then fail ; fi
96
97 activity="compare results"
98 diff -b -B $TEMPDIR/pspp.list - <<EOF
99 1.1 DATA LIST.  Reading 1 record from the command file.
100 +--------+------+-------+------+
101 |Variable|Record|Columns|Format|
102 #========#======#=======#======#
103 |N1      |     1|  1-  1|F1.0  |
104 |N2      |     1|  2-  2|F1.0  |
105 |N3      |     1|  3-  3|F1.0  |
106 |N4      |     1|  4-  4|F1.0  |
107 |N5      |     1|  5-  5|F1.0  |
108 +--------+------+-------+------+
109
110 N1 N2 N3 N4 N5 P1 P2 P3 P4 P5 MC VC S1 S2 S3 S4 S5 M1 M2 M3 M4 M5 V1 V2 V3 V4 V5
111 -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
112  1  2  3  4  5  .  2  .  .  .  4  1  0  0  0  0  0  1  0  1  1  1  1  2  3  4  5 
113  6  7  8  9  .  6  7  8  9  .  1  4  0  0  0  0  1  0  0  0  0  1  6  7  8  9  . 
114 EOF
115
116 if [ $? -ne 0 ] ; then no_result ; fi
117
118
119 if [ $? -ne 0 ] ; then fail ; fi
120
121
122
123 pass;