Fix use of "export" to work with traditional shells.
[pspp-builds.git] / tests / expressions / vectors.sh
1 #!/bin/sh
2
3 # This program tests use of vectors 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 STAT_CONFIG_PATH=$top_srcdir/config
13 export STAT_CONFIG_PATH
14
15
16 cleanup()
17 {
18      rm -rf $TEMPDIR
19 }
20
21
22 fail()
23 {
24     echo $activity
25     echo FAILED
26     cleanup;
27     exit 1;
28 }
29
30
31 no_result()
32 {
33     echo $activity
34     echo NO RESULT;
35     cleanup;
36     exit 2;
37 }
38
39 pass()
40 {
41     cleanup;
42     exit 0;
43 }
44
45 mkdir -p $TEMPDIR
46
47 cd $TEMPDIR
48
49 activity="create program"
50 cat > $TEMPDIR/vectors.stat <<EOF
51 DATA LIST /N1 TO N5 1-5.
52 MISSING VALUES N1 TO N5 (3 THRU 5, 1).
53 BEGIN DATA.
54 12345
55 6789 
56 END DATA.
57
58 VECTOR N=N1 TO N5.
59 VECTOR X(5).
60 LOOP I=1 TO 5.
61 COMPUTE X(I)=N(I) + 1.
62 END LOOP.
63
64 FORMATS ALL (F2).
65
66 LIST.
67 EOF
68 if [ $? -ne 0 ] ; then no_result ; fi
69
70 activity="run program"
71 $SUPERVISOR $here/../src/pspp -o raw-ascii $TEMPDIR/vectors.stat > $TEMPDIR/vectors.err 2> $TEMPDIR/vectors.out
72 if [ $? -ne 0 ] ; then fail ; fi
73
74 activity="compare results"
75 diff -b -B $TEMPDIR/pspp.list - <<EOF
76 1.1 DATA LIST.  Reading 1 record from the command file.
77 +--------+------+-------+------+
78 |Variable|Record|Columns|Format|
79 #========#======#=======#======#
80 |N1      |     1|  1-  1|F1.0  |
81 |N2      |     1|  2-  2|F1.0  |
82 |N3      |     1|  3-  3|F1.0  |
83 |N4      |     1|  4-  4|F1.0  |
84 |N5      |     1|  5-  5|F1.0  |
85 +--------+------+-------+------+
86
87 N1 N2 N3 N4 N5 X1 X2 X3 X4 X5  I
88 -- -- -- -- -- -- -- -- -- -- --
89  1  2  3  4  5  .  3  .  .  .  5 
90  6  7  8  9  .  7  8  9 10  .  5 
91 EOF
92
93 if [ $? -ne 0 ] ; then no_result ; fi
94
95
96 if [ $? -ne 0 ] ; then fail ; fi
97
98
99
100 pass;