r18917: having 255 virtual interfaces available in socket wrapper means we
[ira/wip.git] / source / script / tests / selftest.sh
1 #!/bin/sh
2 # Bootstrap Samba and run a number of tests against it.
3
4 if [ $# -lt 1 ]
5 then
6         echo "$0 PREFIX TESTS"
7         exit
8 fi
9
10 ARG0=$0
11 ARG1=$1
12 ARG2=$2
13 ARG3=$3
14
15 if [ -z "$TORTURE_MAXTIME" ]; then
16     TORTURE_MAXTIME=1200
17 fi
18
19 # disable rpc validation when using valgrind - its way too slow
20 if [ -z "$VALGRIND" ]; then
21     VALIDATE="validate";
22 else
23     VALIDATE="";
24 fi
25
26 OLD_PWD=`pwd`
27 PREFIX=$ARG1
28 PREFIX=`echo $PREFIX | sed s+//+/+`
29 export PREFIX
30
31 # allow selection of the test lists
32 TESTS=$ARG2
33
34 if [ $TESTS = "all" ]; then
35     TLS_ENABLED="yes"
36 else
37     TLS_ENABLED="no"
38 fi
39 export TLS_ENABLED
40
41 LD_LIBRARY_PATH=$OLD_PWD/bin:$LD_LIBRARY_PATH
42 export LD_LIBRARY_PATH
43
44 incdir=`dirname $ARG0`
45 echo -n "PROVISIONING..."
46 . $incdir/mktestsetup.sh $PREFIX || exit 1
47 echo "DONE"
48
49 PATH=bin:$PATH
50 export PATH
51
52 DO_SOCKET_WRAPPER=$ARG3
53 if [ x"$DO_SOCKET_WRAPPER" = x"SOCKET_WRAPPER" ];then
54         SOCKET_WRAPPER_DIR="$PREFIX/w"
55         export SOCKET_WRAPPER_DIR
56         echo "SOCKET_WRAPPER_DIR=$SOCKET_WRAPPER_DIR"
57 else
58         echo "NOT USING SOCKET_WRAPPER"
59 fi
60
61 incdir=`dirname $ARG0`
62 . $incdir/test_functions.sh
63
64 #Start slapd before smbd
65 if [ x"$TEST_LDAP" = x"yes" ]; then
66     slapd_start || exit 1;
67     echo -n "LDAP PROVISIONING..."
68     $srcdir/bin/smbscript $srcdir/setup/provision $PROVISION_OPTIONS --ldap-backend=$LDAPI || {
69         echo "LDAP PROVISIONING failed: $srcdir/bin/smbscript $srcdir/setup/provision $PROVISION_OPTIONS --ldap-backend=$LDAPI"
70         exit 1;
71     }
72 fi
73
74 SMBD_TEST_FIFO="$PREFIX/smbd_test.fifo"
75 export SMBD_TEST_FIFO
76 SMBD_TEST_LOG="$PREFIX/smbd_test.log"
77 export SMBD_TEST_LOG
78
79 SOCKET_WRAPPER_DEFAULT_IFACE=1
80 export SOCKET_WRAPPER_DEFAULT_IFACE
81 smbd_check_or_start
82
83 SOCKET_WRAPPER_DEFAULT_IFACE=6
84 export SOCKET_WRAPPER_DEFAULT_IFACE
85 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'
86 TORTURE_OPTIONS="--option=interfaces=$TORTURE_INTERFACES $CONFIGURATION"
87 # ensure any one smbtorture call doesn't run too long
88 TORTURE_OPTIONS="$TORTURE_OPTIONS --maximum-runtime=$TORTURE_MAXTIME"
89 TORTURE_OPTIONS="$TORTURE_OPTIONS --target=samba4"
90 export TORTURE_OPTIONS
91
92 if [ x"$RUN_FROM_BUILD_FARM" = x"yes" ];then
93         TORTURE_OPTIONS="$TORTURE_OPTIONS --option=torture:progress=no"
94 fi
95
96 START=`date`
97 (
98  # give time for nbt server to register its names
99  echo delaying for nbt name registration
100  sleep 4
101  # This will return quickly when things are up, but be slow if we need to wait for (eg) SSL init 
102  bin/nmblookup $CONFIGURATION $SERVER
103  bin/nmblookup $CONFIGURATION -U $SERVER $SERVER
104  bin/nmblookup $CONFIGURATION $SERVER
105  bin/nmblookup $CONFIGURATION -U $SERVER $NETBIOSNAME
106  bin/nmblookup $CONFIGURATION $NETBIOSNAME
107  bin/nmblookup $CONFIGURATION -U $SERVER $NETBIOSNAME
108
109 # start off with 0 failures
110 failed=0
111 export failed
112 totalfailed=0
113 export totalfailed
114
115  . script/tests/tests_$TESTS.sh
116  exit $totalfailed
117 ) 9>$SMBD_TEST_FIFO
118 failed=$?
119
120 kill `cat $PIDDIR/smbd.pid`
121
122 if [ "$TEST_LDAP"x = "yesx" ]; then
123     kill `cat $PIDDIR/slapd.pid`
124 fi
125
126 END=`date`
127 echo "START: $START ($ARG0)";
128 echo "END:   $END ($ARG0)";
129
130 # if there were any valgrind failures, show them
131 count=`find $PREFIX -name 'valgrind.log*' | wc -l`
132 if [ "$count" != 0 ]; then
133     for f in $PREFIX/valgrind.log*; do
134         if [ -s $f ] && grep -v DWARF2.CFI.reader $f > /dev/null; then
135             echo "VALGRIND FAILURE";
136             failed=`expr $failed + 1`
137             cat $f
138         fi
139     done
140 fi
141
142 teststatus $ARG0 $failed