]> arthur.barton.de Git - ngircd-alex.git/blobdiff - src/testsuite/start-server.sh
Don't use a POSIX thread for the Howl "run loop".
[ngircd-alex.git] / src / testsuite / start-server.sh
index 51de410ec4f2aa49e5bcd5ddda13f007153089c8..8d6c650674d183706bd97ff66e69df107c5311b5 100755 (executable)
@@ -1,17 +1,44 @@
 #!/bin/sh
 # ngIRCd Test Suite
-# $Id: start-server.sh,v 1.2 2002/09/09 22:56:07 alex Exp $
+# $Id: start-server.sh,v 1.14 2004/09/06 22:04:06 alex Exp $
 
-echo "      starting server ..."
+[ -z "$srcdir" ] && srcdir=`dirname $0`
 
+# read in functions
+. ${srcdir}/functions.inc
+
+echo_n "      starting server ..."
+
+# remove old logfiles
+rm -rf logs *.log
+
+# check weather getpid.sh returns valid PIDs. If not, don't start up the
+# test-server, because we won't be able to kill it at the end of the test.
+./getpid.sh sh > /dev/null 2>&1
+if [ $? -ne 0 ]; then
+  echo " getpid.sh failed!"
+  exit 1
+fi
+
+# check if there is a test-server already running
+./getpid.sh T-ngircd > /dev/null 2>&1
+if [ $? -eq 0 ]; then
+  echo " failure: test-server already running!"
+  exit 1
+fi
+
+# generate MOTD for test-server
 echo "This is an ngIRCd Test Server" > ngircd-test.motd
 
-../ngircd/ngircd -np -f ngircd-test.conf > ngircd-test.log 2>&1 &
+# starting up test-server ...
+./T-ngircd -np -f ${srcdir}/ngircd-test.conf $* > ngircd-test.log 2>&1 &
 sleep 1
 
-pid=`ps a | grep ngircd-test | head -n 1 | cut -d ' ' -f 1`
-kill -0 $pid > /dev/null 2>&1
+# validate running test-server
+pid=`./getpid.sh T-ngircd`
+[ -n "$pid" ] && kill -0 $pid > /dev/null 2>&1; r=$?
 
-rm -rf logs
+[ $r -eq 0 ] && echo " ok." || echo " failure!"
+exit 
 
 # -eof-