diff options
author | Holger Hans Peter Freyther <zecke@selfish.org> | 2011-11-20 10:47:14 +0100 |
---|---|---|
committer | Holger Hans Peter Freyther <zecke@selfish.org> | 2011-11-20 10:47:14 +0100 |
commit | 475291355dc2c48dbde85559616dda415042ee13 (patch) | |
tree | d1d36a46f04a3e391cdb87f8a9f6ffca20191b57 | |
parent | fd8513d8c398b08d0f4812b6df5a8fac7e629969 (diff) |
tests: Add GNU Autotest invocation for the tests we have here
Add some std output of the applications, integrate tests.
-rw-r--r-- | configure.ac | 1 | ||||
-rw-r--r-- | tests/Makefile.am | 39 | ||||
-rw-r--r-- | tests/isup/Makefile.am | 2 | ||||
-rw-r--r-- | tests/isup/isup_parse_test.c | 4 | ||||
-rw-r--r-- | tests/isup/isup_parse_test.ok | 3 | ||||
-rw-r--r-- | tests/mgcp/Makefile.am | 2 | ||||
-rw-r--r-- | tests/mgcp/mgcp_patch_test.c | 9 | ||||
-rw-r--r-- | tests/mgcp/mgcp_patch_test.ok | 42 | ||||
-rwxr-xr-x | tests/missing | 376 | ||||
-rw-r--r-- | tests/mtp/Makefile.am | 2 | ||||
-rw-r--r-- | tests/mtp/mtp_parse_test.c | 1 | ||||
-rw-r--r-- | tests/mtp/mtp_parse_test.ok | 1 | ||||
-rw-r--r-- | tests/patching/Makefile.am | 2 | ||||
-rw-r--r-- | tests/patching/patching_test.c | 2 | ||||
-rw-r--r-- | tests/patching/patching_test.ok | 4 | ||||
-rw-r--r-- | tests/testsuite.at | 26 |
16 files changed, 511 insertions, 5 deletions
diff --git a/configure.ac b/configure.ac index 5bc39b3..b37d8d8 100644 --- a/configure.ac +++ b/configure.ac @@ -4,6 +4,7 @@ AC_INIT([cellmgr_ng], [openbsc-devel@lists.openbsc.org]) AM_INIT_AUTOMAKE([dist-bzip2]) +AC_CONFIG_TESTDIR(tests) dnl kernel style compile messages m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])]) diff --git a/tests/Makefile.am b/tests/Makefile.am index d7cebd8..17b9cdb 100644 --- a/tests/Makefile.am +++ b/tests/Makefile.am @@ -1 +1,40 @@ SUBDIRS = mtp patching isup mgcp + +# The `:;' works around a Bash 3.2 bug when the output is not writeable. +$(srcdir)/package.m4: $(top_srcdir)/configure.ac + :;{ \ + echo '# Signature of the current package.' && \ + echo 'm4_define([AT_PACKAGE_NAME],' && \ + echo ' [$(PACKAGE_NAME)])' && \ + echo 'm4_define([AT_PACKAGE_TARNAME],' && \ + echo ' [$(PACKAGE_TARNAME)])' && \ + echo 'm4_define([AT_PACKAGE_VERSION],' && \ + echo ' [$(PACKAGE_VERSION)])' && \ + echo 'm4_define([AT_PACKAGE_STRING],' && \ + echo ' [$(PACKAGE_STRING)])' && \ + echo 'm4_define([AT_PACKAGE_BUGREPORT],' && \ + echo ' [$(PACKAGE_BUGREPORT)])'; \ + echo 'm4_define([AT_PACKAGE_URL],' && \ + echo ' [$(PACKAGE_URL)])'; \ + } >'$(srcdir)/package.m4' + +EXTRA_DIST = testsuite.at $(srcdir)/package.m4 $(TESTSUITE) missing +TESTSUITE = $(srcdir)/testsuite + +check-local: atconfig $(TESTSUITE) + $(SHELL) '$(TESTSUITE)' $(TESTSUITEFLAGS) + +installcheck-local: atconfig $(TESTSUITE) + $(SHELL) '$(TESTSUITE)' AUTOTEST_PATH='$(bindir)' \ + $(TESTSUITEFLAGS) + +clean-local: + test ! -f '$(TESTSUITE)' || \ + $(SHELL) '$(TESTSUITE)' --clean + $(RM) -f atconfig + +AUTOM4TE = $(SHELL) $(srcdir)/missing --run autom4te +AUTOTEST = $(AUTOM4TE) --language=autotest +$(TESTSUITE): $(srcdir)/testsuite.at $(srcdir)/package.m4 + $(AUTOTEST) -I '$(srcdir)' -o $@.tmp $@.at + mv $@.tmp $@ diff --git a/tests/isup/Makefile.am b/tests/isup/Makefile.am index d8ba492..2c00f1f 100644 --- a/tests/isup/Makefile.am +++ b/tests/isup/Makefile.am @@ -2,5 +2,7 @@ INCLUDES = $(all_includes) -I$(top_srcdir)/include AM_CFLAGS=-Wall $(LIBOSMOCORE_CFLAGS) noinst_PROGRAMS = isup_parse_test +EXTRA_DIST = isup_parse_test.ok + isup_parse_test_SOURCES = isup_parse_test.c $(top_srcdir)/src/isup.c isup_parse_test_LDADD = $(LIBOSMOCORE_LIBS) diff --git a/tests/isup/isup_parse_test.c b/tests/isup/isup_parse_test.c index c6dbdf4..6bb582a 100644 --- a/tests/isup/isup_parse_test.c +++ b/tests/isup/isup_parse_test.c @@ -35,6 +35,8 @@ static void test_cic_parsing() static const uint8_t isup_grs[] = {3, 0, 23, 1, 1, 28}; struct isup_msg_hdr *hdr; + printf("Testing CIC parsing.\n"); + hdr = (struct isup_msg_hdr *) isup_grs; ASSERT(hdr->cic, 3); ASSERT(hdr->msg_type, ISUP_MSG_GRS); @@ -46,6 +48,8 @@ static void test_grs_parsing() struct isup_msg_hdr *hdr; int range; + printf("Testing GRS parsing.\n"); + hdr = (struct isup_msg_hdr *) isup_grs; range = isup_parse_status(&hdr->data[0], 3); diff --git a/tests/isup/isup_parse_test.ok b/tests/isup/isup_parse_test.ok new file mode 100644 index 0000000..ed00fc4 --- /dev/null +++ b/tests/isup/isup_parse_test.ok @@ -0,0 +1,3 @@ +Testing CIC parsing. +Testing GRS parsing. +All tests passed. diff --git a/tests/mgcp/Makefile.am b/tests/mgcp/Makefile.am index 2e8db48..008979b 100644 --- a/tests/mgcp/Makefile.am +++ b/tests/mgcp/Makefile.am @@ -2,5 +2,7 @@ INCLUDES = $(all_includes) -I$(top_srcdir)/include AM_CFLAGS=-Wall $(LIBOSMOCORE_CFLAGS) noinst_PROGRAMS = mgcp_patch_test +EXTRA_DIST = mgcp_patch_test.ok + mgcp_patch_test_SOURCES = mgcp_patch_test.c $(top_srcdir)/src/mgcp_patch.c mgcp_patch_test_LDADD = $(LIBOSMOCORE_LIBS) diff --git a/tests/mgcp/mgcp_patch_test.c b/tests/mgcp/mgcp_patch_test.c index 335cfcf..683ea01 100644 --- a/tests/mgcp/mgcp_patch_test.c +++ b/tests/mgcp/mgcp_patch_test.c @@ -71,8 +71,10 @@ static const char mgcp_out[] = static void test_endp_name_rewriting() { struct ss7_application app; - memset(&app, 0, sizeof(app)); + printf("Test Endpoint Name rewriting.\n"); + + memset(&app, 0, sizeof(app)); app.mgcp_domain_name = "foo2"; /* prepare */ @@ -83,12 +85,10 @@ static void test_endp_name_rewriting() /* patch it now */ struct msgb *msg_out = mgcp_patch(&app, msg); msg_out->l2h[msgb_l2len(msg_out)] = '\0'; -#ifdef DEBUG printf("Want : '%s'\n", mgcp_out); printf("Outpu: '%s'\n", (const char *) msg_out->l2h); - printf("%s\n", osmo_hexdump(mgcp_out, strlen(mgcp_out))); + printf("%s\n", osmo_hexdump((const uint8_t *) mgcp_out, strlen(mgcp_out))); printf("%s\n", osmo_hexdump(msg_out->l2h, msgb_l2len(msg_out))); -#endif ASSERT(msg_out, !=, msg, "msg should not be the same"); ASSERT(msgb_l2len(msg_out), ==, strlen(mgcp_out), "Output size wrong"); @@ -99,5 +99,6 @@ int main(int argc, char **argv) { test_endp_name_rewriting(); + printf("All tests passed.\n"); return 0; } diff --git a/tests/mgcp/mgcp_patch_test.ok b/tests/mgcp/mgcp_patch_test.ok new file mode 100644 index 0000000..d59bd28 --- /dev/null +++ b/tests/mgcp/mgcp_patch_test.ok @@ -0,0 +1,42 @@ +Test Endpoint Name rewriting. +Want : 'MDCX 23213 14@foo2 MGCP 1.0
+C: 4a84ad5d25f
+I: %d
+L: p:20, a:GSM-EFR, nt:IN
+M: recvonly
+
+v=0
+o=- 258696477 0 IN IP4 172.16.1.107
+s=-
+c=IN IP4 172.16.1.107
+t=0 0
+m=audio 6666 RTP/AVP 127
+a=rtpmap:127 GSM-EFR/8000/1
+a=ptime:20
+a=recvonly
+m=image 4402 udptl t38
+a=T38FaxVersion:0
+a=T38MaxBitRate:14400
+' +Outpu: 'MDCX 23213 14@foo2 MGCP 1.0
+C: 4a84ad5d25f
+I: %d
+L: p:20, a:GSM-EFR, nt:IN
+M: recvonly
+
+v=0
+o=- 258696477 0 IN IP4 172.16.1.107
+s=-
+c=IN IP4 172.16.1.107
+t=0 0
+m=audio 6666 RTP/AVP 127
+a=rtpmap:127 GSM-EFR/8000/1
+a=ptime:20
+a=recvonly
+m=image 4402 udptl t38
+a=T38FaxVersion:0
+a=T38MaxBitRate:14400
+' +4d 44 43 58 20 32 33 32 31 33 20 31 34 40 66 6f 6f 32 20 4d 47 43 50 20 31 2e 30 0d 0a 43 3a 20 34 61 38 34 61 64 35 64 32 35 66 0d 0a 49 3a 20 25 64 0d 0a 4c 3a 20 70 3a 32 30 2c 20 61 3a 47 53 4d 2d 45 46 52 2c 20 6e 74 3a 49 4e 0d 0a 4d 3a 20 72 65 63 76 6f 6e 6c 79 0d 0a 0d 0a 76 3d 30 0d 0a 6f 3d 2d 20 32 35 38 36 39 36 34 37 37 20 30 20 49 4e 20 49 50 34 20 31 37 32 2e 31 36 2e 31 2e 31 30 37 0d 0a 73 3d 2d 0d 0a 63 3d 49 4e 20 49 50 34 20 31 37 32 2e 31 36 2e 31 2e 31 30 37 0d 0a 74 3d 30 20 30 0d 0a 6d 3d 61 75 64 69 6f 20 36 36 36 36 20 52 54 50 2f 41 56 50 20 31 32 37 0d 0a 61 3d 72 74 70 6d 61 70 3a 31 32 37 20 47 53 4d 2d 45 46 52 2f 38 30 30 30 2f 31 0d 0a 61 3d 70 74 69 6d 65 3a 32 30 0d 0a 61 3d 72 65 63 76 6f 6e 6c 79 0d 0a 6d 3d 69 6d 61 67 65 20 34 34 30 32 20 75 64 70 74 6c 20 74 33 38 0d 0a 61 3d 54 33 38 46 61 78 56 65 72 73 69 6f 6e 3a 30 0d 0a 61 3d 54 33 38 4d 61 78 42 69 74 52 61 74 65 3a 31 34 34 30 30 0d 0a +4d 44 43 58 20 32 33 32 31 33 20 31 34 40 66 6f 6f 32 20 4d 47 43 50 20 31 2e 30 0d 0a 43 3a 20 34 61 38 34 61 64 35 64 32 35 66 0d 0a 49 3a 20 25 64 0d 0a 4c 3a 20 70 3a 32 30 2c 20 61 3a 47 53 4d 2d 45 46 52 2c 20 6e 74 3a 49 4e 0d 0a 4d 3a 20 72 65 63 76 6f 6e 6c 79 0d 0a 0d 0a 76 3d 30 0d 0a 6f 3d 2d 20 32 35 38 36 39 36 34 37 37 20 30 20 49 4e 20 49 50 34 20 31 37 32 2e 31 36 2e 31 2e 31 30 37 0d 0a 73 3d 2d 0d 0a 63 3d 49 4e 20 49 50 34 20 31 37 32 2e 31 36 2e 31 2e 31 30 37 0d 0a 74 3d 30 20 30 0d 0a 6d 3d 61 75 64 69 6f 20 36 36 36 36 20 52 54 50 2f 41 56 50 20 31 32 37 0d 0a 61 3d 72 74 70 6d 61 70 3a 31 32 37 20 47 53 4d 2d 45 46 52 2f 38 30 30 30 2f 31 0d 0a 61 3d 70 74 69 6d 65 3a 32 30 0d 0a 61 3d 72 65 63 76 6f 6e 6c 79 0d 0a 6d 3d 69 6d 61 67 65 20 34 34 30 32 20 75 64 70 74 6c 20 74 33 38 0d 0a 61 3d 54 33 38 46 61 78 56 65 72 73 69 6f 6e 3a 30 0d 0a 61 3d 54 33 38 4d 61 78 42 69 74 52 61 74 65 3a 31 34 34 30 30 0d 0a +All tests passed. diff --git a/tests/missing b/tests/missing new file mode 100755 index 0000000..28055d2 --- /dev/null +++ b/tests/missing @@ -0,0 +1,376 @@ +#! /bin/sh +# Common stub for a few missing GNU programs while installing. + +scriptversion=2009-04-28.21; # UTC + +# Copyright (C) 1996, 1997, 1999, 2000, 2002, 2003, 2004, 2005, 2006, +# 2008, 2009 Free Software Foundation, Inc. +# Originally by Fran,cois Pinard <pinard@iro.umontreal.ca>, 1996. + +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2, or (at your option) +# any later version. + +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. + +# You should have received a copy of the GNU General Public License +# along with this program. If not, see <http://www.gnu.org/licenses/>. + +# As a special exception to the GNU General Public License, if you +# distribute this file as part of a program that contains a +# configuration script generated by Autoconf, you may include it under +# the same distribution terms that you use for the rest of that program. + +if test $# -eq 0; then + echo 1>&2 "Try \`$0 --help' for more information" + exit 1 +fi + +run=: +sed_output='s/.* --output[ =]\([^ ]*\).*/\1/p' +sed_minuso='s/.* -o \([^ ]*\).*/\1/p' + +# In the cases where this matters, `missing' is being run in the +# srcdir already. +if test -f configure.ac; then + configure_ac=configure.ac +else + configure_ac=configure.in +fi + +msg="missing on your system" + +case $1 in +--run) + # Try to run requested program, and just exit if it succeeds. + run= + shift + "$@" && exit 0 + # Exit code 63 means version mismatch. This often happens + # when the user try to use an ancient version of a tool on + # a file that requires a minimum version. In this case we + # we should proceed has if the program had been absent, or + # if --run hadn't been passed. + if test $? = 63; then + run=: + msg="probably too old" + fi + ;; + + -h|--h|--he|--hel|--help) + echo "\ +$0 [OPTION]... PROGRAM [ARGUMENT]... + +Handle \`PROGRAM [ARGUMENT]...' for when PROGRAM is missing, or return an +error status if there is no known handling for PROGRAM. + +Options: + -h, --help display this help and exit + -v, --version output version information and exit + --run try to run the given command, and emulate it if it fails + +Supported PROGRAM values: + aclocal touch file \`aclocal.m4' + autoconf touch file \`configure' + autoheader touch file \`config.h.in' + autom4te touch the output file, or create a stub one + automake touch all \`Makefile.in' files + bison create \`y.tab.[ch]', if possible, from existing .[ch] + flex create \`lex.yy.c', if possible, from existing .c + help2man touch the output file + lex create \`lex.yy.c', if possible, from existing .c + makeinfo touch the output file + tar try tar, gnutar, gtar, then tar without non-portable flags + yacc create \`y.tab.[ch]', if possible, from existing .[ch] + +Version suffixes to PROGRAM as well as the prefixes \`gnu-', \`gnu', and +\`g' are ignored when checking the name. + +Send bug reports to <bug-automake@gnu.org>." + exit $? + ;; + + -v|--v|--ve|--ver|--vers|--versi|--versio|--version) + echo "missing $scriptversion (GNU Automake)" + exit $? + ;; + + -*) + echo 1>&2 "$0: Unknown \`$1' option" + echo 1>&2 "Try \`$0 --help' for more information" + exit 1 + ;; + +esac + +# normalize program name to check for. +program=`echo "$1" | sed ' + s/^gnu-//; t + s/^gnu//; t + s/^g//; t'` + +# Now exit if we have it, but it failed. Also exit now if we +# don't have it and --version was passed (most likely to detect +# the program). This is about non-GNU programs, so use $1 not +# $program. +case $1 in + lex*|yacc*) + # Not GNU programs, they don't have --version. + ;; + + tar*) + if test -n "$run"; then + echo 1>&2 "ERROR: \`tar' requires --run" + exit 1 + elif test "x$2" = "x--version" || test "x$2" = "x--help"; then + exit 1 + fi + ;; + + *) + if test -z "$run" && ($1 --version) > /dev/null 2>&1; then + # We have it, but it failed. + exit 1 + elif test "x$2" = "x--version" || test "x$2" = "x--help"; then + # Could not run --version or --help. This is probably someone + # running `$TOOL --version' or `$TOOL --help' to check whether + # $TOOL exists and not knowing $TOOL uses missing. + exit 1 + fi + ;; +esac + +# If it does not exist, or fails to run (possibly an outdated version), +# try to emulate it. +case $program in + aclocal*) + echo 1>&2 "\ +WARNING: \`$1' is $msg. You should only need it if + you modified \`acinclude.m4' or \`${configure_ac}'. You might want + to install the \`Automake' and \`Perl' packages. Grab them from + any GNU archive site." + touch aclocal.m4 + ;; + + autoconf*) + echo 1>&2 "\ +WARNING: \`$1' is $msg. You should only need it if + you modified \`${configure_ac}'. You might want to install the + \`Autoconf' and \`GNU m4' packages. Grab them from any GNU + archive site." + touch configure + ;; + + autoheader*) + echo 1>&2 "\ +WARNING: \`$1' is $msg. You should only need it if + you modified \`acconfig.h' or \`${configure_ac}'. You might want + to install the \`Autoconf' and \`GNU m4' packages. Grab them + from any GNU archive site." + files=`sed -n 's/^[ ]*A[CM]_CONFIG_HEADER(\([^)]*\)).*/\1/p' ${configure_ac}` + test -z "$files" && files="config.h" + touch_files= + for f in $files; do + case $f in + *:*) touch_files="$touch_files "`echo "$f" | + sed -e 's/^[^:]*://' -e 's/:.*//'`;; + *) touch_files="$touch_files $f.in";; + esac + done + touch $touch_files + ;; + + automake*) + echo 1>&2 "\ +WARNING: \`$1' is $msg. You should only need it if + you modified \`Makefile.am', \`acinclude.m4' or \`${configure_ac}'. + You might want to install the \`Automake' and \`Perl' packages. + Grab them from any GNU archive site." + find . -type f -name Makefile.am -print | + sed 's/\.am$/.in/' | + while read f; do touch "$f"; done + ;; + + autom4te*) + echo 1>&2 "\ +WARNING: \`$1' is needed, but is $msg. + You might have modified some files without having the + proper tools for further handling them. + You can get \`$1' as part of \`Autoconf' from any GNU + archive site." + + file=`echo "$*" | sed -n "$sed_output"` + test -z "$file" && file=`echo "$*" | sed -n "$sed_minuso"` + if test -f "$file"; then + touch $file + else + test -z "$file" || exec >$file + echo "#! /bin/sh" + echo "# Created by GNU Automake missing as a replacement of" + echo "# $ $@" + echo "exit 0" + chmod +x $file + exit 1 + fi + ;; + + bison*|yacc*) + echo 1>&2 "\ +WARNING: \`$1' $msg. You should only need it if + you modified a \`.y' file. You may need the \`Bison' package + in order for those modifications to take effect. You can get + \`Bison' from any GNU archive site." + rm -f y.tab.c y.tab.h + if test $# -ne 1; then + eval LASTARG="\${$#}" + case $LASTARG in + *.y) + SRCFILE=`echo "$LASTARG" | sed 's/y$/c/'` + if test -f "$SRCFILE"; then + cp "$SRCFILE" y.tab.c + fi + SRCFILE=`echo "$LASTARG" | sed 's/y$/h/'` + if test -f "$SRCFILE"; then + cp "$SRCFILE" y.tab.h + fi + ;; + esac + fi + if test ! -f y.tab.h; then + echo >y.tab.h + fi + if test ! -f y.tab.c; then + echo 'main() { return 0; }' >y.tab.c + fi + ;; + + lex*|flex*) + echo 1>&2 "\ +WARNING: \`$1' is $msg. You should only need it if + you modified a \`.l' file. You may need the \`Flex' package + in order for those modifications to take effect. You can get + \`Flex' from any GNU archive site." + rm -f lex.yy.c + if test $# -ne 1; then + eval LASTARG="\${$#}" + case $LASTARG in + *.l) + SRCFILE=`echo "$LASTARG" | sed 's/l$/c/'` + if test -f "$SRCFILE"; then + cp "$SRCFILE" lex.yy.c + fi + ;; + esac + fi + if test ! -f lex.yy.c; then + echo 'main() { return 0; }' >lex.yy.c + fi + ;; + + help2man*) + echo 1>&2 "\ +WARNING: \`$1' is $msg. You should only need it if + you modified a dependency of a manual page. You may need the + \`Help2man' package in order for those modifications to take + effect. You can get \`Help2man' from any GNU archive site." + + file=`echo "$*" | sed -n "$sed_output"` + test -z "$file" && file=`echo "$*" | sed -n "$sed_minuso"` + if test -f "$file"; then + touch $file + else + test -z "$file" || exec >$file + echo ".ab help2man is required to generate this page" + exit $? + fi + ;; + + makeinfo*) + echo 1>&2 "\ +WARNING: \`$1' is $msg. You should only need it if + you modified a \`.texi' or \`.texinfo' file, or any other file + indirectly affecting the aspect of the manual. The spurious + call might also be the consequence of using a buggy \`make' (AIX, + DU, IRIX). You might want to install the \`Texinfo' package or + the \`GNU make' package. Grab either from any GNU archive site." + # The file to touch is that specified with -o ... + file=`echo "$*" | sed -n "$sed_output"` + test -z "$file" && file=`echo "$*" | sed -n "$sed_minuso"` + if test -z "$file"; then + # ... or it is the one specified with @setfilename ... + infile=`echo "$*" | sed 's/.* \([^ ]*\) *$/\1/'` + file=`sed -n ' + /^@setfilename/{ + s/.* \([^ ]*\) *$/\1/ + p + q + }' $infile` + # ... or it is derived from the source name (dir/f.texi becomes f.info) + test -z "$file" && file=`echo "$infile" | sed 's,.*/,,;s,.[^.]*$,,'`.info + fi + # If the file does not exist, the user really needs makeinfo; + # let's fail without touching anything. + test -f $file || exit 1 + touch $file + ;; + + tar*) + shift + + # We have already tried tar in the generic part. + # Look for gnutar/gtar before invocation to avoid ugly error + # messages. + if (gnutar --version > /dev/null 2>&1); then + gnutar "$@" && exit 0 + fi + if (gtar --version > /dev/null 2>&1); then + gtar "$@" && exit 0 + fi + firstarg="$1" + if shift; then + case $firstarg in + *o*) + firstarg=`echo "$firstarg" | sed s/o//` + tar "$firstarg" "$@" && exit 0 + ;; + esac + case $firstarg in + *h*) + firstarg=`echo "$firstarg" | sed s/h//` + tar "$firstarg" "$@" && exit 0 + ;; + esac + fi + + echo 1>&2 "\ +WARNING: I can't seem to be able to run \`tar' with the given arguments. + You may want to install GNU tar or Free paxutils, or check the + command line arguments." + exit 1 + ;; + + *) + echo 1>&2 "\ +WARNING: \`$1' is needed, and is $msg. + You might have modified some files without having the + proper tools for further handling them. Check the \`README' file, + it often tells you about the needed prerequisites for installing + this package. You may also peek at any GNU archive site, in case + some other package would contain this missing \`$1' program." + exit 1 + ;; +esac + +exit 0 + +# Local variables: +# eval: (add-hook 'write-file-hooks 'time-stamp) +# time-stamp-start: "scriptversion=" +# time-stamp-format: "%:y-%02m-%02d.%02H" +# time-stamp-time-zone: "UTC" +# time-stamp-end: "; # UTC" +# End: diff --git a/tests/mtp/Makefile.am b/tests/mtp/Makefile.am index 1f364b6..9e9292c 100644 --- a/tests/mtp/Makefile.am +++ b/tests/mtp/Makefile.am @@ -1,4 +1,6 @@ INCLUDES = $(all_includes) -I$(top_srcdir)/include -Wall noinst_PROGRAMS = mtp_parse_test +EXTRA_DIST = mtp_parse_test.ok + mtp_parse_test_SOURCES = mtp_parse_test.c diff --git a/tests/mtp/mtp_parse_test.c b/tests/mtp/mtp_parse_test.c index cd5d603..e21baed 100644 --- a/tests/mtp/mtp_parse_test.c +++ b/tests/mtp/mtp_parse_test.c @@ -636,5 +636,6 @@ int main(int argc, char **argv) } } + printf("All tests passed.\n"); return 0; } diff --git a/tests/mtp/mtp_parse_test.ok b/tests/mtp/mtp_parse_test.ok new file mode 100644 index 0000000..828a010 --- /dev/null +++ b/tests/mtp/mtp_parse_test.ok @@ -0,0 +1 @@ +All tests passed. diff --git a/tests/patching/Makefile.am b/tests/patching/Makefile.am index c24b768..0829e67 100644 --- a/tests/patching/Makefile.am +++ b/tests/patching/Makefile.am @@ -1,6 +1,8 @@ INCLUDES = $(all_includes) -I$(top_srcdir)/include $(LIBOSMOCORE_CFLAGS) $(LIBOSMOSCCP_CFLAGS) -Wall noinst_PROGRAMS = patching_test +EXTRA_DIST = patching_test.ok + patching_test_SOURCES = patching_test.c $(top_srcdir)/src/bss_patch.c patching_test_LDADD = $(LIBOSMOCORE_LIBS) $(LIBOSMOSCCP_LIBS) $(LIBOSMOGSM_LIBS) diff --git a/tests/patching/patching_test.c b/tests/patching/patching_test.c index 9917734..0456f0f 100644 --- a/tests/patching/patching_test.c +++ b/tests/patching/patching_test.c @@ -276,6 +276,6 @@ int main(int argc, char **argv) test_patch_filter(); test_rewrite_msc(); test_rewrite_bsc(); - printf("DONE!\n"); + printf("All tests passed.\n"); return 0; } diff --git a/tests/patching/patching_test.ok b/tests/patching/patching_test.ok new file mode 100644 index 0000000..0e681b2 --- /dev/null +++ b/tests/patching/patching_test.ok @@ -0,0 +1,4 @@ +Testing patching of GSM messages to the MSC. +Testing rewriting the SCCP header. +Testing rewriting the SCCP header for BSC. +All tests passed. diff --git a/tests/testsuite.at b/tests/testsuite.at new file mode 100644 index 0000000..069a502 --- /dev/null +++ b/tests/testsuite.at @@ -0,0 +1,26 @@ +AT_INIT +AT_BANNER([Regression tests.]) + +AT_SETUP([isup]) +AT_KEYWORDS([isup]) +cat $abs_srcdir/isup/isup_parse_test.ok > expout +AT_CHECK([$abs_top_builddir/tests/isup/isup_parse_test], [], [expout], [ignore]) +AT_CLEANUP + +AT_SETUP([mgcp]) +AT_KEYWORDS([mgcp]) +cat $abs_srcdir/mgcp/mgcp_patch_test.ok > expout +AT_CHECK([$abs_top_builddir/tests/mgcp/mgcp_patch_test], [], [expout], [ignore]) +AT_CLEANUP + +AT_SETUP([mtp]) +AT_KEYWORDS([mtp]) +cat $abs_srcdir/mtp/mtp_parse_test.ok > expout +AT_CHECK([$abs_top_builddir/tests/mtp/mtp_parse_test], [], [expout], [ignore]) +AT_CLEANUP + +AT_SETUP([patching]) +AT_KEYWORDS([patching]) +cat $abs_srcdir/patching/patching_test.ok > expout +AT_CHECK([$abs_top_builddir/tests/patching/patching_test], [], [expout], [ignore]) +AT_CLEANUP |