lexer: New functions for parsing real numbers in specified ranges.
[pspp] / tests / language / data-io / inpt-pgm.at
1 dnl PSPP - a program for statistical analysis.
2 dnl Copyright (C) 2017 Free Software Foundation, Inc.
3 dnl
4 dnl This program is free software: you can redistribute it and/or modify
5 dnl it under the terms of the GNU General Public License as published by
6 dnl the Free Software Foundation, either version 3 of the License, or
7 dnl (at your option) any later version.
8 dnl
9 dnl This program is distributed in the hope that it will be useful,
10 dnl but WITHOUT ANY WARRANTY; without even the implied warranty of
11 dnl MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12 dnl GNU General Public License for more details.
13 dnl
14 dnl You should have received a copy of the GNU General Public License
15 dnl along with this program.  If not, see <http://www.gnu.org/licenses/>.
16 dnl
17 AT_BANNER([INPUT PROGRAM])
18
19 dnl Tests for a bug which caused a crash when
20 dnl reading invalid INPUT PROGRAM syntax.
21 AT_SETUP([INPUT PROGRAM invalid syntax crash])
22 AT_DATA([input-program.sps], [dnl
23 INPUT PROGRAM.
24 DATA LIST NOTABLE /a 1-9.
25 BEGIN DATA
26 123456789
27 END DATA.
28 END INPUT PROGRAM.
29 ])
30 AT_CHECK([pspp -O format=csv input-program.sps], [1], [dnl
31 input-program.sps:3: error: BEGIN DATA: BEGIN DATA is not allowed inside INPUT PROGRAM.
32 ])
33 AT_CLEANUP
34
35 dnl Tests for bug #21108, a crash when
36 dnl reading invalid INPUT PROGRAM syntax.
37 AT_SETUP([INPUT PROGRAM invalid syntax crash])
38 AT_DATA([input-program.sps], [dnl
39 INPUT PROGRAM.
40 DATA LIST LIST NOTABLE /x.
41 END FILE.
42 END INPUT PROGRAM.
43
44 DESCRIPTIVES x.
45 ])
46 AT_CHECK([pspp -O format=csv input-program.sps], [1], [dnl
47 error: DESCRIPTIVES: Syntax error at end of input: expecting BEGIN.
48 ])
49 AT_CLEANUP
50
51 dnl Tests for bug #38782, an infinite loop processing an empty input program.
52 AT_SETUP([INPUT PROGRAM infinite loop])
53 AT_DATA([input-program.sps], [dnl
54 INPUT PROGRAM.
55 STRING firstname lastname (a24) / address (a80).
56 END INPUT PROGRAM.
57 EXECUTE.
58 ])
59 AT_CHECK([pspp -O format=csv input-program.sps], [1], [dnl
60 input-program.sps:3: error: INPUT PROGRAM: Input program must contain DATA LIST or END FILE.
61
62 input-program.sps:4: error: EXECUTE: EXECUTE is allowed only after the active dataset has been defined.
63 ])
64 AT_CLEANUP
65
66 dnl Tests for bug #39097, a bug when an INPUT PROGRAM used VECTOR, was
67 dnl followed immediately by a call to proc_execute() (here via DATASET
68 dnl COPY), and then the input was actually used.
69 AT_SETUP([INPUT PROGRAM with VECTOR and EXECUTE])
70 AT_DATA([input-program.sps], [dnl
71 INPUT PROGRAM.
72 VECTOR vec(5).
73 LOOP #c = 1 to 10.
74  LOOP #v = 1 to 5.
75   COMPUTE vec(#v) = #v.
76  END LOOP.
77  END CASE.
78 END LOOP.
79 END FILE.
80 END INPUT PROGRAM.
81 DATASET COPY x.
82 LIST.
83 ])
84 AT_CHECK([pspp -O format=csv input-program.sps], [0], [dnl
85 Table: Data List
86 vec1,vec2,vec3,vec4,vec5
87 1.00,2.00,3.00,4.00,5.00
88 1.00,2.00,3.00,4.00,5.00
89 1.00,2.00,3.00,4.00,5.00
90 1.00,2.00,3.00,4.00,5.00
91 1.00,2.00,3.00,4.00,5.00
92 1.00,2.00,3.00,4.00,5.00
93 1.00,2.00,3.00,4.00,5.00
94 1.00,2.00,3.00,4.00,5.00
95 1.00,2.00,3.00,4.00,5.00
96 1.00,2.00,3.00,4.00,5.00
97 ])
98 AT_CLEANUP
99
100 AT_SETUP([INPUT PROGRAM taking shorter of two files])
101 AT_DATA([input-program.sps], [dnl
102 INPUT PROGRAM.
103     DATA LIST NOTABLE FILE='a.txt'/X 1-10.
104     DATA LIST NOTABLE FILE='b.txt'/Y 1-10.
105 END INPUT PROGRAM.
106 LIST.
107 ])
108 AT_DATA([short.txt], [dnl
109 1
110 2
111 3
112 ])
113 AT_DATA([long.txt], [dnl
114 4
115 5
116 6
117 7
118 ])
119
120 cp short.txt a.txt
121 cp long.txt b.txt
122 AT_CHECK([pspp -O format=csv input-program.sps], 0, [dnl
123 Table: Data List
124 X,Y
125 1,4
126 2,5
127 3,6
128 ])
129
130 cp short.txt b.txt
131 cp long.txt a.txt
132 AT_CHECK([pspp -O format=csv input-program.sps], 0, [dnl
133 Table: Data List
134 X,Y
135 4,1
136 5,2
137 6,3
138 ])
139 AT_CLEANUP
140
141 AT_SETUP([INPUT PROGRAM taking longer of two files])
142 AT_DATA([input-program.sps], [dnl
143 INPUT PROGRAM.
144     NUMERIC #A #B.
145
146     DO IF NOT #A.
147         DATA LIST NOTABLE END=#A FILE='a.txt'/X 1-10.
148     END IF.
149     DO IF NOT #B.
150         DATA LIST NOTABLE END=#B FILE='b.txt'/Y 1-10.
151     END IF.
152     DO IF #A AND #B.
153         END FILE.
154     END IF.
155     END CASE.
156 END INPUT PROGRAM.
157 LIST.
158 ])
159 AT_DATA([short.txt], [dnl
160 1
161 2
162 3
163 ])
164 AT_DATA([long.txt], [dnl
165 4
166 5
167 6
168 7
169 8
170 ])
171
172 cp short.txt a.txt
173 cp long.txt b.txt
174 AT_CHECK([pspp -O format=csv input-program.sps], 0, [dnl
175 Table: Data List
176 X,Y
177 1,4
178 2,5
179 3,6
180 .,7
181 .,8
182 ])
183
184 cp short.txt b.txt
185 cp long.txt a.txt
186 AT_CHECK([pspp -O format=csv input-program.sps], 0, [dnl
187 Table: Data List
188 X,Y
189 4,1
190 5,2
191 6,3
192 7,.
193 8,.
194 ])
195 AT_CLEANUP
196
197 AT_SETUP([INPUT PROGRAM concatenating two files - version 1])
198 AT_DATA([input-program.sps], [dnl
199 INPUT PROGRAM.
200     NUMERIC #A #B.
201
202     DO IF #A.
203         DATA LIST NOTABLE END=#B FILE='b.txt'/X 1-10.
204         DO IF #B.
205             END FILE.
206         ELSE.
207             END CASE.
208         END IF.
209     ELSE.
210         DATA LIST NOTABLE END=#A FILE='a.txt'/X 1-10.
211         DO IF NOT #A.
212             END CASE.
213         END IF.
214     END IF.
215 END INPUT PROGRAM.
216 LIST.
217 ])
218 AT_DATA([a.txt], [dnl
219 1
220 2
221 3
222 ])
223 AT_DATA([b.txt], [dnl
224 4
225 5
226 6
227 7
228 8
229 ])
230
231 AT_CHECK([pspp -O format=csv input-program.sps], 0, [dnl
232 Table: Data List
233 X
234 1
235 2
236 3
237 4
238 5
239 6
240 7
241 8
242 ])
243 AT_CLEANUP
244
245 AT_SETUP([INPUT PROGRAM concatenating two files - version 2])
246 AT_DATA([input-program.sps], [dnl
247 INPUT PROGRAM.
248     NUMERIC #EOF.
249
250     LOOP IF NOT #EOF.
251         DATA LIST NOTABLE END=#EOF FILE='a.txt'/X 1-10.
252         DO IF NOT #EOF.
253             END CASE.
254         END IF.
255     END LOOP.
256
257     COMPUTE #EOF = 0.
258     LOOP IF NOT #EOF.
259         DATA LIST NOTABLE END=#EOF FILE='b.txt'/X 1-10.
260         DO IF NOT #EOF.
261             END CASE.
262         END IF.
263     END LOOP.
264
265     END FILE.
266 END INPUT PROGRAM.
267 LIST.
268 ])
269 AT_DATA([a.txt], [dnl
270 1
271 2
272 3
273 ])
274 AT_DATA([b.txt], [dnl
275 4
276 5
277 6
278 7
279 8
280 ])
281
282 AT_CHECK([pspp -O format=csv input-program.sps], 0, [dnl
283 Table: Data List
284 X
285 1
286 2
287 3
288 4
289 5
290 6
291 7
292 8
293 ])
294 AT_CLEANUP
295
296 AT_SETUP([INPUT PROGRAM generating data])
297 AT_DATA([input-program.sps], [dnl
298 INPUT PROGRAM.
299     LOOP #I=1 TO 10.
300         COMPUTE X=#I.
301         END CASE.
302     END LOOP.
303     END FILE.
304 END INPUT PROGRAM.
305 FORMAT X(F2).
306 LIST.
307 ])
308 AT_CHECK([pspp -O format=csv input-program.sps], 0, [dnl
309 Table: Data List
310 X
311 1
312 2
313 3
314 4
315 5
316 6
317 7
318 8
319 9
320 10
321 ])
322 AT_CLEANUP
323
324 AT_SETUP([INPUT PROGRAM unexpected end of file])
325 AT_DATA([input-program.sps], [dnl
326 INPUT PROGRAM.
327 ])
328 AT_CHECK([pspp input-program.sps], 1, [dnl
329 error: INPUT PROGRAM: Unexpected end-of-file within INPUT PROGRAM.
330 ])
331 AT_CLEANUP
332
333
334 AT_SETUP([INPUT PROGRAM no variables])
335 AT_DATA([input-program.sps], [dnl
336 INPUT PROGRAM.
337 END FILE.
338 END INPUT PROGRAM.
339 ])
340 AT_CHECK([pspp input-program.sps], 1, [dnl
341 input-program.sps:3: error: INPUT PROGRAM: Input program did not create any
342 variables.
343 ])
344 AT_CLEANUP