Make the expression code a little nicer and fix bugs found
[pspp-builds.git] / tests / command / print.sh
1 #!/bin/sh
2
3 # This program tests the PRINT transformation
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 # Copy this file --- it's shared with another test
49 activity="create data"
50 cp $top_srcdir/tests/data-list.data $TEMPDIR
51 if [ $? -ne 0 ] ; then no_result ; fi
52
53
54 activity="create program"
55 cat > $TEMPDIR/print.stat << foobar
56 title 'Test PRINT transformation'.
57
58 data list free table file='$TEMPDIR/data-list.data'/A B C D.
59 print outfile="foo" table/A(f8.2) '/' B(e8.2) '/' C(n10) '/' D(rbhex16) '/'.
60 print space a.
61 print outfile="foo" /a b c d.
62 list.
63
64 data list list table file='$TEMPDIR/data-list.data'/A B C D.
65 print table/A B C D.
66 list.
67
68 foobar
69 if [ $? -ne 0 ] ; then no_result ; fi
70
71
72 activity="run program"
73 $SUPERVISOR $here/../src/pspp --testing-mode -o raw-ascii --testing-mode $TEMPDIR/print.stat > $TEMPDIR/errs
74 # Note   vv   --- there are errors in input.  Therefore, the  command must FAIL
75 if [ $? -eq 0 ] ; then fail ; fi
76
77 activity="compare error messages"
78 diff -w $TEMPDIR/errs - <<EOF
79 $TEMPDIR/data-list.data:1: error: (columns 1-5, field type F8.0) Field does not form a valid floating-point constant.
80 $TEMPDIR/data-list.data:1: warning: LIST: The expression on PRINT SPACE evaluated to -2147483648.  It's not possible to PRINT SPACE a negative number of lines.
81 $TEMPDIR/data-list.data:2: error: (columns 1-8, field type F8.0) Field does not form a valid floating-point constant.
82 $TEMPDIR/data-list.data:4: warning: LIST: The expression on PRINT SPACE evaluated to -2147483648.  It's not possible to PRINT SPACE a negative number of lines.
83 $TEMPDIR/data-list.data:4: error: (columns 3-12, field type F8.0) Field does not form a valid floating-point constant.
84 $TEMPDIR/data-list.data:6: warning: LIST: The expression on PRINT SPACE evaluated to -2147483648.  It's not possible to PRINT SPACE a negative number of lines.
85 $TEMPDIR/data-list.data:1: error: (columns 1-5, field type F8.0) Field does not form a valid floating-point constant.
86 $TEMPDIR/data-list.data:2: error: (columns 1-8, field type F8.0) Field does not form a valid floating-point constant.
87 $TEMPDIR/data-list.data:2: warning: LIST: Missing value(s) for all variables from C onward.  These will be filled with the system-missing value or blanks, as appropriate.
88 $TEMPDIR/data-list.data:3: warning: LIST: Missing value(s) for all variables from B onward.  These will be filled with the system-missing value or blanks, as appropriate.
89 $TEMPDIR/data-list.data:4: error: (columns 3-12, field type F8.0) Field does not form a valid floating-point constant.
90 $TEMPDIR/data-list.data:4: warning: LIST: Missing value(s) for all variables from C onward.  These will be filled with the system-missing value or blanks, as appropriate.
91 $TEMPDIR/data-list.data:5: warning: LIST: Missing value(s) for all variables from C onward.  These will be filled with the system-missing value or blanks, as appropriate.
92 $TEMPDIR/data-list.data:6: warning: LIST: Missing value(s) for all variables from B onward.  These will be filled with the system-missing value or blanks, as appropriate.
93 EOF
94 if [ $? -ne 0 ] ; then fail ; fi
95
96
97 activity="compare output"
98 diff -b -B $TEMPDIR/pspp.list - << EOF
99 1.1 DATA LIST.  Reading free-form data from file $TEMPDIR/data-list.data.
100 +--------+------+
101 |Variable|Format|
102 #========#======#
103 |A       |F8.0  |
104 |B       |F8.0  |
105 |C       |F8.0  |
106 |D       |F8.0  |
107 +--------+------+
108
109 2.1 PRINT.  Writing 1 record(s) to file foo.
110 +--------+------+-------+-------+
111 |Variable|Record|Columns| Format|
112 #========#======#=======#=======#
113 |A       |     1|  1-  8|F8.2   |
114 |"/"     |     1|  9-  9|A1     |
115 |B       |     1| 10- 17|E8.2   |
116 |"/"     |     1| 18- 18|A1     |
117 |C       |     1| 19- 28|N10.0  |
118 |"/"     |     1| 29- 29|A1     |
119 |D       |     1| 30- 45|RBHEX16|
120 |"/"     |     1| 46- 46|A1     |
121 +--------+------+-------+-------+
122
123
124        A        B        C        D
125 -------- -------- -------- --------
126      .       2.00     3.00     4.00 
127
128      .       6.00     7.00     8.00 
129
130      .      10.00    11.00    12.00 
131
132 3.1 DATA LIST.  Reading free-form data from file $TEMPDIR/data-list.data.
133 +--------+------+
134 |Variable|Format|
135 #========#======#
136 |A       |F8.0  |
137 |B       |F8.0  |
138 |C       |F8.0  |
139 |D       |F8.0  |
140 +--------+------+
141
142 4.1 PRINT.  Writing 1 record(s) to the listing file.
143 +--------+------+-------+------+
144 |Variable|Record|Columns|Format|
145 #========#======#=======#======#
146 |A       |     1|  1-  8|F8.2  |
147 |B       |     1| 10- 17|F8.2  |
148 |C       |     1| 19- 26|F8.2  |
149 |D       |     1| 28- 35|F8.2  |
150 +--------+------+-------+------+
151      .       2.00     3.00     4.00 
152
153        A        B        C        D
154 -------- -------- -------- --------
155      .       2.00     3.00     4.00 
156      .       6.00      .        .   
157      .       6.00      .        .   
158     7.00      .        .        .   
159     7.00      .        .        .   
160     8.00      .        .        .   
161     8.00      .        .        .   
162    10.00    11.00      .        .   
163    10.00    11.00      .        .   
164    12.00      .        .        .   
165    12.00      .        .        .   
166
167 EOF
168 if [ $? -ne 0 ] ; then fail ; fi
169
170
171 activity="compare print out"
172 diff $TEMPDIR/foo - << EOF
173      .  /2.00E+00/0000000003/0000000000001040/
174      .       2.00     3.00     4.00 
175      .  /6.00E+00/0000000007/0000000000002040/
176      .       6.00     7.00     8.00 
177      .  /1.00E+01/0000000011/0000000000002840/
178      .      10.00    11.00    12.00 
179 EOF
180 if [ $? -ne 0 ] ; then fail ; fi
181
182 pass;