2 # Bootstrap Samba and run a number of tests against it.
15 if [ -z "$TORTURE_MAXTIME" ]; then
19 # disable rpc validation when using valgrind - its way too slow
20 if [ -z "$VALGRIND" ]; then
28 PREFIX
=`echo $PREFIX | sed s+//+/+`
31 # allow selection of the test lists
34 if [ $TESTS = "all" ]; then
41 LD_LDB_MODULE_PATH
=$OLD_PWD/bin
/modules
/ldb
42 export LD_LDB_MODULE_PATH
44 LD_SAMBA_MODULE_PATH
=$OLD_PWD/bin
/modules
45 export LD_SAMBA_MODULE_PATH
47 LD_LIBRARY_PATH
=$OLD_PWD/bin
:$LD_LIBRARY_PATH
48 export LD_LIBRARY_PATH
50 incdir
=`dirname $ARG0`
51 echo -n "PROVISIONING..."
52 .
$incdir/mktestsetup.sh
$PREFIX ||
exit 1
58 DO_SOCKET_WRAPPER
=$ARG3
59 if [ x
"$DO_SOCKET_WRAPPER" = x
"SOCKET_WRAPPER" ];then
60 SOCKET_WRAPPER_DIR
="$PREFIX/w"
61 export SOCKET_WRAPPER_DIR
62 echo "SOCKET_WRAPPER_DIR=$SOCKET_WRAPPER_DIR"
64 echo "NOT USING SOCKET_WRAPPER"
67 incdir
=`dirname $ARG0`
68 .
$incdir/test_functions.sh
70 #Start slapd before smbd
71 if [ x
"$TEST_LDAP" = x
"yes" ]; then
72 slapd_start ||
exit 1;
73 echo -n "LDAP PROVISIONING..."
74 $srcdir/bin
/smbscript
$srcdir/setup
/provision
$PROVISION_OPTIONS --ldap-backend=$LDAPI ||
{
75 echo "LDAP PROVISIONING failed: $srcdir/bin/smbscript $srcdir/setup/provision $PROVISION_OPTIONS --ldap-backend=$LDAPI"
79 TORTURE_MAXTIME
=`expr $TORTURE_MAXTIME '*' 2`
82 SMBD_TEST_FIFO
="$PREFIX/smbd_test.fifo"
84 SMBD_TEST_LOG
="$PREFIX/smbd_test.log"
87 SOCKET_WRAPPER_DEFAULT_IFACE
=1
88 export SOCKET_WRAPPER_DEFAULT_IFACE
91 SOCKET_WRAPPER_DEFAULT_IFACE
=6
92 export SOCKET_WRAPPER_DEFAULT_IFACE
93 TORTURE_INTERFACES
='127.0.0.6/8,127.0.0.7/8,127.0.0.8/8,127.0.0.9/8,127.0.0.10/8,127.0.0.11/8'
94 TORTURE_OPTIONS
="--option=interfaces=$TORTURE_INTERFACES $CONFIGURATION"
95 # ensure any one smbtorture call doesn't run too long
96 TORTURE_OPTIONS
="$TORTURE_OPTIONS --maximum-runtime=$TORTURE_MAXTIME"
97 TORTURE_OPTIONS
="$TORTURE_OPTIONS --target=samba4"
98 export TORTURE_OPTIONS
100 if [ x
"$RUN_FROM_BUILD_FARM" = x
"yes" ];then
101 TORTURE_OPTIONS
="$TORTURE_OPTIONS --option=torture:progress=no"
106 # give time for nbt server to register its names
107 echo delaying
for nbt name registration
109 # This will return quickly when things are up, but be slow if we need to wait for (eg) SSL init
110 bin
/nmblookup
$CONFIGURATION $SERVER
111 bin
/nmblookup
$CONFIGURATION -U $SERVER $SERVER
112 bin
/nmblookup
$CONFIGURATION $SERVER
113 bin
/nmblookup
$CONFIGURATION -U $SERVER $NETBIOSNAME
114 bin
/nmblookup
$CONFIGURATION $NETBIOSNAME
115 bin
/nmblookup
$CONFIGURATION -U $SERVER $NETBIOSNAME
117 # start off with 0 failures
123 . script
/tests
/tests_
$TESTS.sh
128 kill `cat $PIDDIR/smbd.pid`
130 if [ "$TEST_LDAP"x
= "yesx" ]; then
131 kill `cat $PIDDIR/slapd.pid`
135 echo "START: $START ($ARG0)";
136 echo "END: $END ($ARG0)";
138 # if there were any valgrind failures, show them
139 count
=`find $PREFIX -name 'valgrind.log*' | wc -l`
140 if [ "$count" != 0 ]; then
141 for f
in $PREFIX/valgrind.log
*; do
142 if [ -s $f ] && grep -v DWARF2.CFI.reader
$f > /dev
/null
; then
143 echo "VALGRIND FAILURE";
144 failed
=`expr $failed + 1`
150 teststatus
$ARG0 $failed