mirror of https://github.com/getdnsapi/getdns.git
Merge branch 'develop' into features/conversion_functions
This commit is contained in:
commit
3752bf0a46
|
@ -55,3 +55,4 @@ m4/ltversion.m4
|
||||||
m4/lt~obsolete.m4
|
m4/lt~obsolete.m4
|
||||||
src/config.h.in
|
src/config.h.in
|
||||||
build/
|
build/
|
||||||
|
getdns.pc
|
||||||
|
|
22
.travis.yml
22
.travis.yml
|
@ -1,15 +1,21 @@
|
||||||
|
sudo: false
|
||||||
language: c
|
language: c
|
||||||
compiler:
|
compiler:
|
||||||
- gcc
|
- gcc
|
||||||
- clang
|
- clang
|
||||||
before_script:
|
addons:
|
||||||
- sudo apt-get update
|
apt:
|
||||||
- sudo apt-get install libunbound-dev libldns-dev libidn11-dev check libevent-dev
|
packages:
|
||||||
|
- libunbound-dev
|
||||||
|
- libldns-dev
|
||||||
|
- libidn11-dev
|
||||||
|
- check
|
||||||
|
- libevent-dev
|
||||||
|
- libev-dev
|
||||||
|
- bc
|
||||||
script:
|
script:
|
||||||
- libtoolize -fic
|
- libtoolize -fic
|
||||||
- autoreconf -fi
|
- autoreconf -fi
|
||||||
- ./configure --with-libevent
|
- mkdir tests
|
||||||
- make
|
- cd tests
|
||||||
- sudo PATH=$PATH make install
|
- ../src/test/tpkg/run-all.sh
|
||||||
- make test
|
|
||||||
- sudo make uninstall
|
|
||||||
|
|
|
@ -73,11 +73,11 @@ CHECK_OBJS=check_getdns_common.lo check_getdns_context_set_timeout.lo \
|
||||||
ALL_OBJS=$(CHECK_OBJS) check_getdns_libevent.lo check_getdns_libev.lo \
|
ALL_OBJS=$(CHECK_OBJS) check_getdns_libevent.lo check_getdns_libev.lo \
|
||||||
check_getdns_selectloop.lo getdns_query.lo scratchpad.lo \
|
check_getdns_selectloop.lo getdns_query.lo scratchpad.lo \
|
||||||
testmessages.lo tests_dict.lo tests_list.lo tests_namespaces.lo \
|
testmessages.lo tests_dict.lo tests_list.lo tests_namespaces.lo \
|
||||||
tests_stub_async.lo tests_stub_sync.lo tests_json-pointers.lo
|
tests_stub_async.lo tests_stub_sync.lo
|
||||||
|
|
||||||
NON_C99_OBJS=check_getdns_libuv.lo
|
NON_C99_OBJS=check_getdns_libuv.lo
|
||||||
|
|
||||||
PROGRAMS=tests_dict tests_list tests_namespaces tests_stub_async tests_stub_sync tests_json-pointers getdns_query $(CHECK_GETDNS) $(CHECK_EV_PROG) $(CHECK_EVENT_PROG) $(CHECK_UV_PROG)
|
PROGRAMS=tests_dict tests_list tests_namespaces tests_stub_async tests_stub_sync getdns_query $(CHECK_GETDNS) $(CHECK_EV_PROG) $(CHECK_EVENT_PROG) $(CHECK_UV_PROG)
|
||||||
|
|
||||||
|
|
||||||
.SUFFIXES: .c .o .a .lo .h
|
.SUFFIXES: .c .o .a .lo .h
|
||||||
|
@ -113,9 +113,6 @@ tests_stub_async: tests_stub_async.lo testmessages.lo
|
||||||
tests_stub_sync: tests_stub_sync.lo
|
tests_stub_sync: tests_stub_sync.lo
|
||||||
$(LIBTOOL) --tag=CC --mode=link $(CC) $(CFLAGS) $(LDFLAGS) $(LDLIBS) -o $@ tests_stub_sync.lo
|
$(LIBTOOL) --tag=CC --mode=link $(CC) $(CFLAGS) $(LDFLAGS) $(LDLIBS) -o $@ tests_stub_sync.lo
|
||||||
|
|
||||||
tests_json-pointers: tests_json-pointers.lo
|
|
||||||
$(LIBTOOL) --tag=CC --mode=link $(CC) $(CFLAGS) $(LDFLAGS) $(LDLIBS) -o $@ tests_json-pointers.lo
|
|
||||||
|
|
||||||
check_getdns_common: check_getdns_common.lo
|
check_getdns_common: check_getdns_common.lo
|
||||||
$(LIBTOOL) --tag=CC --mode=link $(CC) $(CFLAGS) $(LDFLAGS) $(LDLIBS) -o $@ check_getdns_common.lo
|
$(LIBTOOL) --tag=CC --mode=link $(CC) $(CFLAGS) $(LDFLAGS) $(LDLIBS) -o $@ check_getdns_common.lo
|
||||||
|
|
||||||
|
@ -281,8 +278,6 @@ scratchpad.template.lo scratchpad.template.o: scratchpad.template.c ../getdns/ge
|
||||||
../getdns/getdns_extra.h
|
../getdns/getdns_extra.h
|
||||||
testmessages.lo testmessages.o: $(srcdir)/testmessages.c $(srcdir)/testmessages.h
|
testmessages.lo testmessages.o: $(srcdir)/testmessages.c $(srcdir)/testmessages.h
|
||||||
tests_dict.lo tests_dict.o: $(srcdir)/tests_dict.c $(srcdir)/testmessages.h ../getdns/getdns.h
|
tests_dict.lo tests_dict.o: $(srcdir)/tests_dict.c $(srcdir)/testmessages.h ../getdns/getdns.h
|
||||||
tests_json-pointers.lo tests_json-pointers.o: $(srcdir)/tests_json-pointers.c ../getdns/getdns.h \
|
|
||||||
../getdns/getdns_extra.h
|
|
||||||
tests_list.lo tests_list.o: $(srcdir)/tests_list.c $(srcdir)/testmessages.h ../getdns/getdns.h
|
tests_list.lo tests_list.o: $(srcdir)/tests_list.c $(srcdir)/testmessages.h ../getdns/getdns.h
|
||||||
tests_namespaces.lo tests_namespaces.o: $(srcdir)/tests_namespaces.c $(srcdir)/testmessages.h ../getdns/getdns.h
|
tests_namespaces.lo tests_namespaces.o: $(srcdir)/tests_namespaces.c $(srcdir)/testmessages.h ../getdns/getdns.h
|
||||||
tests_stub_async.lo tests_stub_async.o: $(srcdir)/tests_stub_async.c ../config.h $(srcdir)/testmessages.h \
|
tests_stub_async.lo tests_stub_async.o: $(srcdir)/tests_stub_async.c ../config.h $(srcdir)/testmessages.h \
|
||||||
|
|
|
@ -331,6 +331,10 @@
|
||||||
}
|
}
|
||||||
END_TEST
|
END_TEST
|
||||||
|
|
||||||
|
/* This test disabled because travis does not support IPv6 in their
|
||||||
|
* container based infrastructure!
|
||||||
|
*/
|
||||||
|
#if 0
|
||||||
START_TEST (getdns_context_set_upstream_recursive_servers_10)
|
START_TEST (getdns_context_set_upstream_recursive_servers_10)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
|
@ -345,7 +349,7 @@
|
||||||
struct getdns_dict *dict = NULL;
|
struct getdns_dict *dict = NULL;
|
||||||
struct getdns_dict *response = NULL;
|
struct getdns_dict *response = NULL;
|
||||||
struct getdns_bindata address_type = { 5, (void *)"IPv6" };
|
struct getdns_bindata address_type = { 5, (void *)"IPv6" };
|
||||||
struct getdns_bindata address_data = { 16, (void *)"\x20\x01\x48\x60\x48\x60\x00\x00\x00\x00\x00\x00\x00\x00\x88\x44" };
|
struct getdns_bindata address_data = { 16, (void *)"\x26\x20\x00\x74\x00\x1b\x00\x00\x00\x00\x00\x00\x00\x01\x00\x01" };
|
||||||
size_t index = 0;
|
size_t index = 0;
|
||||||
|
|
||||||
CONTEXT_CREATE(TRUE);
|
CONTEXT_CREATE(TRUE);
|
||||||
|
@ -379,7 +383,7 @@
|
||||||
DICT_DESTROY(response);
|
DICT_DESTROY(response);
|
||||||
}
|
}
|
||||||
END_TEST
|
END_TEST
|
||||||
|
#endif
|
||||||
START_TEST (getdns_context_set_upstream_recursive_servers_11)
|
START_TEST (getdns_context_set_upstream_recursive_servers_11)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
|
@ -460,7 +464,7 @@
|
||||||
/* Positive test cases */
|
/* Positive test cases */
|
||||||
TCase *tc_pos = tcase_create("Positive");
|
TCase *tc_pos = tcase_create("Positive");
|
||||||
tcase_add_test(tc_pos, getdns_context_set_upstream_recursive_servers_9);
|
tcase_add_test(tc_pos, getdns_context_set_upstream_recursive_servers_9);
|
||||||
tcase_add_test(tc_pos, getdns_context_set_upstream_recursive_servers_10);
|
/***** tcase_add_test(tc_pos, getdns_context_set_upstream_recursive_servers_10); *****/
|
||||||
tcase_add_test(tc_pos, getdns_context_set_upstream_recursive_servers_11);
|
tcase_add_test(tc_pos, getdns_context_set_upstream_recursive_servers_11);
|
||||||
|
|
||||||
suite_add_tcase(s, tc_pos);
|
suite_add_tcase(s, tc_pos);
|
||||||
|
|
|
@ -0,0 +1,16 @@
|
||||||
|
BaseName: 100-compile
|
||||||
|
Version: 1.0
|
||||||
|
Description: Create a builddir and compile
|
||||||
|
CreationDate: do dec 10 11:09:43 CET 2015
|
||||||
|
Maintainer: Willem Toorop
|
||||||
|
Category:
|
||||||
|
Component:
|
||||||
|
CmdDepends:
|
||||||
|
Depends:
|
||||||
|
Help: 100-compile.help
|
||||||
|
Pre: 100-compile.pre
|
||||||
|
Post:
|
||||||
|
Test: 100-compile.test
|
||||||
|
AuxFiles:
|
||||||
|
Passed:
|
||||||
|
Failure:
|
|
@ -0,0 +1 @@
|
||||||
|
The library is compiled without eventloop extensions.
|
|
@ -0,0 +1,19 @@
|
||||||
|
# #-- 100-compile.pre--#
|
||||||
|
# source the master var file when it's there
|
||||||
|
if [ -f ../.tpkg.var.master ]
|
||||||
|
then
|
||||||
|
source ../.tpkg.var.master
|
||||||
|
else
|
||||||
|
(
|
||||||
|
cd ..
|
||||||
|
[ -f "${TPKG_SRCDIR}/setup-env.sh" ] \
|
||||||
|
&& sh "${TPKG_SRCDIR}/setup-env.sh"
|
||||||
|
) && source ../.tpkg.var.master
|
||||||
|
fi
|
||||||
|
# use .tpkg.var.test for in test variable passing
|
||||||
|
[ -f .tpkg.var.test ] && source .tpkg.var.test
|
||||||
|
|
||||||
|
rm -fr "${BUILDDIR}/build"
|
||||||
|
mkdir "${BUILDDIR}/build"
|
||||||
|
cd "${BUILDDIR}/build"
|
||||||
|
"${SRCROOT}/configure"
|
|
@ -0,0 +1,8 @@
|
||||||
|
# #-- 100-compile.test --#
|
||||||
|
# source the master var file when it's there
|
||||||
|
[ -f ../.tpkg.var.master ] && source ../.tpkg.var.master
|
||||||
|
# use .tpkg.var.test for in test variable passing
|
||||||
|
[ -f .tpkg.var.test ] && source .tpkg.var.test
|
||||||
|
|
||||||
|
cd "${BUILDDIR}/build"
|
||||||
|
make
|
|
@ -0,0 +1,16 @@
|
||||||
|
BaseName: 110-link
|
||||||
|
Version: 1.0
|
||||||
|
Description: Link getdns_query program
|
||||||
|
CreationDate: do dec 10 11:10:11 CET 2015
|
||||||
|
Maintainer: Willem Toorop
|
||||||
|
Category:
|
||||||
|
Component:
|
||||||
|
CmdDepends:
|
||||||
|
Depends: 100-compile.tpkg
|
||||||
|
Help: 110-link.help
|
||||||
|
Pre:
|
||||||
|
Post:
|
||||||
|
Test: 110-link.test
|
||||||
|
AuxFiles:
|
||||||
|
Passed:
|
||||||
|
Failure:
|
|
@ -0,0 +1 @@
|
||||||
|
Try to link the getdns_query program
|
|
@ -0,0 +1,10 @@
|
||||||
|
# #-- 110-link.test --#
|
||||||
|
# source the master var file when it's there
|
||||||
|
[ -f ../.tpkg.var.master ] && source ../.tpkg.var.master
|
||||||
|
# use .tpkg.var.test for in test variable passing
|
||||||
|
[ -f .tpkg.var.test ] && source .tpkg.var.test
|
||||||
|
|
||||||
|
cd "${BUILDDIR}/build"
|
||||||
|
make getdns_query \
|
||||||
|
&& echo "export GETDNS_QUERY=\"${BUILDDIR}/build/src/test/getdns_query\"" \
|
||||||
|
>> ../.tpkg.var.master
|
|
@ -0,0 +1,16 @@
|
||||||
|
BaseName: 120-run-getdns_query
|
||||||
|
Version: 1.0
|
||||||
|
Description: Run the getdns_query program
|
||||||
|
CreationDate: do dec 10 11:09:59 CET 2015
|
||||||
|
Maintainer: Willem Toorop
|
||||||
|
Category:
|
||||||
|
Component:
|
||||||
|
CmdDepends:
|
||||||
|
Depends: 110-link.tpkg
|
||||||
|
Help: 120-run-getdns_query.help
|
||||||
|
Pre:
|
||||||
|
Post:
|
||||||
|
Test: 120-run-getdns_query.test
|
||||||
|
AuxFiles:
|
||||||
|
Passed:
|
||||||
|
Failure:
|
|
@ -0,0 +1 @@
|
||||||
|
Run the getdns_query test program
|
|
@ -0,0 +1,7 @@
|
||||||
|
# #-- 120-run-getdns_query.test --#
|
||||||
|
# source the master var file when it's there
|
||||||
|
[ -f ../.tpkg.var.master ] && source ../.tpkg.var.master
|
||||||
|
# use .tpkg.var.test for in test variable passing
|
||||||
|
[ -f .tpkg.var.test ] && source .tpkg.var.test
|
||||||
|
|
||||||
|
"${GETDNS_QUERY}" -i
|
|
@ -0,0 +1,16 @@
|
||||||
|
BaseName: 130-run-unit-tests
|
||||||
|
Version: 1.0
|
||||||
|
Description: Run the getdns_query program
|
||||||
|
CreationDate: do dec 10 11:10:29 CET 2015
|
||||||
|
Maintainer: Willem Toorop
|
||||||
|
Category:
|
||||||
|
Component:
|
||||||
|
CmdDepends:
|
||||||
|
Depends: 110-link.tpkg
|
||||||
|
Help: 130-run-unit-tests.help
|
||||||
|
Pre:
|
||||||
|
Post:
|
||||||
|
Test: 130-run-unit-tests.test
|
||||||
|
AuxFiles:
|
||||||
|
Passed:
|
||||||
|
Failure:
|
|
@ -0,0 +1 @@
|
||||||
|
Run the getdns_query test program
|
|
@ -0,0 +1,8 @@
|
||||||
|
# #-- 130-run-unit-tests.test --#
|
||||||
|
# source the master var file when it's there
|
||||||
|
[ -f ../.tpkg.var.master ] && source ../.tpkg.var.master
|
||||||
|
# use .tpkg.var.test for in test variable passing
|
||||||
|
[ -f .tpkg.var.test ] && source .tpkg.var.test
|
||||||
|
|
||||||
|
cd "${BUILDDIR}/build"
|
||||||
|
make test
|
|
@ -0,0 +1,16 @@
|
||||||
|
BaseName: 200-stub-only-compile
|
||||||
|
Version: 1.0
|
||||||
|
Description: Create a builddir and compile simple
|
||||||
|
CreationDate: do dec 10 11:08:24 CET 2015
|
||||||
|
Maintainer: Willem Toorop
|
||||||
|
Category:
|
||||||
|
Component:
|
||||||
|
CmdDepends:
|
||||||
|
Depends:
|
||||||
|
Help: 200-stub-only-compile.help
|
||||||
|
Pre: 200-stub-only-compile.pre
|
||||||
|
Post:
|
||||||
|
Test: 200-stub-only-compile.test
|
||||||
|
AuxFiles:
|
||||||
|
Passed:
|
||||||
|
Failure:
|
|
@ -0,0 +1 @@
|
||||||
|
The library is compiled as stub only and without eventloop extensions.
|
|
@ -0,0 +1,19 @@
|
||||||
|
# #-- 200-stub-only-compile.pre--#
|
||||||
|
# source the master var file when it's there
|
||||||
|
if [ -f ../.tpkg.var.master ]
|
||||||
|
then
|
||||||
|
source ../.tpkg.var.master
|
||||||
|
else
|
||||||
|
(
|
||||||
|
cd ..
|
||||||
|
[ -f "${TPKG_SRCDIR}/setup-env.sh" ] \
|
||||||
|
&& sh "${TPKG_SRCDIR}/setup-env.sh"
|
||||||
|
) && source ../.tpkg.var.master
|
||||||
|
fi
|
||||||
|
# use .tpkg.var.test for in test variable passing
|
||||||
|
[ -f .tpkg.var.test ] && source .tpkg.var.test
|
||||||
|
|
||||||
|
rm -fr "${BUILDDIR}/build-stub-only"
|
||||||
|
mkdir "${BUILDDIR}/build-stub-only"
|
||||||
|
cd "${BUILDDIR}/build-stub-only"
|
||||||
|
"${SRCROOT}/configure" --enable-stub-only
|
|
@ -0,0 +1,8 @@
|
||||||
|
# #-- 200-stub-only-compile.test --#
|
||||||
|
# source the master var file when it's there
|
||||||
|
[ -f ../.tpkg.var.master ] && source ../.tpkg.var.master
|
||||||
|
# use .tpkg.var.test for in test variable passing
|
||||||
|
[ -f .tpkg.var.test ] && source .tpkg.var.test
|
||||||
|
|
||||||
|
cd "${BUILDDIR}/build-stub-only"
|
||||||
|
make
|
|
@ -0,0 +1,16 @@
|
||||||
|
BaseName: 210-stub-only-link
|
||||||
|
Version: 1.0
|
||||||
|
Description: Link getdns_query program
|
||||||
|
CreationDate: do dec 10 11:08:37 CET 2015
|
||||||
|
Maintainer: Willem Toorop
|
||||||
|
Category:
|
||||||
|
Component:
|
||||||
|
CmdDepends:
|
||||||
|
Depends: 200-stub-only-compile.tpkg
|
||||||
|
Help: 210-stub-only-link.help
|
||||||
|
Pre:
|
||||||
|
Post:
|
||||||
|
Test: 210-stub-only-link.test
|
||||||
|
AuxFiles:
|
||||||
|
Passed:
|
||||||
|
Failure:
|
|
@ -0,0 +1 @@
|
||||||
|
Try to link the getdns_query program
|
|
@ -0,0 +1,10 @@
|
||||||
|
# #-- 210-stub-only-link.test --#
|
||||||
|
# source the master var file when it's there
|
||||||
|
[ -f ../.tpkg.var.master ] && source ../.tpkg.var.master
|
||||||
|
# use .tpkg.var.test for in test variable passing
|
||||||
|
[ -f .tpkg.var.test ] && source .tpkg.var.test
|
||||||
|
|
||||||
|
cd "${BUILDDIR}/build-stub-only"
|
||||||
|
make getdns_query \
|
||||||
|
&& echo "export GETDNS_STUB_QUERY=\"${BUILDDIR}/build-stub-only/src/test/getdns_query\"" \
|
||||||
|
>> ../.tpkg.var.master
|
|
@ -0,0 +1,16 @@
|
||||||
|
BaseName: 220-stub-only-run-getdns_query
|
||||||
|
Version: 1.0
|
||||||
|
Description: Run the getdns_query program
|
||||||
|
CreationDate: do dec 10 11:08:51 CET 2015
|
||||||
|
Maintainer: Willem Toorop
|
||||||
|
Category:
|
||||||
|
Component:
|
||||||
|
CmdDepends:
|
||||||
|
Depends: 210-stub-only-link.tpkg
|
||||||
|
Help: 220-stub-only-run-getdns_query.help
|
||||||
|
Pre:
|
||||||
|
Post:
|
||||||
|
Test: 220-stub-only-run-getdns_query.test
|
||||||
|
AuxFiles:
|
||||||
|
Passed:
|
||||||
|
Failure:
|
|
@ -0,0 +1 @@
|
||||||
|
Run the getdns_query test program
|
|
@ -0,0 +1,7 @@
|
||||||
|
# #-- 220-stub-only-run-getdns_query.test --#
|
||||||
|
# source the master var file when it's there
|
||||||
|
[ -f ../.tpkg.var.master ] && source ../.tpkg.var.master
|
||||||
|
# use .tpkg.var.test for in test variable passing
|
||||||
|
[ -f .tpkg.var.test ] && source .tpkg.var.test
|
||||||
|
|
||||||
|
"${GETDNS_STUB_QUERY}" -i
|
|
@ -0,0 +1,16 @@
|
||||||
|
BaseName: 230-stub-only-run-unit-tests
|
||||||
|
Version: 1.0
|
||||||
|
Description: Run the getdns_query program
|
||||||
|
CreationDate: do dec 10 11:09:02 CET 2015
|
||||||
|
Maintainer: Willem Toorop
|
||||||
|
Category:
|
||||||
|
Component:
|
||||||
|
CmdDepends:
|
||||||
|
Depends: 210-stub-only-link.tpkg
|
||||||
|
Help: 230-stub-only-run-unit-tests.help
|
||||||
|
Pre:
|
||||||
|
Post:
|
||||||
|
Test: 230-stub-only-run-unit-tests.test
|
||||||
|
AuxFiles:
|
||||||
|
Passed:
|
||||||
|
Failure:
|
|
@ -0,0 +1 @@
|
||||||
|
Run the getdns_query test program
|
|
@ -0,0 +1,8 @@
|
||||||
|
# #-- 230-stub-only-run-unit-tests.test --#
|
||||||
|
# source the master var file when it's there
|
||||||
|
[ -f ../.tpkg.var.master ] && source ../.tpkg.var.master
|
||||||
|
# use .tpkg.var.test for in test variable passing
|
||||||
|
[ -f .tpkg.var.test ] && source .tpkg.var.test
|
||||||
|
|
||||||
|
cd "${BUILDDIR}/build-stub-only"
|
||||||
|
make test
|
|
@ -0,0 +1,15 @@
|
||||||
|
builddir = @BUILDDIR@
|
||||||
|
testname = @TPKG_NAME@
|
||||||
|
LIBTOOL = $(builddir)/libtool
|
||||||
|
|
||||||
|
CFLAGS=-I$(builddir)/src/getdns
|
||||||
|
LDLIBS=$(builddir)/src/libgetdns.la
|
||||||
|
|
||||||
|
.SUFFIXES: .c .o .a .lo .h
|
||||||
|
|
||||||
|
.c.lo:
|
||||||
|
$(LIBTOOL) --quiet --tag=CC --mode=compile $(CC) $(CFLAGS) -c $< -o $@
|
||||||
|
|
||||||
|
$(testname): $(testname).lo
|
||||||
|
$(LIBTOOL) --tag=CC --mode=link $(CC) $(LDLIBS) $(LDFLAGS) -o $@ $<
|
||||||
|
|
|
@ -0,0 +1,16 @@
|
||||||
|
BaseName: 250-json-pointers
|
||||||
|
Version: 1.0
|
||||||
|
Description: Test json pointers
|
||||||
|
CreationDate: vr dec 11 11:09:57 CET 2015
|
||||||
|
Maintainer: Willem Toorop
|
||||||
|
Category:
|
||||||
|
Component:
|
||||||
|
CmdDepends:
|
||||||
|
Depends: 200-stub-only-compile.tpkg
|
||||||
|
Help: 250-json-pointers.help
|
||||||
|
Pre: 250-json-pointers.pre
|
||||||
|
Post:
|
||||||
|
Test: 250-json-pointers.test
|
||||||
|
AuxFiles:
|
||||||
|
Passed:
|
||||||
|
Failure:
|
|
@ -0,0 +1,2 @@
|
||||||
|
Compile a program that setups a dict with json pointers and pretty prints the dict.
|
||||||
|
Then compare the output to the known to be good output.
|
|
@ -0,0 +1,14 @@
|
||||||
|
# #-- 250-json-pointers.test --#
|
||||||
|
# source the master var file when it's there
|
||||||
|
[ -f ../.tpkg.var.master ] && source ../.tpkg.var.master
|
||||||
|
# use .tpkg.var.test for in test variable passing
|
||||||
|
[ -f .tpkg.var.test ] && source .tpkg.var.test
|
||||||
|
|
||||||
|
(
|
||||||
|
grep '^CC=' "${BUILDDIR}/build-stub-only/src/Makefile"
|
||||||
|
grep '^LDFLAGS=' "${BUILDDIR}/build-stub-only/src/Makefile"
|
||||||
|
|
||||||
|
BUILDDIR4SED=`echo "${BUILDDIR}/build-stub-only" | sed 's/\//\\\\\//g'`
|
||||||
|
sed -e "s/@BUILDDIR@/${BUILDDIR4SED}/g" \
|
||||||
|
-e "s/@TPKG_NAME@/${TPKG_NAME}/g" "${TPKG_NAME}.Makefile"
|
||||||
|
) > Makefile
|
|
@ -0,0 +1,7 @@
|
||||||
|
# #-- 250-json-pointers.test --#
|
||||||
|
# source the master var file when it's there
|
||||||
|
[ -f ../.tpkg.var.master ] && source ../.tpkg.var.master
|
||||||
|
# use .tpkg.var.test for in test variable passing
|
||||||
|
[ -f .tpkg.var.test ] && source .tpkg.var.test
|
||||||
|
|
||||||
|
make && "./${TPKG_NAME}" | tee out && diff out "${TPKG_NAME}.good"
|
|
@ -0,0 +1,16 @@
|
||||||
|
BaseName: 300-event-loops-compile
|
||||||
|
Version: 1.0
|
||||||
|
Description: Create a builddir and compile with event loops
|
||||||
|
CreationDate: do dec 10 11:38:35 CET 2015
|
||||||
|
Maintainer: Willem Toorop
|
||||||
|
Category:
|
||||||
|
Component:
|
||||||
|
CmdDepends:
|
||||||
|
Depends:
|
||||||
|
Help: 300-event-loops-compile.help
|
||||||
|
Pre: 300-event-loops-compile.pre
|
||||||
|
Post:
|
||||||
|
Test: 300-event-loops-compile.test
|
||||||
|
AuxFiles:
|
||||||
|
Passed:
|
||||||
|
Failure:
|
|
@ -0,0 +1 @@
|
||||||
|
The library is compiled with eventloop extensions for all event loops available.
|
|
@ -0,0 +1,25 @@
|
||||||
|
# #-- 300-event-loops-compile.pre--#
|
||||||
|
# source the master var file when it's there
|
||||||
|
if [ -f ../.tpkg.var.master ]
|
||||||
|
then
|
||||||
|
source ../.tpkg.var.master
|
||||||
|
else
|
||||||
|
(
|
||||||
|
cd ..
|
||||||
|
[ -f "${TPKG_SRCDIR}/setup-env.sh" ] \
|
||||||
|
&& sh "${TPKG_SRCDIR}/setup-env.sh"
|
||||||
|
) && source ../.tpkg.var.master
|
||||||
|
fi
|
||||||
|
# use .tpkg.var.test for in test variable passing
|
||||||
|
[ -f .tpkg.var.test ] && source .tpkg.var.test
|
||||||
|
|
||||||
|
rm -fr "${BUILDDIR}/build-event-loops"
|
||||||
|
mkdir "${BUILDDIR}/build-event-loops"
|
||||||
|
cd "${BUILDDIR}/build-event-loops"
|
||||||
|
"${SRCROOT}/configure" --with-libevent --with-libev --with-libuv \
|
||||||
|
|| "${SRCROOT}/configure" --with-libevent --with-libev \
|
||||||
|
|| "${SRCROOT}/configure" --with-libevent --with-libuv \
|
||||||
|
|| "${SRCROOT}/configure" --with-libev --with-libuv \
|
||||||
|
|| "${SRCROOT}/configure" --with-libevent \
|
||||||
|
|| "${SRCROOT}/configure" --with-libev \
|
||||||
|
|| "${SRCROOT}/configure" --with-libuv
|
|
@ -0,0 +1,8 @@
|
||||||
|
# #-- 300-event-loops-compile.test --#
|
||||||
|
# source the master var file when it's there
|
||||||
|
[ -f ../.tpkg.var.master ] && source ../.tpkg.var.master
|
||||||
|
# use .tpkg.var.test for in test variable passing
|
||||||
|
[ -f .tpkg.var.test ] && source .tpkg.var.test
|
||||||
|
|
||||||
|
cd "${BUILDDIR}/build-event-loops"
|
||||||
|
make
|
|
@ -0,0 +1,16 @@
|
||||||
|
BaseName: 330-event-loops-unit-tests
|
||||||
|
Version: 1.0
|
||||||
|
Description: Run the unit tests
|
||||||
|
CreationDate: do dec 10 11:40:16 CET 2015
|
||||||
|
Maintainer: Willem Toorop
|
||||||
|
Category:
|
||||||
|
Component:
|
||||||
|
CmdDepends:
|
||||||
|
Depends: 300-event-loops-compile.tpkg
|
||||||
|
Help: 330-event-loops-unit-tests.help
|
||||||
|
Pre:
|
||||||
|
Post:
|
||||||
|
Test: 330-event-loops-unit-tests.test
|
||||||
|
AuxFiles:
|
||||||
|
Passed:
|
||||||
|
Failure:
|
|
@ -0,0 +1 @@
|
||||||
|
Run the getdns_query test program
|
|
@ -0,0 +1,8 @@
|
||||||
|
# #-- 330-event-loops-unit-tests.test --#
|
||||||
|
# source the master var file when it's there
|
||||||
|
[ -f ../.tpkg.var.master ] && source ../.tpkg.var.master
|
||||||
|
# use .tpkg.var.test for in test variable passing
|
||||||
|
[ -f .tpkg.var.test ] && source .tpkg.var.test
|
||||||
|
|
||||||
|
cd "${BUILDDIR}/build-event-loops"
|
||||||
|
make test
|
|
@ -0,0 +1,10 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
export SRCDIR=`dirname $0`
|
||||||
|
. `dirname $0`/setup-env.sh
|
||||||
|
|
||||||
|
for TEST_PKG in ${SRCDIR}/*.tpkg
|
||||||
|
do
|
||||||
|
"${TPKG}" $* exe "${TEST_PKG}"
|
||||||
|
done
|
||||||
|
"${TPKG}" r
|
|
@ -0,0 +1,34 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
export SRCDIR=`dirname $0`
|
||||||
|
export SRCROOT=`(cd "${SRCDIR}/../../.."; pwd)`
|
||||||
|
export TPKG="${SRCDIR}/tpkg"
|
||||||
|
export BUILDDIR=`pwd`
|
||||||
|
export BUILDROOT=`(cd "${BUILDDIR}/../../.."; pwd)`
|
||||||
|
export LIBTOOL="${BUILDROOT}/libtool"
|
||||||
|
|
||||||
|
if [ ! -f "${SRCROOT}/libtool" ]
|
||||||
|
then
|
||||||
|
(cd "${SRCROOT}"; libtoolize -fic)
|
||||||
|
fi
|
||||||
|
if [ ! -f "${SRCROOT}/configure" ]
|
||||||
|
then
|
||||||
|
(cd "${SRCROOT}"; autoreconf -fi)
|
||||||
|
fi
|
||||||
|
if [ -f .tpkg.var.master ]
|
||||||
|
then
|
||||||
|
cat .tpkg.var.master \
|
||||||
|
| egrep -v '^export SRCDIR=|^export SRCROOT=|^export TPKG=' \
|
||||||
|
| egrep -v 'export BUILDDIR|^export BUILDROOT=|^export LIBTOOL=' \
|
||||||
|
>.tpkg.var.master.cleanup
|
||||||
|
mv .tpkg.var.master.cleanup .tpkg.var.master
|
||||||
|
fi
|
||||||
|
cat >>.tpkg.var.master << END_OF_TPKG_VAR_MASTER
|
||||||
|
export SRCDIR="${SRCDIR}"
|
||||||
|
export SRCROOT="${SRCROOT}"
|
||||||
|
export BUILDDIR="${BUILDDIR}"
|
||||||
|
export BUILDROOT="${BUILDROOT}"
|
||||||
|
export TPKG="${TPKG}"
|
||||||
|
export LIBTOOL="${LIBTOOL}"
|
||||||
|
END_OF_TPKG_VAR_MASTER
|
||||||
|
|
|
@ -0,0 +1,922 @@
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
# a utlity to run a shar test archive (aka tpkg)
|
||||||
|
# Created by Miek Gieben, NLnetLabs, (c) 2005, 2006
|
||||||
|
# Licensed under GPL version 2
|
||||||
|
|
||||||
|
export TPKG_VAR_MASTER="../.tpkg.var.master"
|
||||||
|
export TPKG_VAR_TEST=".tpkg.var.test"
|
||||||
|
export TPKG_VERSION="1.12";
|
||||||
|
export SHELL="/bin/sh"
|
||||||
|
TPKG_LOGGER=/usr/bin/logger
|
||||||
|
TPKG_BASE="."
|
||||||
|
TPKG_ARGS=""
|
||||||
|
TPKG_CURRENT=`pwd`
|
||||||
|
TPKG_QUIET=0 # only output err() msgs
|
||||||
|
TPKG_KEEP=0 # tpkg create doesn't remove dir/
|
||||||
|
TPKG_PASS=0 # how much must succeed
|
||||||
|
TPKG_LOG=0 # don't log
|
||||||
|
TPKG_PRI="" # log facility
|
||||||
|
TPKG_FORMAT="targz" # format of underlying tpkg files
|
||||||
|
TPKG_FORCE=0 # execute tests even when .done file is found
|
||||||
|
|
||||||
|
_DESC_WIDTH=${COLUMNS:-55}
|
||||||
|
if [ $_DESC_WIDTH -ge 70 ]; then
|
||||||
|
_DESC_WIDTH=70
|
||||||
|
fi
|
||||||
|
|
||||||
|
### Helper functions
|
||||||
|
function cleanup() {
|
||||||
|
out "[log] Cleaning up"
|
||||||
|
[[ -f result.$dsc_basename ]] && cp result.$dsc_basename ../
|
||||||
|
cd ..
|
||||||
|
if [[ ! -z "$dir" ]]; then
|
||||||
|
rm -rf `basename $dir`
|
||||||
|
fi
|
||||||
|
cd $TPKG_CURRENT
|
||||||
|
}
|
||||||
|
|
||||||
|
function cleanup_and_exit() {
|
||||||
|
cleanup; exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
function err() {
|
||||||
|
if [[ -z $testname ]]; then
|
||||||
|
echo -e " $1"
|
||||||
|
else
|
||||||
|
echo -e "[$testname] $1"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function tpkg_log() {
|
||||||
|
if [[ $TPKG_LOG -eq 0 ]]; then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -e $TPKG_LOGGER ]]; then
|
||||||
|
if [[ -z $TPKG_PRI ]]; then
|
||||||
|
$TPKG_LOGGER "$1"
|
||||||
|
else
|
||||||
|
$TPKG_LOGGER -p "$TPKG_PRI" "$1"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function out() {
|
||||||
|
if [[ $TPKG_QUIET -eq 1 ]]; then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
if [[ -z $testname ]]; then
|
||||||
|
echo -e " $1"
|
||||||
|
else
|
||||||
|
echo -e "[$testname] $1"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function epoch() {
|
||||||
|
# make this sorta portable allthough not needed now
|
||||||
|
epoch=0
|
||||||
|
case $OSTYPE in
|
||||||
|
linux*)
|
||||||
|
epoch=`date +%s`
|
||||||
|
;;
|
||||||
|
freebsd*)
|
||||||
|
epoch=`date +%s`
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
function post() {
|
||||||
|
if [ -f "${dsc_post}" ]; then
|
||||||
|
err "[log] Executing post script: ${dsc_post} ${TPKG_ARGS}"
|
||||||
|
echo "--------- Start Post Output ------------------ " >> result.$dsc_basename
|
||||||
|
${SHELL} ${dsc_post} ${TPKG_ARGS} >> result.$dsc_basename
|
||||||
|
echo "----------- End Post Output ------------------ " >> result.$dsc_basename
|
||||||
|
result=$?
|
||||||
|
if [ $result -ne 0 ]; then
|
||||||
|
err "[warning] Post-script executed with errors: $result."
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function pre() {
|
||||||
|
if [ -f "${dsc_pre}" ]; then
|
||||||
|
err "[log] Executing pre script: ${dsc_pre} ${TPKG_ARGS}"
|
||||||
|
echo "--------- Start Pre Output ------------------- " >> result.$dsc_basename
|
||||||
|
${SHELL} ${dsc_pre} ${TPKG_ARGS} >> result.$dsc_basename
|
||||||
|
echo "----------- End Pre Output ------------------- " >> result.$dsc_basename
|
||||||
|
result=$?
|
||||||
|
if [ $result -ne 0 ]; then
|
||||||
|
err "[warning] Pre-script executed with errors: $result."
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function write_done() {
|
||||||
|
# we are executing in a subdir
|
||||||
|
if [ -f "../.done-${testname}" -a $TPKG_FORCE -ne 1 ]; then
|
||||||
|
err "[warning] Overwriting .done-${testname}"
|
||||||
|
fi
|
||||||
|
> ../.done-${testname}
|
||||||
|
}
|
||||||
|
|
||||||
|
# write done file in current dir
|
||||||
|
function write_fake_done() {
|
||||||
|
if [ -f ".done-${testname}" -a $TPKG_FORCE -ne 1 ]; then
|
||||||
|
err "[warning] Overwriting .done-${testname}"
|
||||||
|
fi
|
||||||
|
> .done-${testname}
|
||||||
|
}
|
||||||
|
|
||||||
|
function mktempdir() {
|
||||||
|
# check if mktemp is there, if not use plain mkdir with $$
|
||||||
|
# as a side effect set $dir
|
||||||
|
dir=
|
||||||
|
case $OSTYPE in
|
||||||
|
solaris*)
|
||||||
|
# use mkdir
|
||||||
|
dir="$1.$$"
|
||||||
|
mkdir "$dir"
|
||||||
|
return
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
dir=`mktemp -d "$1"`
|
||||||
|
return
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
function usage() {
|
||||||
|
out "Usage:"
|
||||||
|
out "$0 [OPTIONS] [exe|create|extract|tmpl|fake] test.tpkg"
|
||||||
|
out "or:"
|
||||||
|
out "$0 [OPTIONS] [report|clean|list|desc|help] test.tpkg"
|
||||||
|
out "or:"
|
||||||
|
out "$0 [OPTIONS] clone test1.tpkg test2.tpkg"
|
||||||
|
out
|
||||||
|
out "Testing"
|
||||||
|
out " exe.........:\texecute a test, safe the result result.testname"
|
||||||
|
out " c | create..:\tcreate a .tpkg out of the test.{pre, post, test} files"
|
||||||
|
out " e | extract.:\textract a .tpkg to tmp. dir"
|
||||||
|
out " t | tmpl....:\tcreate empty template files for a new test"
|
||||||
|
out " f | fake....:\tfake the running of test, but do create a .done file"
|
||||||
|
out
|
||||||
|
out "When no action is given a test is executed"
|
||||||
|
out
|
||||||
|
out "Reporting/Cleanup"
|
||||||
|
out " clean........:\tremove all the result files"
|
||||||
|
out " cd | cleandir:\tremove all .dir directories"
|
||||||
|
out " r | report..:\tcreate a nice report from all the result files"
|
||||||
|
out " cl | clone...:\tclone test1.tpkg to test2.tkpg"
|
||||||
|
out " l | list....:\tprint the files of the test to stdout"
|
||||||
|
out " d | desc....:\tprint the test's description to stdout"
|
||||||
|
out " h | help....:\tprint the help message for this test, if available"
|
||||||
|
out
|
||||||
|
out " When multiple tests depend on a single other test, this"
|
||||||
|
out " other test is only executed once."
|
||||||
|
out
|
||||||
|
out "OPTIONS"
|
||||||
|
out " -h\t\tshow this help"
|
||||||
|
out " -v\t\tshow version"
|
||||||
|
out " -q\t\tonly print errors"
|
||||||
|
out " -l\t\tlog test name to syslog when starting the test (using logger)"
|
||||||
|
out " -p PRI\tlog using PRI as priority"
|
||||||
|
out " -k\t\tdon't remove test directory when creating/executing a tpkg package"
|
||||||
|
out " -n NUM\tif less than NUM of the tests are passed exit with 1"
|
||||||
|
out " \t\tOtherwise exit with 0. Only valid when running tpkg report"
|
||||||
|
out " -b DIR\tuse DIR is a base directory in stead of ."
|
||||||
|
out " -a ARGS\tpass the string ARGS through to the test scripts"
|
||||||
|
out " -d\t\tUse directories instead of tar.gz for tpkg archive format"
|
||||||
|
out
|
||||||
|
out " (C) NLnetLabs, Miek Gieben. Licensed under the GPL version 2."
|
||||||
|
}
|
||||||
|
|
||||||
|
function version() {
|
||||||
|
out "tpkg (test package), version $TPKG_VERSION"
|
||||||
|
out "Written by Miek Gieben, NLnet Labs"
|
||||||
|
out
|
||||||
|
out "Copyright (C) 2005, 2006 NLnet Labs"
|
||||||
|
out
|
||||||
|
out "This is free software; see the source for copying conditions. There is no"
|
||||||
|
out "warranty; even not for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE"
|
||||||
|
}
|
||||||
|
|
||||||
|
function cleanreport() {
|
||||||
|
# cleanup all the result. files
|
||||||
|
for result in `ls result.* 2>/dev/null`; do
|
||||||
|
err "[log] rm $result"
|
||||||
|
rm $result
|
||||||
|
done
|
||||||
|
# rm any .var files
|
||||||
|
out "[log] rm `basename $TPKG_VAR_MASTER`"
|
||||||
|
rm -f `basename $TPKG_VAR_MASTER`
|
||||||
|
rm -f $TPKG_VAR_TEST
|
||||||
|
out "[log] rm .done files"
|
||||||
|
rm -f .done*
|
||||||
|
cd $TPKG_CURRENT
|
||||||
|
}
|
||||||
|
|
||||||
|
function cleandirs() {
|
||||||
|
for result in `ls -d *.dir 2> /dev/null`; do
|
||||||
|
err "[log] rm -rf $result"
|
||||||
|
rm -rf $result
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
function report() {
|
||||||
|
# generate a report from the result. files.
|
||||||
|
passed=0
|
||||||
|
failed=0
|
||||||
|
unknown=0
|
||||||
|
first=0
|
||||||
|
|
||||||
|
tp="passed"
|
||||||
|
tf="failed"
|
||||||
|
tu="unknown"
|
||||||
|
for result in `ls result.* 2>/dev/null` ; do
|
||||||
|
passfailed=`head -1 $result | awk ' { print $2 }'`
|
||||||
|
basename=`head -3 $result | grep BaseName | awk -F': ?' ' { print $2 }'`
|
||||||
|
description=`head -4 $result | grep Description | awk -F': ?' ' { print $2 }'`
|
||||||
|
runend=`head -2 $result | grep DateRunEnd | awk -F': ?' ' { print $2 }'`
|
||||||
|
runstart=`head -5 $result | grep DateRunStart | awk -F': ?' ' { print $2 }'`
|
||||||
|
|
||||||
|
# truncate the description to 35 chars
|
||||||
|
if [ ${#description} -gt $_DESC_WIDTH ]; then
|
||||||
|
description=${description:0:$_DESC_WIDTH}
|
||||||
|
description=$description"..."
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -z $runend ]; then
|
||||||
|
runend=0
|
||||||
|
fi
|
||||||
|
if [ -z $runstart ]; then
|
||||||
|
runstart=0
|
||||||
|
fi
|
||||||
|
|
||||||
|
((period=$runend - $runstart))
|
||||||
|
# prefix period if < 9
|
||||||
|
if [ $period -lt 10 ]; then
|
||||||
|
period="0$period"
|
||||||
|
fi
|
||||||
|
|
||||||
|
case $passfailed in
|
||||||
|
"FAILED")
|
||||||
|
if [ $first -eq 0 ]; then
|
||||||
|
echo " STATUS : ELAPSED : TESTNAME : TESTDESCRIPTION"
|
||||||
|
first=1
|
||||||
|
fi
|
||||||
|
echo -e "!! $passfailed !! : $period s : $basename : $description"
|
||||||
|
((failed=$failed + 1))
|
||||||
|
failed_tests="$failed_tests $basename"
|
||||||
|
tf="FAILED"
|
||||||
|
;;
|
||||||
|
"PASSED")
|
||||||
|
if [ $TPKG_QUIET -eq 0 ]; then
|
||||||
|
if [ $first -eq 0 ]; then
|
||||||
|
echo " STATUS : ELAPSED : TESTNAME : TESTDESCRIPTION"
|
||||||
|
first=1
|
||||||
|
fi
|
||||||
|
echo -e "** $passfailed ** : $period s : $basename : $description"
|
||||||
|
fi
|
||||||
|
((passed=$passed + 1))
|
||||||
|
tp="PASSED"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
if [ $first -eq 0 ]; then
|
||||||
|
echo " STATUS : ELAPSED : TESTNAME : TESTDESCRIPTION"
|
||||||
|
first=1
|
||||||
|
fi
|
||||||
|
echo -e "-- $passfailed -- : $period s : $basename : $description"
|
||||||
|
((unknown=$unknown + 1))
|
||||||
|
failed_tests="$failed_tests $basename"
|
||||||
|
tu="UNKNOWN"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
((total=$passed + $failed + $unknown))
|
||||||
|
if [[ $total -eq 0 ]]; then
|
||||||
|
fper=0
|
||||||
|
pper=0
|
||||||
|
uper=0
|
||||||
|
else
|
||||||
|
fper=`echo -e "scale=4\n$failed/$total*100" | bc | sed 's/00$//'`
|
||||||
|
pper=`echo -e "scale=4\n$passed/$total*100" | bc | sed 's/00$//'`
|
||||||
|
uper=`echo -e "scale=4\n$unknown/$total*100" | bc | sed 's/00$//'`
|
||||||
|
fi
|
||||||
|
echo
|
||||||
|
echo -e "$tp: $passed ($pper %)\t$tf: $failed ($fper %)\t$tu: $unknown ($uper %)"
|
||||||
|
|
||||||
|
# for each failed test include the complete result file
|
||||||
|
# $i is basename
|
||||||
|
echo
|
||||||
|
for i in $failed_tests; do
|
||||||
|
echo --------------- Start Output: $i ------------------
|
||||||
|
cat result.$i
|
||||||
|
echo --------------- End Output: $i ------------------
|
||||||
|
done
|
||||||
|
cd $NT
|
||||||
|
if [[ $TPKG_PASS -gt 0 ]]; then
|
||||||
|
if [[ $passed -lt $TPKG_PASS ]]; then
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
elif [[ $failed -gt 0 ]]; then
|
||||||
|
exit 1
|
||||||
|
else
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# clone test1 to test2
|
||||||
|
function clone() {
|
||||||
|
$0 extract $test1.tpkg
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
err "[fatal] Extract of $test1.tpkg failed. Abort."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ ! -d "$test1.dir" ]; then
|
||||||
|
err "[fatal] No $test1.dir directory? Abort."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
cd $test1.dir
|
||||||
|
for i in $test1.* ; do
|
||||||
|
ext=`echo $i | sed s/$test1//`
|
||||||
|
if [ ! -z "$ext" ]; then
|
||||||
|
# rename the content of the files too
|
||||||
|
sed "s/$test1/$test2/g" < $i > $i.$$
|
||||||
|
mv $i.$$ $i
|
||||||
|
# rename
|
||||||
|
mv $i $test2$ext
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
# edit the dsc file too
|
||||||
|
# update the date
|
||||||
|
sed "s/^CreationDate:.*/CreationDate: `date`/" < $test2.dsc > $test2.dsc.$$
|
||||||
|
mv $test2.dsc.$$ $test2.dsc
|
||||||
|
|
||||||
|
cd ..
|
||||||
|
# rename the dir
|
||||||
|
mv $test1.dir $test2.dir
|
||||||
|
if [ $TPKG_KEEP -eq 0 ]; then
|
||||||
|
if [ $TPKG_FORMAT = "dir" ]; then
|
||||||
|
$0 -d create $test2.tpkg
|
||||||
|
else
|
||||||
|
$0 create $test2.tpkg
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
if [ $TPKG_FORMAT = "dir" ]; then
|
||||||
|
$0 -d -k create $test2.tpkg
|
||||||
|
else
|
||||||
|
$0 -k create $test2.tpkg
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
err "[warning] Creating of $test2.tpkg failed."
|
||||||
|
fi
|
||||||
|
cd $TPKG_CURRENT
|
||||||
|
}
|
||||||
|
|
||||||
|
# try to find the specific cmd
|
||||||
|
function find_cmd {
|
||||||
|
which "${i}" >/dev/null
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
err "[fatal] CmdDepend \"$i\" could not be satisfied: not found. Abort."
|
||||||
|
cleanup; exit 1
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# extract a tpkg to the given dir. The dir must exist already.
|
||||||
|
function extract_tpkg_to { # <dir>
|
||||||
|
out "[log] Extracting..."
|
||||||
|
# tar xfz ${testname}.tpkg -C $1 2>/dev/null
|
||||||
|
if [ -d "${test_pkg}" ]
|
||||||
|
then
|
||||||
|
cp -pr "${test_pkg}" "$1/${testname}.dir"
|
||||||
|
else
|
||||||
|
gzip -cd "${test_pkg}" | (cd $1; tar xf -) 2>/dev/null
|
||||||
|
fi
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
err "[fatal] Could not untar archive. Abort."
|
||||||
|
cd $TPKG_CURRENT; exit 1
|
||||||
|
fi
|
||||||
|
# now stuff is in: $1/testname.dir/...
|
||||||
|
mv $1/${testname}.dir $1/${testname}.dir.tmp$$
|
||||||
|
mv $1/${testname}.dir.tmp$$/* $1/.
|
||||||
|
rm -rf $1/${testname}.dir.tmp$$
|
||||||
|
}
|
||||||
|
|
||||||
|
### MAIN
|
||||||
|
# check the arguments
|
||||||
|
while getopts ":vhkqb:a:n:lp:df" o
|
||||||
|
do case "$o" in
|
||||||
|
b) TPKG_BASE="$OPTARG";;
|
||||||
|
h) usage; exit 0;;
|
||||||
|
v) version; exit 0;;
|
||||||
|
l) TPKG_LOG=1;;
|
||||||
|
p) TPKG_PRI="$OPTARG";;
|
||||||
|
a) TPKG_ARGS="$OPTARG";;
|
||||||
|
q) TPKG_QUIET=1;;
|
||||||
|
k) TPKG_KEEP=1;;
|
||||||
|
n) TPKG_PASS=$OPTARG
|
||||||
|
if [ $TPKG_PASS -eq 0 ]; then
|
||||||
|
err "[fatal] A null or non numerical value is not valid. Abort."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
d) TPKG_FORMAT="dir";;
|
||||||
|
f) TPKG_FORCE=1;;
|
||||||
|
*) err "[fatal] Unknown option. Abort."; exit 1;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
shift $(($OPTIND - 1))
|
||||||
|
|
||||||
|
# go to the base dir
|
||||||
|
if [ ! -d $TPKG_BASE ]; then
|
||||||
|
err "[fatal] Directory $TPKG_BASE does not exist. Abort"
|
||||||
|
exit 1
|
||||||
|
else
|
||||||
|
cd $TPKG_BASE
|
||||||
|
fi
|
||||||
|
|
||||||
|
# either create a tpkg (ie. call shar) or exe (do a test)
|
||||||
|
goal=$1
|
||||||
|
archive=$2
|
||||||
|
if [ -z "${goal}" ]; then
|
||||||
|
usage
|
||||||
|
cd $TPKG_CURRENT; exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
# allow short goals
|
||||||
|
case $goal in
|
||||||
|
# none for exe - short enough
|
||||||
|
c) goal="create";;
|
||||||
|
e) goal="extract";;
|
||||||
|
t) goal="tmpl";;
|
||||||
|
f) goal="fake";;
|
||||||
|
cd) goal="cleandir";;
|
||||||
|
|
||||||
|
r) goal="report";;
|
||||||
|
# none for clean
|
||||||
|
cl) goal="clone";;
|
||||||
|
l) goal="list";;
|
||||||
|
d) goal="desc";;
|
||||||
|
h) goal="help";;
|
||||||
|
esac
|
||||||
|
|
||||||
|
### REPORT ###
|
||||||
|
# no extra args required
|
||||||
|
if [ "${goal}" = "report" ]; then
|
||||||
|
report;
|
||||||
|
fi
|
||||||
|
if [ "${goal}" = "clean" ]; then
|
||||||
|
cleanreport; exit 0
|
||||||
|
fi
|
||||||
|
if [ "${goal}" = "cleandir" ]; then
|
||||||
|
cleandirs; exit 0
|
||||||
|
fi
|
||||||
|
if [ "${goal}" = "clone" ]; then
|
||||||
|
test1=`basename $2 .tpkg`
|
||||||
|
test2=`basename $3 .tpkg`;
|
||||||
|
if [ -z "$test1" -o -z "$test2" ]; then
|
||||||
|
usage; cd $TPKG_CURRENT; exit 0
|
||||||
|
fi
|
||||||
|
clone; exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -z "${archive}" ]; then
|
||||||
|
out "[log] Defaulting to \`execute'"
|
||||||
|
archive=$1
|
||||||
|
goal="exe"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -z "${archive}" ]; then
|
||||||
|
usage; cd $TPKG_CURRENT; exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
testname=`basename "${archive}" .tpkg`
|
||||||
|
export TPKG_SRCDIR=`dirname "${archive}"`
|
||||||
|
export TPKG_NAME=${testname}
|
||||||
|
test_pkg="${TPKG_SRCDIR}/${testname}.tpkg"
|
||||||
|
dsc_file=$testname.dsc
|
||||||
|
if [ -z $testname ]; then
|
||||||
|
err "[fatal] The test package should have a .tpkg extension. Abort."
|
||||||
|
cd $TPKG_CURRENT; exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "${goal}" = "fake" ]; then
|
||||||
|
out "[log] Writing .done-$testname file."
|
||||||
|
write_fake_done; exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ $goal = "create" ]; then
|
||||||
|
### CREATE ###
|
||||||
|
# get all files with the same basename except those that ends in .tpkg
|
||||||
|
|
||||||
|
# check for shar
|
||||||
|
which tar >/dev/null
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
err "[fatal] Tar command not found. Abort."
|
||||||
|
cd $TPKG_CURRENT; exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# assume there is a dir named $testname.dir
|
||||||
|
if [ ! -d "${testname}.dir" ]; then
|
||||||
|
err "[fatal] No $testname.dir directory found. Abort."
|
||||||
|
cd $TPKG_CURRENT; exit 1
|
||||||
|
fi
|
||||||
|
cd $testname.dir
|
||||||
|
|
||||||
|
# rm unwanted files
|
||||||
|
cleanreport # this cd's to $TPKG_CURRENT
|
||||||
|
cd - >/dev/null # jump back
|
||||||
|
|
||||||
|
# tar is smart enough to handle this
|
||||||
|
cd ../
|
||||||
|
i=$( ls ${testname}.dir/$testname.* 2>/dev/null )
|
||||||
|
if [ -z "${i}" ]; then
|
||||||
|
err "[fatal] No $testname.* files found. Abort."
|
||||||
|
cd $TPKG_CURRENT; exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
# tar --create --file $testname.tpkg --gzip ${testname}.dir
|
||||||
|
(
|
||||||
|
if [ -d "${test_pkg}" ]
|
||||||
|
then
|
||||||
|
TPKG_FORMAT="dir"
|
||||||
|
fi
|
||||||
|
if [ $TPKG_FORMAT = "dir" ]
|
||||||
|
then
|
||||||
|
if [ -e "${test_pkg}" ]
|
||||||
|
then
|
||||||
|
rm -fr "${test_pkg}"
|
||||||
|
fi
|
||||||
|
cp -pr "${testname}.dir" "${test_pkg}" \
|
||||||
|
|| cp -pr "${testname}.dir" "${test_pkg}" \
|
||||||
|
|| ( mkdir "${test_pkg}" \
|
||||||
|
&& ( ( cd "${testname}.dir" ; tar cf - . ) \
|
||||||
|
| ( cd "${test_pkg}"; tar xf -)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
else
|
||||||
|
tar -cf - ${testname}.dir | gzip - > "${test_pkg}"
|
||||||
|
fi
|
||||||
|
)
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
err "[fatal] Archive create error. Abort."
|
||||||
|
cd $TPKG_CURRENT; exit 1
|
||||||
|
fi
|
||||||
|
if [ $TPKG_KEEP -eq 0 ]; then
|
||||||
|
out "[log] Removing member files"
|
||||||
|
rm $i
|
||||||
|
fi
|
||||||
|
if [ $TPKG_KEEP -eq 0 ]; then
|
||||||
|
out "[log] Removing directory"
|
||||||
|
rmdir $testname.dir
|
||||||
|
fi
|
||||||
|
cd $TPKG_CURRENT; exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
### TMPL ####
|
||||||
|
# write out a .dsc and touch a .pre/.post/.test
|
||||||
|
if [ $goal = "tmpl" ]; then
|
||||||
|
if [ -f $testname.dsc ]; then
|
||||||
|
err "[fatal] $testname.dsc already exists. Abort."
|
||||||
|
cd $TPKG_CURRENT; exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# make tmp dir
|
||||||
|
dir="$testname.dir"
|
||||||
|
mkdir $dir
|
||||||
|
if [ ! -d $dir ]; then
|
||||||
|
err "[fatal] Failure to create a temporary working directory. Abort."
|
||||||
|
cd $TPKG_CURRENT; exit 1
|
||||||
|
fi
|
||||||
|
cd $dir
|
||||||
|
|
||||||
|
cat <<TMPL_EOF > $testname.dsc
|
||||||
|
BaseName: $testname
|
||||||
|
Version: 1.0
|
||||||
|
Description: [Put something nice here]
|
||||||
|
CreationDate: `date`
|
||||||
|
Maintainer: `grep $LOGNAME /etc/passwd | awk -F: ' { print $5 }' | sed s/,//g`
|
||||||
|
Category:
|
||||||
|
Component:
|
||||||
|
CmdDepends:
|
||||||
|
Depends:
|
||||||
|
Help: $testname.help
|
||||||
|
Pre: $testname.pre
|
||||||
|
Post: $testname.post
|
||||||
|
Test: $testname.test
|
||||||
|
AuxFiles:
|
||||||
|
Passed:
|
||||||
|
Failure:
|
||||||
|
TMPL_EOF
|
||||||
|
# .help file
|
||||||
|
echo "Please describe how to use this test." > $testname.help
|
||||||
|
echo "i.e. tpkg -a ARG exe testname:" >> $testname.help
|
||||||
|
echo " ARG is used to ..." >> $testname.help
|
||||||
|
|
||||||
|
# .test file
|
||||||
|
echo "# #-- $testname.test --#" > $testname.test
|
||||||
|
echo "# source the master var file when it's there" >> $testname.test
|
||||||
|
echo "[ -f $TPKG_VAR_MASTER ] && source $TPKG_VAR_MASTER" >> $testname.test
|
||||||
|
echo "# use $TPKG_VAR_TEST for in test variable passing" >> $testname.test
|
||||||
|
echo "[ -f $TPKG_VAR_TEST ] && source $TPKG_VAR_TEST" >> $testname.test
|
||||||
|
|
||||||
|
# .post file
|
||||||
|
echo "# #-- $testname.post --#" > $testname.post
|
||||||
|
echo "# source the master var file when it's there" >> $testname.post
|
||||||
|
echo "[ -f $TPKG_VAR_MASTER ] && source $TPKG_VAR_MASTER" >> $testname.post
|
||||||
|
echo "# source the test var file when it's there" >> $testname.post
|
||||||
|
echo "[ -f $TPKG_VAR_TEST ] && source $TPKG_VAR_TEST" >> $testname.post
|
||||||
|
echo "#" >> $testname.post
|
||||||
|
echo "# do your teardown here" >> $testname.post
|
||||||
|
|
||||||
|
# .pre file
|
||||||
|
echo "# #-- $testname.pre--#" > $testname.pre
|
||||||
|
echo "# source the master var file when it's there" >> $testname.pre
|
||||||
|
echo "[ -f $TPKG_VAR_MASTER ] && source $TPKG_VAR_MASTER" >> $testname.pre
|
||||||
|
echo "# use $TPKG_VAR_TEST for in test variable passing" >> $testname.pre
|
||||||
|
echo "[ -f $TPKG_VAR_TEST ] && source $TPKG_VAR_TEST" >> $testname.pre
|
||||||
|
|
||||||
|
out "[log] created $testname.{dsc, test, help, pre, post}"
|
||||||
|
out "[log] please create the script(s) and then run: tpkg create $testname.tpkg"
|
||||||
|
out "[log] created $testname in $dir."
|
||||||
|
cd $TPKG_CURRENT; exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ ! -e $archive ]; then
|
||||||
|
err "[fatal] Cannot find the test package: $archive. Abort."
|
||||||
|
cd $TPKG_CURRENT; exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
## EXTRACT
|
||||||
|
if [ $goal = "extract" ]; then
|
||||||
|
dir="${testname}.dir"
|
||||||
|
if [ -d $dir ]; then
|
||||||
|
err "[fatal] Directory $dir already exists. Abort."
|
||||||
|
cd $TPKG_CURRENT; exit 1
|
||||||
|
fi
|
||||||
|
mkdir $dir
|
||||||
|
if [ ! -d $dir ]; then
|
||||||
|
err "[fatal] Failure to create $dir directory. Abort."
|
||||||
|
cd $TPKG_CURRENT; exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
extract_tpkg_to $dir
|
||||||
|
cd $dir
|
||||||
|
trap cleanup_and_exit INT
|
||||||
|
|
||||||
|
# stop here
|
||||||
|
out "[log] extracted ${test_pkg} $dir."
|
||||||
|
cd $TPKG_CURRENT; exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
## LIST OR DESC OR HELP
|
||||||
|
if [ $goal = "list" -o $goal = "desc" -o $goal = "help" ]; then
|
||||||
|
$0 extract "${archive}"
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
cd $TPKG_CURRENT; exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
cd ${testname}.dir/
|
||||||
|
|
||||||
|
case $goal in
|
||||||
|
list*)
|
||||||
|
cat *
|
||||||
|
;;
|
||||||
|
desc*)
|
||||||
|
echo -n "$testname: "
|
||||||
|
cat $testname.dsc | awk -F': ?' '/^Description/ { print $2 }'
|
||||||
|
;;
|
||||||
|
help*)
|
||||||
|
if [ -f $testname.help ]; then
|
||||||
|
cat $testname.help
|
||||||
|
else
|
||||||
|
err "[warning] No help file found."
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
cd $TPKG_CURRENT
|
||||||
|
# dir can go
|
||||||
|
rm -rf ${testname}.dir; exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
trap cleanup_and_exit INT
|
||||||
|
|
||||||
|
# make a tmp dir during execution
|
||||||
|
if [ "$goal" != "exe" ]; then
|
||||||
|
err "[fatal] What do you mean with $goal?. Abort."
|
||||||
|
cd $TPKG_CURRENT; exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
mktempdir "${testname}.XXXXXX"
|
||||||
|
if [ ! -d $dir ]; then
|
||||||
|
err "[fatal] Failure to create a temporary working directory. Abort."
|
||||||
|
cd $TPKG_CURRENT; exit 1
|
||||||
|
fi
|
||||||
|
## EXTRACT
|
||||||
|
extract_tpkg_to $dir
|
||||||
|
cd $dir
|
||||||
|
|
||||||
|
### EXE ###
|
||||||
|
# extract the information out of the *.dsc files
|
||||||
|
if [ ! -f $dsc_file ]; then
|
||||||
|
err "[fatal] Can't locate the description file: $dsc_file. Abort."
|
||||||
|
cleanup; exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
SHELL=`which bash`
|
||||||
|
if [ -z ${SHELL} ]; then
|
||||||
|
SHELL=/usr/local/bin/bash
|
||||||
|
if [ ! -x $SHELL ]; then
|
||||||
|
err "[fatal] Can't find the bash shell. Abort."
|
||||||
|
cleanup; exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# check for a .done file
|
||||||
|
if [ -f "../.done-${testname}" -a $TPKG_FORCE -ne 1 ]; then
|
||||||
|
out "[log] Found .done-${testname}. Not executing this test."
|
||||||
|
cleanup; exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
# this is the template for .dsc files
|
||||||
|
# we need to check if all these files also exist TODO
|
||||||
|
dsc_basename=$testname
|
||||||
|
function get_field_from_dsc() # fieldname
|
||||||
|
{
|
||||||
|
grep "^$1: " $dsc_file | sed -e "s/^$1:[ ]*//" -e "s/[ ]*$//"
|
||||||
|
}
|
||||||
|
dsc_version=`get_field_from_dsc Version`
|
||||||
|
dsc_description=`get_field_from_dsc Description`
|
||||||
|
dsc_creationdate=`get_field_from_dsc CreationDate`
|
||||||
|
dsc_category=`get_field_from_dsc Category`
|
||||||
|
dsc_component=`get_field_from_dsc Component`
|
||||||
|
dsc_cmddepends=`get_field_from_dsc CmdDepends`
|
||||||
|
dsc_depends=`get_field_from_dsc Depends`
|
||||||
|
dsc_maintainer=`get_field_from_dsc Maintainer`
|
||||||
|
dsc_help=`get_field_from_dsc Help`
|
||||||
|
dsc_pre=`get_field_from_dsc Pre`
|
||||||
|
dsc_post=`get_field_from_dsc Post`
|
||||||
|
dsc_test=`get_field_from_dsc Test`
|
||||||
|
dsc_aux=`get_field_from_dsc AuxFiles`
|
||||||
|
dsc_passed=`get_field_from_dsc Passed`
|
||||||
|
dsc_failure=`get_field_from_dsc Failure`
|
||||||
|
|
||||||
|
# consistency check the lot
|
||||||
|
for i in $dsc_pre $dsc_post $dsc_test $dsc_help; do
|
||||||
|
if [ ! -z ${i} ]; then
|
||||||
|
if [ ! -f "${i}" ]; then
|
||||||
|
err "[fatal] File defined, but ${i} cannot be found. Abort."
|
||||||
|
cleanup; exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
for i in $dsc_pre $dsc_post $dsc_test $dsc_help; do
|
||||||
|
if [ -z ${i} ]; then
|
||||||
|
if [ -f "${i}" ]; then
|
||||||
|
err "[fatal] File not defined, but ${i} is included in the package. Abort."
|
||||||
|
cleanup; exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
# if we depend on another test to that one first and then return
|
||||||
|
for deptest in ${dsc_depends}; do
|
||||||
|
cd .. # go up one dir
|
||||||
|
out "[log] executing dependency test: ${TPKG_SRCDIR}/${deptest}"
|
||||||
|
${SHELL} $0 "-b ${TPKG_BASE}" exe "${TPKG_SRCDIR}/${deptest}"
|
||||||
|
test_result=$?
|
||||||
|
cd - > /dev/null # back where we belong
|
||||||
|
if [ $test_result -ne 0 ]; then
|
||||||
|
err "[fatal] Test depends on $deptest which failed. Abort."
|
||||||
|
cleanup; exit 1
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
# this enhances the template from above
|
||||||
|
## Post Processing of some of these variables
|
||||||
|
# dsc_aux is a comma seperated list of files, max 8 files
|
||||||
|
i=$( echo $dsc_aux | awk -F', ?' '{ print $1 "\n" $2 "\n" $3 "\n" $4 "\n" \
|
||||||
|
$5 "\n" $6 "\n" $7 "\n" $8 }' )
|
||||||
|
dsc_aux_files=($i)
|
||||||
|
dsc_aux_files_total=${#dsc_aux_files[*]}
|
||||||
|
# cmd depends
|
||||||
|
i=$( echo $dsc_cmddepends | awk -F', ?' '{ print $1 "\n" $2 "\n" $3 "\n" $4 "\n" \
|
||||||
|
$5 "\n" $6 "\n" $7 "\n" $8 }' )
|
||||||
|
dsc_cmddepends_files=($i)
|
||||||
|
dsc_cmddepends_files_total=${#dsc_cmddepends_files[*]}
|
||||||
|
|
||||||
|
for i in ${dsc_cmddepends_files[*]}; do
|
||||||
|
find_cmd $i
|
||||||
|
done
|
||||||
|
# depends can also be a comma seperated list of package
|
||||||
|
# TODO
|
||||||
|
|
||||||
|
# check is the aux files are also really in the shar
|
||||||
|
for i in ${dsc_aux_files[*]}; do
|
||||||
|
if [ ! -f $i ]; then
|
||||||
|
err "[fatal] Aux. file $i must be in the archive. Abort."
|
||||||
|
cleanup; exit 1
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
if [ ! -f $dsc_test ]; then
|
||||||
|
err "[fatal] Can't locate the test script: $dsc_test. Abort."
|
||||||
|
cleanup; exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
### Actual executing of the scripts
|
||||||
|
tpkg_log "Starting test: '$dsc_basename'"
|
||||||
|
|
||||||
|
epoch # run before pre()
|
||||||
|
echo "BaseName: $dsc_basename" > result.$dsc_basename
|
||||||
|
echo "Description: $dsc_description" >> result.$dsc_basename
|
||||||
|
echo "DateRunStart: $epoch " >> result.$dsc_basename
|
||||||
|
echo "--------------- Test Output ------------------" >> result.$dsc_basename
|
||||||
|
|
||||||
|
pre
|
||||||
|
|
||||||
|
out "[log] Executing test"
|
||||||
|
|
||||||
|
( ${SHELL} $dsc_test ${TPKG_ARGS} 2>&1 ) >> result.$dsc_basename
|
||||||
|
test_result=$?
|
||||||
|
epoch # would like to run after post, but that is not possible :-(
|
||||||
|
if [ $test_result -ne 0 ]; then
|
||||||
|
err "[warning] Test executed with errors: $test_result."
|
||||||
|
echo "!! FAILED !! !! FAILED !!" > result.$dsc_basename.tmp
|
||||||
|
echo "DateRunEnd: $epoch" >> result.$dsc_basename.tmp
|
||||||
|
err "[log] !! FAILED !!"
|
||||||
|
cat result.$dsc_basename >> result.$dsc_basename.tmp
|
||||||
|
echo "exit code: $test_result" >> result.$dsc_basename.tmp
|
||||||
|
mv result.$dsc_basename.tmp result.$dsc_basename
|
||||||
|
post;
|
||||||
|
if [ $TPKG_KEEP -eq 0 ]; then
|
||||||
|
out "[log] Removing temp directory $dir"
|
||||||
|
cleanup
|
||||||
|
else
|
||||||
|
out "[log] Keeping temp directory $dir"
|
||||||
|
fi
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
cp -f result.$dsc_basename result.$dsc_basename.$$
|
||||||
|
|
||||||
|
failed=-1 # -1 undef, 0 passed, 1 failed
|
||||||
|
## PASSED
|
||||||
|
[ ! -z "${dsc_passed}" ] && egrep "${dsc_passed}" result.$dsc_basename.$$ > /dev/null
|
||||||
|
if [ $? -eq 0 ]; then
|
||||||
|
err "[log] ** PASSED **"
|
||||||
|
echo "** PASSED ** ** PASSED **" > result.$dsc_basename.tmp
|
||||||
|
echo "DateRunEnd: $epoch" >> result.$dsc_basename.tmp
|
||||||
|
cat result.$dsc_basename >> result.$dsc_basename.tmp
|
||||||
|
echo "exit code: $test_result" >> result.$dsc_basename.tmp
|
||||||
|
mv result.$dsc_basename.tmp result.$dsc_basename
|
||||||
|
write_done
|
||||||
|
failed=0
|
||||||
|
fi
|
||||||
|
## FAILED
|
||||||
|
[ ! -z "${dsc_failure}" ] && egrep "${dsc_failure}" result.$dsc_basename.$$ > /dev/null
|
||||||
|
# if not found this actually means PASSED
|
||||||
|
if [ $? -eq 0 ]; then
|
||||||
|
err "[log] !! FAILED !!"
|
||||||
|
echo "!! FAILED !! !! FAILED !!" > result.$dsc_basename.tmp
|
||||||
|
echo "DateRunEnd: $epoch" >> result.$dsc_basename.tmp
|
||||||
|
cat result.$dsc_basename >> result.$dsc_basename.tmp
|
||||||
|
echo "exit code: $test_result" >> result.$dsc_basename.tmp
|
||||||
|
mv result.$dsc_basename.tmp result.$dsc_basename
|
||||||
|
failed=1
|
||||||
|
else
|
||||||
|
err "[log] ** PASSED **"
|
||||||
|
echo "** PASSED ** ** PASSED **" > result.$dsc_basename.tmp
|
||||||
|
echo "DateRunEnd: $epoch" >> result.$dsc_basename.tmp
|
||||||
|
cat result.$dsc_basename >> result.$dsc_basename.tmp
|
||||||
|
echo "exit code: $test_result" >> result.$dsc_basename.tmp
|
||||||
|
mv result.$dsc_basename.tmp result.$dsc_basename
|
||||||
|
write_done
|
||||||
|
failed=0
|
||||||
|
fi
|
||||||
|
|
||||||
|
## UNKNOWN
|
||||||
|
if [ $failed -eq -1 ]; then
|
||||||
|
# neither failed, not success, unknown
|
||||||
|
err "[log] -- UNKNOWN --"
|
||||||
|
echo "-- UNKNOWN -- -- UNKNOWN --" > result.$dsc_basename.tmp
|
||||||
|
echo "DateRunEnd: $epoch" >> result.$dsc_basename.tmp
|
||||||
|
cat result.$dsc_basename >> result.$dsc_basename.tmp
|
||||||
|
echo "exit code: $test_result" >> result.$dsc_basename.tmp
|
||||||
|
mv result.$dsc_basename.tmp result.$dsc_basename
|
||||||
|
write_done
|
||||||
|
failed=1 # not passed
|
||||||
|
fi
|
||||||
|
|
||||||
|
post
|
||||||
|
if [ $TPKG_KEEP -eq 0 ]; then
|
||||||
|
out "[log] Removing temp directory $dir"
|
||||||
|
cleanup
|
||||||
|
else
|
||||||
|
out "[log] Keeping temp directory $dir"
|
||||||
|
fi
|
||||||
|
exit $failed
|
Loading…
Reference in New Issue