[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[autotest 2/5] ADD FILES: Convert testsuite to use Autotest.
From: |
Ben Pfaff |
Subject: |
[autotest 2/5] ADD FILES: Convert testsuite to use Autotest. |
Date: |
Sun, 8 Aug 2010 22:40:27 -0700 |
---
tests/automake.mk | 2 +-
tests/command/add-files.sh | 200 -----------------------------------
tests/language/data-io/add-files.at | 110 +++++++++++++++++++
3 files changed, 111 insertions(+), 201 deletions(-)
delete mode 100755 tests/command/add-files.sh
create mode 100644 tests/language/data-io/add-files.at
diff --git a/tests/automake.mk b/tests/automake.mk
index 7da5514..fd50986 100644
--- a/tests/automake.mk
+++ b/tests/automake.mk
@@ -10,7 +10,6 @@ TESTS_ENVIRONMENT += LC_ALL=C
TESTS_ENVIRONMENT += EXEEXT=$(EXEEXT)
dist_TESTS = \
- tests/command/add-files.sh \
tests/command/beg-data.sh \
tests/command/bignum.sh \
tests/command/count.sh \
@@ -417,6 +416,7 @@ EXTRA_DIST += \
TESTSUITE_AT = \
tests/data/calendar.at \
+ tests/language/data-io/add-files.at \
tests/language/data-io/data-list.at \
tests/language/data-io/save.at \
tests/language/data-io/save-translate.at \
diff --git a/tests/command/add-files.sh b/tests/command/add-files.sh
deleted file mode 100755
index 4cba8ce..0000000
--- a/tests/command/add-files.sh
+++ /dev/null
@@ -1,200 +0,0 @@
-#!/bin/sh
-
-# This program tests the ADD FILES procedure
-
-TEMPDIR=/tmp/pspp-tst-$$
-TESTFILE=$TEMPDIR/add-files.pspp
-
-
-# ensure that top_builddir are absolute
-if [ -z "$top_builddir" ] ; then top_builddir=. ; fi
-if [ -z "$top_srcdir" ] ; then top_srcdir=. ; fi
-top_builddir=`cd $top_builddir; pwd`
-PSPP=$top_builddir/src/ui/terminal/pspp$EXEEXT
-
-# ensure that top_srcdir is absolute
-top_srcdir=`cd $top_srcdir; pwd`
-
-
-STAT_CONFIG_PATH=$top_srcdir/config
-export STAT_CONFIG_PATH
-
-cleanup()
-{
- if [ x"$PSPP_TEST_NO_CLEANUP" != x ] ; then
- echo "NOT cleaning $TEMPDIR"
- return ;
- fi
- cd /
- rm -rf $TEMPDIR
-}
-
-
-fail()
-{
- echo $activity
- echo FAILED
- cleanup;
- exit 1;
-}
-
-
-no_result()
-{
- echo $activity
- echo NO RESULT;
- cleanup;
- exit 2;
-}
-
-pass()
-{
- cleanup;
- exit 0;
-}
-
-mkdir -p $TEMPDIR
-
-cd $TEMPDIR
-
-activity="data create"
-cat > a.data <<EOF
-1aB
-8aM
-3aE
-5aG
-0aA
-5aH
-6aI
-7aJ
-2aD
-7aK
-1aC
-7aL
-4aF
-EOF
-if [ $? -ne 0 ] ; then no_result ; fi
-cat > b.data <<EOF
-1bN
-3bO
-4bP
-6bQ
-7bR
-9bS
-EOF
-if [ $? -ne 0 ] ; then no_result ; fi
-
-cat > concatenate.csv <<EOF
-Table: Data List
-A,B,C,D,INA,INB
-1,a,B,,1,0
-8,a,M,,1,0
-3,a,E,,1,0
-5,a,G,,1,0
-0,a,A,,1,0
-5,a,H,,1,0
-6,a,I,,1,0
-7,a,J,,1,0
-2,a,D,,1,0
-7,a,K,,1,0
-1,a,C,,1,0
-7,a,L,,1,0
-4,a,F,,1,0
-1,b,,N,0,1
-3,b,,O,0,1
-4,b,,P,0,1
-6,b,,Q,0,1
-7,b,,R,0,1
-9,b,,S,0,1
-EOF
-
-cat > interleave.csv <<EOF
-Table: Data List
-A,B,C,D,INA,INB,FIRST,LAST
-0,a,A,,1,0,1,1
-1,a,B,,1,0,1,0
-1,a,C,,1,0,0,0
-1,b,,N,0,1,0,1
-2,a,D,,1,0,1,1
-3,a,E,,1,0,1,0
-3,b,,O,0,1,0,1
-4,a,F,,1,0,1,0
-4,b,,P,0,1,0,1
-5,a,G,,1,0,1,0
-5,a,H,,1,0,0,1
-6,a,I,,1,0,1,0
-6,b,,Q,0,1,0,1
-7,a,J,,1,0,1,0
-7,a,K,,1,0,0,0
-7,a,L,,1,0,0,0
-7,b,,R,0,1,0,1
-8,a,M,,1,0,1,1
-9,b,,S,0,1,1,1
-EOF
-
-# Test ADD FILES.
-dla="data list notable file='a.data' /A B C 1-3 (a)."
-sa="save outfile='a.sys'."
-dlb="data list notable file='b.data' /A B C 1-3 (a)."
-sb="save outfile='b.sys'."
-for type in interleave concatenate; do
- if test $type = interleave; then
- by="/by a /first=FIRST /last=LAST"
- sort="/sort"
- else
- by=
- sort=
- fi
- for sources in ss sa as; do
- name="$type-$sources"
- activity="create $name.pspp"
- {
- if [ $sources = ss ]; then
- cat <<EOF
-$dla
-$sa
-$dlb
-$sb
-add files file='a.sys' /in=INA $sort
- /file='b.sys' /in=INB /rename c=D
- $by.
-EOF
- elif [ $sources = sa ]; then
- cat <<EOF
-$dla
-$sa
-$dlb
-add files file='a.sys' /in=INA $sort
- /file=* /in=INB /rename c=D
- $by.
-EOF
- elif [ $sources = as ]; then
- cat <<EOF
-$dlb
-$sb
-$dla
-add files file=* /in=INA $sort
- /file='b.sys' /in=INB /rename c=D
- $by.
-EOF
- else
- activity="internal error"
- no_result
- fi
- echo 'list.'
- } > $name.pspp
- if [ $? -ne 0 ] ; then no_result ; fi
-
- activity="run $name.pspp"
- $SUPERVISOR $PSPP -o pspp.csv $name.pspp
- if [ $? -ne 0 ] ; then no_result ; fi
-
- activity="check $name output"
- perl -pi -e 's/^\s*$//g' pspp.csv
- perl -pi -e 's/^\s*$//g' $type.csv
- diff -u -b -w pspp.csv $type.csv
- if [ $? -ne 0 ] ; then fail ; fi
- done
-done
-
-pass;
diff --git a/tests/language/data-io/add-files.at
b/tests/language/data-io/add-files.at
new file mode 100644
index 0000000..d665081
--- /dev/null
+++ b/tests/language/data-io/add-files.at
@@ -0,0 +1,110 @@
+m4_define([CHECK_ADD_FILES],
+ [AT_SETUP([ADD FILES -- $1 $2 with $3])
+ AT_DATA([a.data], [dnl
+1aB
+8aM
+3aE
+5aG
+0aA
+5aH
+6aI
+7aJ
+2aD
+7aK
+1aC
+7aL
+4aF
+])
+ AT_DATA([b.data], [dnl
+1bN
+3bO
+4bP
+6bQ
+7bR
+9bS
+])
+ m4_if([$2], [sav],
+ [AT_DATA([save-a.sps], [dnl
+DATA LIST NOTABLE FILE='a.data' /a b c 1-3 (A).
+SAVE OUTFILE='a.sav'.
+])
+ AT_CHECK([pspp -O format=csv save-a.sps])])
+ m4_if([$3], [sav],
+ [AT_DATA([save-b.sps], [dnl
+DATA LIST NOTABLE FILE='b.data' /a b c 1-3 (A).
+SAVE OUTFILE='b.sav'.
+])
+ AT_CHECK([pspp -O format=csv save-b.sps])])
+ m4_if([$1], [interleave],
+ [m4_pushdef([BY], [[/BY a /FIRST=first /LAST=last]])
+ m4_pushdef([SORT], [[/SORT]])],
+ [m4_pushdef([BY], [])
+ m4_pushdef([SORT], [])])
+ AT_DATA([add-files.sps], [dnl
+m4_if([$2], [sav], [], [DATA LIST NOTABLE FILE='a.data' /a b c 1-3 (A).])
+m4_if([$3], [sav], [], [DATA LIST NOTABLE FILE='b.data' /a b c 1-3 (A).])
+ADD FILES
+ m4_if([$2], [sav], [FILE='a.sav'], [FILE=*]) /IN=InA SORT
+ m4_if([$3], [sav], [FILE='b.sav'], [FILE=*]) /IN=InB /RENAME c=d
+ BY[].
+LIST.
+])
+ m4_popdef([BY])
+ m4_popdef([SORT])
+ AT_CHECK([pspp -O format=csv add-files.sps], [0],
+[m4_if([$1], [interleave], [dnl
+Table: Data List
+a,b,c,d,InA,InB,first,last
+0,a,A,,1,0,1,1
+1,a,B,,1,0,1,0
+1,a,C,,1,0,0,0
+1,b,,N,0,1,0,1
+2,a,D,,1,0,1,1
+3,a,E,,1,0,1,0
+3,b,,O,0,1,0,1
+4,a,F,,1,0,1,0
+4,b,,P,0,1,0,1
+5,a,G,,1,0,1,0
+5,a,H,,1,0,0,1
+6,a,I,,1,0,1,0
+6,b,,Q,0,1,0,1
+7,a,J,,1,0,1,0
+7,a,K,,1,0,0,0
+7,a,L,,1,0,0,0
+7,b,,R,0,1,0,1
+8,a,M,,1,0,1,1
+9,b,,S,0,1,1,1
+], [dnl
+Table: Data List
+a,b,c,d,InA,InB
+1,a,B,,1,0
+8,a,M,,1,0
+3,a,E,,1,0
+5,a,G,,1,0
+0,a,A,,1,0
+5,a,H,,1,0
+6,a,I,,1,0
+7,a,J,,1,0
+2,a,D,,1,0
+7,a,K,,1,0
+1,a,C,,1,0
+7,a,L,,1,0
+4,a,F,,1,0
+1,b,,N,0,1
+3,b,,O,0,1
+4,b,,P,0,1
+6,b,,Q,0,1
+7,b,,R,0,1
+9,b,,S,0,1
+])])
+AT_CLEANUP
+])
+
+AT_BANNER([ADD FILES])
+
+CHECK_ADD_FILES([interleave], [sav], [sav])
+CHECK_ADD_FILES([interleave], [sav], [inline])
+CHECK_ADD_FILES([interleave], [inline], [sav])
+CHECK_ADD_FILES([concatenate], [sav], [sav])
+CHECK_ADD_FILES([concatenate], [sav], [inline])
+CHECK_ADD_FILES([concatenate], [inline], [sav])
--
1.7.1
- more autotest conversions, Ben Pfaff, 2010/08/09
- [autotest 1/5] tests: Rewrite attributes tests to use Autotest., Ben Pfaff, 2010/08/09
- [autotest 5/5] tests: Ignore testsuite.at since it is now a generated file., Ben Pfaff, 2010/08/09
- [autotest 2/5] ADD FILES: Convert testsuite to use Autotest.,
Ben Pfaff <=
- [autotest 3/5] BEGIN DATA: Convert tests to use Autotest., Ben Pfaff, 2010/08/09
- [autotest 4/5] COUNT: Convert tests to use Autotest., Ben Pfaff, 2010/08/09
- Re: more autotest conversions, Ben Pfaff, 2010/08/10