setup a bit of a test framework

This commit is contained in:
Mike Frysinger 2008-03-24 07:17:05 +00:00
parent 1c9c2f9fcf
commit 486d517674
7 changed files with 58 additions and 11 deletions

View File

@ -43,6 +43,7 @@ realinstall: ${BIN} ${CONF} ${CONF_APPEND}
install: all realinstall ${INSTALLAFTER} install: all realinstall ${INSTALLAFTER}
check test:: check test::
@if test -e runtests.sh ; then ./runtests.sh || exit $$? ; fi
# A lot of scripts don't have anything to clean # A lot of scripts don't have anything to clean
# Also, some rm implentation require a file argument regardless of error # Also, some rm implentation require a file argument regardless of error

View File

@ -18,3 +18,6 @@ _installafter:
@# Put functions.sh into the init.d dir so 3rd party apps don't have to @# Put functions.sh into the init.d dir so 3rd party apps don't have to
@# be multilib aware @# be multilib aware
ln -snf ${PREFIX}/${RC_LIB}/sh/functions.sh ${DESTDIR}/${PREFIX}/${INITDIR} || exit $$? ln -snf ${PREFIX}/${RC_LIB}/sh/functions.sh ${DESTDIR}/${PREFIX}/${INITDIR} || exit $$?
check test::
./runtests.sh

25
sh/runtests.sh Executable file
View File

@ -0,0 +1,25 @@
#!/bin/sh
top_srcdir=${top_srcdir:-..}
. ${top_srcdir}/test/setup_env.sh
ret=0
tret=0
ebegin "Testing yesno()"
for f in yes YES Yes true TRUE True 1 ; do
if ! yesno ${f} ; then
((tret+=1))
echo "!${f}!"
fi
done
for f in no NO No false FALSE False 0 ; do
if yesno ${f} ; then
((tret+=1))
echo "!${f}!"
fi
done
eend ${tret}
((ret+=tret))
exit ${ret}

View File

@ -3,7 +3,7 @@ all:
install: install:
check test:: check test::
./symbols.sh ./runtests.sh
clean: clean:
rm -f *.out rm -f *.out

View File

@ -1,11 +1,7 @@
#!/bin/sh #!/bin/sh
top_srcdir=${top_srcdir:-../..} top_srcdir=${top_srcdir:-../..}
srcdir=${builddir:-.} . ${top_srcdir}/test/setup_env.sh
top_builddir=${top_srcdir:-../..}
builddir=${builddir:-.}
. ${top_srcdir}/sh/functions.sh
libeinfo_srcdir="${srcdir}/../libeinfo" libeinfo_srcdir="${srcdir}/../libeinfo"
libeinfo_builddir="${builddir}/../libeinfo" libeinfo_builddir="${builddir}/../libeinfo"
@ -14,11 +10,6 @@ librc_builddir="${builddir}/../librc"
rc_srcdir="${srcdir}/../rc" rc_srcdir="${srcdir}/../rc"
rc_builddir="${builddir}/../rc" rc_builddir="${builddir}/../rc"
make -s -C ${rc_builddir} links
export LD_LIBRARY_PATH=${libeinfo_builddir}:${librc_builddir}:${LD_LIBRARY_PATH}
export PATH=${rc_builddir}:${PATH}
checkit() { checkit() {
local base=$1; shift local base=$1; shift
echo "$@" | tr ' ' '\n' > ${base}.out echo "$@" | tr ' ' '\n' > ${base}.out

22
test/setup_env.sh Executable file
View File

@ -0,0 +1,22 @@
#!/bin/sh
if [ -z "${top_srcdir}" ] ; then
echo "You must set top_srcdir before sourcing this file" 1>&2
exit 1
fi
srcdir=${srcdir:-.}
top_builddir=${top_builddir:-${top_srcdir}}
builddir=${builddir:-${srcdir}}
export LD_LIBRARY_PATH=${top_builddir}/src/libeinfo:${top_builddir}/src/librc:${LD_LIBRARY_PATH}
export PATH=${top_builddir}/src/rc:${PATH}
${MAKE:-make} -s -C ${top_srcdir}/src/rc links
. ${top_srcdir}/sh/functions.sh
if [ $? -ne 0 ] ; then
echo "Sourcing functions.sh failed !?" 1>&2
exit 1
fi

5
test/skel.runtests.sh Executable file
View File

@ -0,0 +1,5 @@
#!/bin/sh
# top_srcdir=${top_srcdir:-SET/THIS/PATH/OK!?}
. ${top_srcdir}/test/setup_env.sh