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