Test: Properly track current test binary for tracking crashes.
[ira/wip.git] / source3 / script / tests / selftest.sh
1 #!/bin/sh
2
3 if [ $# != 3 ]; then
4         echo "$0 <directory> <all | quick> <smbtorture4>"
5         exit 1
6 fi
7
8 SMBTORTURE4=$3
9 TESTS=$2
10
11 ##
12 ## create the test directory
13 ##
14 PREFIX=`echo $1 | sed s+//+/+`
15 mkdir -p $PREFIX || exit $?
16 OLD_PWD=`pwd`
17 cd $PREFIX || exit $?
18 PREFIX_ABS=`pwd`
19 cd $OLD_PWD
20
21 if [ -z "$TORTURE_MAXTIME" ]; then
22     TORTURE_MAXTIME=300
23 fi
24 export TORTURE_MAXTIME
25
26 ##
27 ## setup the various environment variables we need
28 ##
29
30 WORKGROUP=SAMBA-TEST
31 SERVER=localhost2
32 SERVER_IP=127.0.0.2
33 USERNAME=`PATH=/usr/ucb:$PATH whoami`
34 USERID=`PATH=/usr/ucb:$PATH id | cut -d ' ' -f1 | sed -e 's/uid=\([0-9]*\).*/\1/g'`
35 GROUPID=`PATH=/usr/ucb:$PATH id | cut -d ' ' -f2 | sed -e 's/gid=\([0-9]*\).*/\1/g'`
36 PASSWORD=test
37
38 SRCDIR="`dirname $0`/../.."
39 BINDIR="`pwd`/bin"
40 SCRIPTDIR=$SRCDIR/script/tests
41 SHRDIR=$PREFIX_ABS/tmp
42 LIBDIR=$PREFIX_ABS/lib
43 PIDDIR=$PREFIX_ABS/pid
44 CONFFILE=$LIBDIR/client.conf
45 SAMBA4CONFFILE=$LIBDIR/samba4client.conf
46 SERVERCONFFILE=$LIBDIR/server.conf
47 COMMONCONFFILE=$LIBDIR/common.conf
48 PRIVATEDIR=$PREFIX_ABS/private
49 LOCKDIR=$PREFIX_ABS/lockdir
50 LOGDIR=$PREFIX_ABS/logs
51 SOCKET_WRAPPER_DIR=$PREFIX/sw
52 CONFIGURATION="--configfile $CONFFILE"
53 SAMBA4CONFIGURATION="-s $SAMBA4CONFFILE"
54 NSS_WRAPPER_PASSWD="$PRIVATEDIR/passwd"
55 NSS_WRAPPER_GROUP="$PRIVATEDIR/group"
56 WINBINDD_SOCKET_DIR=$PREFIX_ABS/winbindd
57 WINBINDD_PRIV_PIPE_DIR=$LOCKDIR/winbindd_privileged
58
59 export PREFIX PREFIX_ABS
60 export CONFIGURATION CONFFILE SAMBA4CONFIGURATION SAMBA4CONFFILE
61 export PATH SOCKET_WRAPPER_DIR DOMAIN
62 export PRIVATEDIR LIBDIR PIDDIR LOCKDIR LOGDIR SERVERCONFFILE
63 export SRCDIR SCRIPTDIR BINDIR
64 export USERNAME PASSWORD
65 export WORKGROUP SERVER SERVER_IP
66 export NSS_WRAPPER_PASSWD NSS_WRAPPER_GROUP
67 export WINBINDD_SOCKET_DIR WINBINDD_PRIV_PIPE_DIR
68
69 PATH=bin:$PATH
70 export PATH
71
72 if test x"$LD_LIBRARY_PATH" != x""; then
73         LD_LIBRARY_PATH="$BINDIR:$LD_LIBRARY_PATH"
74 else
75         LD_LIBRARY_PATH="$BINDIR"
76 fi
77 echo "LD_LIBRARY_PATH=$LD_LIBRARY_PATH"
78 export LD_LIBRARY_PATH
79
80 SAMBA4BINDIR=`dirname $SMBTORTURE4`
81 SAMBA4SHAREDDIR="$SAMBA4BINDIR/shared"
82
83 export SAMBA4SHAREDDIR
84 export SMBTORTURE4
85
86 ##
87 ## verify that we were built with --enable-socket-wrapper
88 ##
89
90 if test "x`smbd -b | grep SOCKET_WRAPPER`" = "x"; then
91         echo "***"
92         echo "*** You must include --enable-socket-wrapper when compiling Samba"
93         echo "*** in order to execute 'make test'.  Exiting...."
94         echo "***"
95         exit 1
96 fi
97
98 if test "x`smbd -b | grep NSS_WRAPPER`" = "x"; then
99         echo "***"
100         echo "*** You must include --enable-nss-wrapper when compiling Samba"
101         echo "*** in order to execute 'make test'.  Exiting...."
102         echo "***"
103         exit 1
104 fi
105
106
107 ## 
108 ## create the test directory layout
109 ##
110 echo -n "CREATE TEST ENVIRONMENT IN '$PREFIX'"...
111 /bin/rm -rf $PREFIX/*
112 mkdir -p $PRIVATEDIR $LIBDIR $PIDDIR $LOCKDIR $LOGDIR
113 mkdir -p $SOCKET_WRAPPER_DIR
114 mkdir -p $WINBINDD_SOCKET_DIR
115 chmod 755 $WINBINDD_SOCKET_DIR
116 mkdir -p $PREFIX_ABS/tmp
117 chmod 777 $PREFIX_ABS/tmp
118
119 ##
120 ## Create the common config include file with the basic settings
121 ##
122
123 cat >$COMMONCONFFILE<<EOF
124         workgroup = $WORKGROUP
125
126         private dir = $PRIVATEDIR
127         pid directory = $PIDDIR
128         lock directory = $LOCKDIR
129         log file = $LOGDIR/log.%m
130         log level = 0
131
132         name resolve order = bcast
133 EOF
134
135 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'
136
137 cat >$CONFFILE<<EOF
138 [global]
139         netbios name = TORTURE_6
140         interfaces = $TORTURE_INTERFACES
141         panic action = $SCRIPTDIR/gdb_backtrace %d %\$(MAKE_TEST_BINARY)
142         include = $COMMONCONFFILE
143
144         passdb backend = tdbsam
145 EOF
146
147 cat >$SAMBA4CONFFILE<<EOF
148 [global]
149         netbios name = TORTURE_6
150         interfaces = $TORTURE_INTERFACES
151         panic action = $SCRIPTDIR/gdb_backtrace %PID% %PROG%
152         include = $COMMONCONFFILE
153 EOF
154
155 cat >$SERVERCONFFILE<<EOF
156 [global]
157         netbios name = $SERVER
158         interfaces = $SERVER_IP/8
159         bind interfaces only = yes
160         panic action = $SCRIPTDIR/gdb_backtrace %d %\$(MAKE_TEST_BINARY)
161         include = $COMMONCONFFILE
162
163         passdb backend = tdbsam
164
165         add user script = $PERL $SRCDIR/lib/nss_wrapper/nss_wrapper.pl --path $NSS_WRAPPER_PASSWD --type passwd --action add --name %u
166         add machine script = $PERL $SRCDIR/lib/nss_wrapper/nss_wrapper.pl --path $NSS_WRAPPER_PASSWD --type passwd --action add --name %u
167         delete user script = $PERL $SRCDIR/lib/nss_wrapper/nss_wrapper.pl --path $NSS_WRAPPER_PASSWD --type passwd --action delete --name %u
168
169         kernel oplocks = no
170         kernel change notify = no
171
172         syslog = no
173         printing = bsd
174         printcap name = /dev/null
175
176         winbindd:socket dir = $WINBINDD_SOCKET_DIR
177         idmap uid = 100000-200000
178         idmap gid = 100000-200000
179
180 #       min receivefile size = 4000
181
182 [tmp]
183         path = $PREFIX_ABS/tmp
184         read only = no
185         smbd:sharedelay = 100000
186         map hidden = yes
187         map system = yes
188         create mask = 755
189         vfs objects = $BINDIR/xattr_tdb.so $BINDIR/streams_xattr.so
190 [hideunread]
191         copy = tmp
192         hide unreadable = yes
193 [hideunwrite]
194         copy = tmp
195         hide unwriteable files = yes
196 [print1]
197         copy = tmp
198         printable = yes
199         printing = test
200 [print2]
201         copy = print1
202 [print3]
203         copy = print1
204 [print4]
205         copy = print1
206 EOF
207
208 ##
209 ## create a test account
210 ##
211
212 cat >$NSS_WRAPPER_PASSWD<<EOF
213 nobody:x:65534:65533:nobody gecos:$PREFIX_ABS:/bin/false
214 $USERNAME:x:$USERID:$GROUPID:$USERNAME gecos:$PREFIX_ABS:/bin/false
215 EOF
216
217 cat >$NSS_WRAPPER_GROUP<<EOF
218 nobody:x:65533:
219 nogroup:x:65534:nobody
220 $USERNAME-group:x:$GROUPID:
221 EOF
222
223 MAKE_TEST_BINARY="bin/smbpasswd"
224 export MAKE_TEST_BINARY
225
226 (echo $PASSWORD; echo $PASSWORD) | \
227         bin/smbpasswd -c $CONFFILE -L -s -a $USERNAME >/dev/null || exit 1
228
229 echo "DONE";
230
231 MAKE_TEST_BINARY=""
232
233 SERVER_TEST_FIFO="$PREFIX/server_test.fifo"
234 export SERVER_TEST_FIFO
235 NMBD_TEST_LOG="$PREFIX/nmbd_test.log"
236 export NMBD_TEST_LOG
237 WINBINDD_TEST_LOG="$PREFIX/winbindd_test.log"
238 export WINBINDD_TEST_LOG
239 SMBD_TEST_LOG="$PREFIX/smbd_test.log"
240 export SMBD_TEST_LOG
241
242 # start off with 0 failures
243 failed=0
244 export failed
245
246 . $SCRIPTDIR/test_functions.sh
247
248 SOCKET_WRAPPER_DEFAULT_IFACE=2
249 export SOCKET_WRAPPER_DEFAULT_IFACE
250 samba3_check_or_start
251
252 # ensure any one smbtorture call doesn't run too long
253 # and smbtorture will use 127.0.0.6 as source address by default
254 SOCKET_WRAPPER_DEFAULT_IFACE=6
255 export SOCKET_WRAPPER_DEFAULT_IFACE
256 TORTURE4_OPTIONS="$SAMBA4CONFIGURATION"
257 TORTURE4_OPTIONS="$TORTURE4_OPTIONS --maximum-runtime=$TORTURE_MAXTIME"
258 TORTURE4_OPTIONS="$TORTURE4_OPTIONS --target=samba3"
259 TORTURE4_OPTIONS="$TORTURE4_OPTIONS --option=torture:localdir=$PREFIX_ABS/tmp"
260 export TORTURE4_OPTIONS
261
262 if [ x"$RUN_FROM_BUILD_FARM" = x"yes" ];then
263         TORTURE4_OPTIONS="$TORTURE4_OPTIONS --option=torture:progress=no"
264 fi
265
266
267 ##
268 ## ready to go...now loop through the tests
269 ##
270
271 START=`date`
272 (
273  # give time for nbt server to register its names
274  echo "delaying for nbt name registration"
275  sleep 10
276  # This will return quickly when things are up, but be slow if we need to wait for (eg) SSL init 
277  MAKE_TEST_BINARY="bin/nmblookup"
278  bin/nmblookup $CONFIGURATION -U $SERVER_IP __SAMBA__
279  bin/nmblookup $CONFIGURATION __SAMBA__
280  bin/nmblookup $CONFIGURATION -U 127.255.255.255 __SAMBA__
281  bin/nmblookup $CONFIGURATION -U $SERVER_IP $SERVER
282  bin/nmblookup $CONFIGURATION $SERVER
283  # make sure smbd is also up set
284  echo "wait for smbd"
285  MAKE_TEST_BINARY="bin/smbclient"
286  bin/smbclient $CONFIGURATION -L $SERVER_IP -U% -p 139 | head -2
287  bin/smbclient $CONFIGURATION -L $SERVER_IP -U% -p 139 | head -2
288  MAKE_TEST_BINARY=""
289
290  failed=0
291
292  . $SCRIPTDIR/tests_$TESTS.sh
293  exit $failed
294 )
295 failed=$?
296
297 samba3_stop_sig_term
298
299 END=`date`
300 echo "START: $START ($0)";
301 echo "END:   $END ($0)";
302
303 # if there were any valgrind failures, show them
304 count=`find $PREFIX -name 'valgrind.log*' | wc -l`
305 if [ "$count" != 0 ]; then
306     for f in $PREFIX/valgrind.log*; do
307         if [ -s $f ]; then
308             echo "VALGRIND FAILURE";
309             failed=`expr $failed + 1`
310             cat $f
311         fi
312     done
313 fi
314
315 sleep 2
316 samba3_stop_sig_kill
317
318 teststatus $0 $failed