Update to most recent Gnulib
[pspp-builds.git] / tests / command / sample.sh
1 #!/bin/sh
2
3 # This program tests the SAMPLE function
4
5 TEMPDIR=/tmp/pspp-tst-$$
6 TESTFILE=$TEMPDIR/`basename $0`.sps
7
8 # ensure that top_builddir  are absolute
9 if [ -z "$top_builddir" ] ; then top_builddir=. ; fi
10 if [ -z "$top_srcdir" ] ; then top_srcdir=. ; fi
11 top_builddir=`cd $top_builddir; pwd`
12 PSPP=$top_builddir/src/ui/terminal/pspp
13
14 # ensure that top_srcdir is absolute
15 top_srcdir=`cd $top_srcdir; pwd`
16
17 STAT_CONFIG_PATH=$top_srcdir/config
18 export STAT_CONFIG_PATH
19
20
21 cleanup()
22 {
23      if [ x"$PSPP_TEST_NO_CLEANUP" != x ] ; then 
24         echo "NOT cleaning $TEMPDIR" 
25         return ; 
26      fi
27      cd /
28      rm -rf $TEMPDIR
29 }
30
31
32 fail()
33 {
34     echo $activity
35     echo FAILED
36     cleanup;
37     exit 1;
38 }
39
40
41 no_result()
42 {
43     echo $activity
44     echo NO RESULT;
45     cleanup;
46     exit 2;
47 }
48
49 pass()
50 {
51     cleanup;
52     exit 0;
53 }
54
55 mkdir -p $TEMPDIR
56
57 cd $TEMPDIR
58
59
60 activity="create program"
61 cat > $TEMPDIR/sample.stat <<EOF
62 set seed=3
63
64 data list notable /A 1-2.
65 begin data.
66 1
67 2
68 3
69 4
70 5
71 6
72 7
73 8
74 9
75 10
76 end data.
77 sample .5.
78 list.
79 EOF
80 if [ $? -ne 0 ] ; then no_result ; fi
81
82
83 activity="run program"
84 $SUPERVISOR $PSPP --testing-mode $TEMPDIR/sample.stat 
85 if [ $? -ne 0 ] ; then no_result ; fi
86
87 activity="create head"
88 grep -v '^\ *$' $TEMPDIR/pspp.list | head -2 > $TEMPDIR/head
89 if [ $? -ne 0 ] ; then no_result ; fi
90
91 activity="extract data"
92 grep  '[0-9][0-9]*' $TEMPDIR/pspp.list > $TEMPDIR/data
93 if [ $? -ne 0 ] ; then no_result ; fi
94
95
96 activity="compare head"
97 perl -pi -e 's/^\s*$//g' $TEMPDIR/head
98 diff -b $TEMPDIR/head - << EOF
99  A
100 --
101 EOF
102 if [ $? -ne 0 ] ; then fail ; fi
103
104 activity="compare data"
105 diff -w $TEMPDIR/data - << EOF > $TEMPDIR/diffs
106 1
107 2
108 3
109 4
110 5
111 6
112 7
113 8
114 9
115 10
116 EOF
117 # note   vv 
118 if [ $? -eq 0 ] ; then fail ; fi
119
120 # Check that there was nothing added
121 grep '^<' $TEMPDIR/diffs
122 # note   vv
123 if [ $? -eq 0 ] ; then fail ; fi
124
125
126 pass;