4 echo "$0 <directory> <all | quick> <smbtorture4>"
12 ## create the test directory
14 PREFIX=`echo $1 | sed s+//+/+`
15 mkdir -p $PREFIX || exit $?
18 export PREFIX_ABS=`pwd`
21 if [ -z "$TORTURE_MAXTIME" ]; then
24 export TORTURE_MAXTIME
27 ## setup the various environment variables we need
36 SCRIPTDIR=$SRCDIR/script/tests
37 SHRDIR=$PREFIX_ABS/tmp
38 LIBDIR=$PREFIX_ABS/lib
39 PIDDIR=$PREFIX_ABS/pid
40 CONFFILE=$LIBDIR/client.conf
41 SERVERCONFFILE=$LIBDIR/server.conf
42 COMMONCONFFILE=$LIBDIR/common.conf
43 PRIVATEDIR=$PREFIX_ABS/private
44 LOCKDIR=$PREFIX_ABS/lockdir
45 LOGDIR=$PREFIX_ABS/logs
46 SOCKET_WRAPPER_DIR=$PREFIX/sw
47 CONFIGURATION="-s $CONFFILE"
49 export PREFIX_ABS CONFIGURATION CONFFILE PATH SOCKET_WRAPPER_DIR DOMAIN
50 export PRIVATEDIR LIBDIR PIDDIR LOCKDIR LOGDIR SERVERCONFFILE
51 export SRCDIR SCRIPTDIR
52 export USERNAME PASSWORD
54 export SERVER SERVER_IP
60 ## verify that we were built with --enable-socket-wrapper
63 if test "x`smbd -b | grep SOCKET_WRAPPER`" = "x"; then
65 echo "*** You must include --enable-socket-wrapper when compiling Samba"
66 echo "*** in order to execute 'make test'. Exiting...."
72 ## create the test directory layout
74 echo -n "CREATE TEST ENVIRONMENT IN '$PREFIX'"...
76 mkdir -p $PRIVATEDIR $LIBDIR $PIDDIR $LOCKDIR $LOGDIR $SOCKET_WRAPPER_DIR
77 mkdir -p $PREFIX_ABS/tmp
78 chmod 777 $PREFIX_ABS/tmp
81 ## Create the common config include file with the basic settings
84 cat >$COMMONCONFFILE<<EOF
85 workgroup = SAMBA-TEST
87 private dir = $PRIVATEDIR
88 pid directory = $PIDDIR
89 lock directory = $LOCKDIR
90 log file = $LOGDIR/log.%m
93 passdb backend = tdbsam
95 name resolve order = bcast
97 panic action = $SCRIPTDIR/gdb_backtrace %d
102 netbios name = TORTURE26
103 interfaces = 127.0.0.26/8
104 include = $COMMONCONFFILE
107 cat >$SERVERCONFFILE<<EOF
109 netbios name = $SERVER
110 interfaces = $SERVER_IP/8
111 bind interfaces only = yes
112 include = $COMMONCONFFILE
115 path = $PREFIX_ABS/tmp
117 smbd:sharedelay = 100000
122 ## create a test account
125 (echo $PASSWORD; echo $PASSWORD) | \
126 smbpasswd -c $CONFFILE -L -s -a $USERNAME >/dev/null || exit 1
130 if [ x"$RUN_FROM_BUILD_FARM" = x"yes" ];then
131 CONFIGURATION="$CONFIGURATION --option=\"torture:progress=no\""
134 SERVER_TEST_FIFO="$PREFIX/server_test.fifo"
135 export SERVER_TEST_FIFO
136 NMBD_TEST_LOG="$PREFIX/nmbd_test.log"
138 SMBD_TEST_LOG="$PREFIX/smbd_test.log"
141 # start off with 0 failures
145 . $SCRIPTDIR/test_functions.sh
147 SOCKET_WRAPPER_DEFAULT_IFACE=2
148 export SOCKET_WRAPPER_DEFAULT_IFACE
149 samba3_check_or_start
151 # ensure any one smbtorture call doesn't run too long
152 # and smbtorture will use 127.0.0.26 as source address by default
153 SOCKET_WRAPPER_DEFAULT_IFACE=26
154 export SOCKET_WRAPPER_DEFAULT_IFACE
155 TORTURE4_INTERFACES='127.0.0.26/8,127.0.0.27/8,127.0.0.28/8,127.0.0.29/8,127.0.0.30/8,127.0.0.31/8'
156 TORTURE4_OPTIONS="--maximum-runtime=$TORTURE_MAXTIME --option=interfaces=$TORTURE4_INTERFACES $CONFIGURATION"
157 export TORTURE4_OPTIONS
159 if [ x"$RUN_FROM_BUILD_FARM" = x"yes" ];then
160 TORTURE4_OPTIONS="$TORTURE4_OPTIONS --option=torture:progress=no"
163 TORTURE4_OPTIONS="$TORTURE4_OPTIONS --option=target:samba3=yes"
166 ## ready to go...now loop through the tests
171 # give time for nbt server to register its names
172 echo "delaying for nbt name registration"
174 # This will return quickly when things are up, but be slow if we need to wait for (eg) SSL init
175 bin/nmblookup $CONFIGURATION -U $SERVER_IP __SAMBA__
176 bin/nmblookup $CONFIGURATION __SAMBA__
177 bin/nmblookup $CONFIGURATION -U 127.255.255.255 __SAMBA__
178 bin/nmblookup $CONFIGURATION -U $SERVER_IP $SERVER
179 bin/nmblookup $CONFIGURATION $SERVER
180 # make sure smbd is also up set
182 bin/smbclient $CONFIGURATION -L $SERVER_IP -N -p 139 | head -2
183 bin/smbclient $CONFIGURATION -L $SERVER_IP -N -p 139 | head -2
187 . $SCRIPTDIR/tests_$TESTS.sh
195 echo "START: $START ($0)";
196 echo "END: $END ($0)";
198 # if there were any valgrind failures, show them
199 count=`find $PREFIX -name 'valgrind.log*' | wc -l`
200 if [ "$count" != 0 ]; then
201 for f in $PREFIX/valgrind.log*; do
203 echo "VALGRIND FAILURE";
204 failed=`expr $failed + 1`
213 teststatus $0 $failed