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