X-Git-Url: https://arthur.barton.de/cgi-bin/gitweb.cgi?p=ngircd-alex.git;a=blobdiff_plain;f=contrib%2Fplatformtest.sh;h=7f7e6b476bf7d13771d28fe528e12a4a77c516cb;hp=76f4169c70843ffb0ba88b5effe94101bd949545;hb=804c2403203258ba8b9bf869be3f9ef057c2d39a;hpb=e2b85ccde360ccc389afb0af12d5d75f0549f666 diff --git a/contrib/platformtest.sh b/contrib/platformtest.sh index 76f4169c..7f7e6b47 100755 --- a/contrib/platformtest.sh +++ b/contrib/platformtest.sh @@ -1,7 +1,7 @@ #!/bin/sh # # ngIRCd -- The Next Generation IRC Daemon -# Copyright (c)2001-2014 Alexander Barton (alex@barton.de) and Contributors +# Copyright (c)2001-2016 Alexander Barton (alex@barton.de) and Contributors # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -14,20 +14,25 @@ # suitable for inclusion in doc/Platforms.txt -- please send reports # to the ngIRCd mailing list: . -NAME=`basename "$0"` +NAME=$(basename "$0") VERBOSE= +CLEAN=1 PLATFORM= COMPILER="unknown" VERSION="unknown" -DATE=`date "+%y-%m-%d"` +DATE=$(date "+%y-%m-%d") COMMENT= R_CONFIGURE= R_MAKE= R_CHECK= +R_CHECK_Y="?" R_RUN= +SRC_D=$(dirname "$0") +MY_D="$PWD" + [ -n "$MAKE" ] || MAKE="make" export MAKE CC @@ -36,54 +41,95 @@ while [ $# -gt 0 ]; do "-v") VERBOSE=1 ;; + "-x") + CLEAN= + ;; *) - echo "Usage: $NAME [-v]" + echo "Usage: $NAME [-v] [-x]" + echo + echo " -v Verbose output" + echo " -x Don't regenerate build system, even when possible" + echo exit 2 esac shift done +for cmd in telnet expect; do + command -v "$cmd" >/dev/null 2>&1 \ + || echo "$NAME: WARNING: $cmd(1) not found, \"make check\" won't run all tests!" +done + echo "$NAME: Checking ngIRCd base source directory ..." -grep "ngIRCd" ./ChangeLog >/dev/null 2>&1 +grep "ngIRCd" "$SRC_D/ChangeLog" >/dev/null 2>&1 if [ $? -ne 0 ]; then - grep "ngIRCd" ../ChangeLog >/dev/null 2>&1 + grep "ngIRCd" "$SRC_D/../ChangeLog" >/dev/null 2>&1 if [ $? -ne 0 ]; then echo "$NAME: ngIRCd base source directory not found!?" exit 1 fi - cd .. + SRC_D="$SRC_D/.." fi +echo "$NAME: - source directory: $SRC_D" +echo "$NAME: - working directory: $MY_D" echo "$NAME: Checking for GIT tree ..." -if [ -d .git ]; then +if [ -d "$SRC_D/.git" ]; then echo "$NAME: Checking for \"git\" command ..." git version >/dev/null 2>&1 - if [ $? -eq 0 ]; then + if [ $? -eq 0 ] && [ -n "$CLEAN" ]; then echo "$NAME: Running \"git clean\" ..." - [ -n "$VERBOSE" ] && git clean -dxf || git clean -dxf >/dev/null + cd "$SRC_D" || exit 1 + if [ -n "$VERBOSE" ]; then + git clean -dxf + else + git clean -dxf >/dev/null + fi + cd "$MY_D" || exit 1 fi fi -echo "$NAME: Checking for \"./configure\" script ..." -if [ ! -r ./configure ]; then - echo "$NAME: Running \"./autogen.sh\" ..." - [ -n "$VERBOSE" ] && ./autogen.sh || ./autogen.sh >/dev/null +echo "$NAME: Checking for \"$SRC_D/configure\" script ..." +if [ ! -r "$SRC_D/configure" ]; then + echo "$NAME: Running \"$SRC_D/autogen.sh\" ..." + cd "$SRC_D" || exit 1 + if [ -n "$VERBOSE" ]; then + ./autogen.sh + else + ./autogen.sh >/dev/null + fi + cd "$MY_D" || exit 1 fi -if [ -r ./configure ]; then - echo "$NAME: Running \"./configure\" script ..." - [ -n "$VERBOSE" ] && ./configure || ./configure >/dev/null - if [ $? -eq 0 -a -r ./Makefile ]; then +if [ -r "$SRC_D/configure" ]; then + echo "$NAME: Running \"$SRC_D/configure\" script ..." + if [ -n "$VERBOSE" ]; then + "$SRC_D/configure" -C + else + "$SRC_D/configure" -C >/dev/null + fi + if [ $? -eq 0 ] && [ -r ./Makefile ]; then R_CONFIGURE=1 + rm -f "src/ngircd/ngircd" echo "$NAME: Running \"$MAKE\" ..." - [ -n "$VERBOSE" ] && "$MAKE" || "$MAKE" >/dev/null - if [ $? -eq 0 -a -x src/ngircd/ngircd ]; then + if [ -n "$VERBOSE" ]; then + "$MAKE" + else + "$MAKE" >/dev/null + fi + if [ $? -eq 0 ] && [ -x src/ngircd/ngircd ]; then R_MAKE=1 echo "$NAME: Running \"$MAKE check\" ..." - [ -n "$VERBOSE" ] && "$MAKE" check || "$MAKE" check >/dev/null + if [ -n "$VERBOSE" ]; then + "$MAKE" check + else + "$MAKE" check >/dev/null + fi if [ $? -eq 0 ]; then R_CHECK=1 R_RUN=$R_CHECK + [ -r ./src/testsuite/tests-skipped.lst ] \ + && R_CHECK_Y="y" || R_CHECK_Y="Y" else ./src/ngircd/ngircd --help 2>/dev/null \ | grep "^ngIRCd" >/dev/null @@ -95,13 +141,13 @@ fi # Get target platform information if [ -r "src/config.h" ]; then - CPU=`grep "HOST_CPU" "src/config.h" | cut -d'"' -f2` - OS=`grep "HOST_OS" "src/config.h" | cut -d'"' -f2` - VENDOR=`grep "HOST_VENDOR" "src/config.h" | cut -d'"' -f2` + CPU=$(grep "HOST_CPU" "src/config.h" | cut -d'"' -f2) + OS=$(grep "HOST_OS" "src/config.h" | cut -d'"' -f2) + VENDOR=$(grep "HOST_VENDOR" "src/config.h" | cut -d'"' -f2) PLATFORM="$CPU/$VENDOR/$OS" fi if [ -z "$PLATFORM" ]; then - PLATFORM="`uname 2>/dev/null` `uname -r 2>/dev/null`, `uname -m 2>/dev/null`" + PLATFORM="$(uname 2>/dev/null) $(uname -r 2>/dev/null), $(uname -m 2>/dev/null)" fi # Get compiler information @@ -133,18 +179,18 @@ if [ -r "Makefile" ]; then | cut -d'(' -f1 | sed -e 's/version //g') fi if [ "$COMPILER" = "unknown" ]; then - v="`$CC --version 2>/dev/null | head -1`" - [ -z "$v" ] && v="`$CC -version 2>/dev/null | head -1`" + v="$($CC --version 2>/dev/null | head -1)" + [ -z "$v" ] && v="$($CC -version 2>/dev/null | head -1)" [ -n "$v" ] && COMPILER="$v" fi fi fi # Get ngIRCd version information -eval $(grep "^VERSION = " Makefile | sed -e 's/ //g') +eval "$(grep "^VERSION = " Makefile | sed -e 's/ //g')" case "$VERSION" in - *-*-*) - VERSION=`echo "$VERSION" | cut -d'-' -f3 | cut -b2-` + *~*-*) + VERSION=$(echo "$VERSION" | cut -b1-10) ;; esac [ -n "$VERSION" ] || VERSION="unknown" @@ -163,8 +209,13 @@ fi [ -n "$R_CONFIGURE" ] && C="Y" || C="N" [ -n "$R_MAKE" ] && M="Y" || M="N" -[ -n "$R_CHECK" ] && T="Y" || T="N" -[ -n "$R_RUN" ] && R="Y" || R="N" +[ -n "$R_CHECK" ] && T="$R_CHECK_Y" || T="N" +if [ -n "$R_RUN" ]; then + # Mark "runs" with "Y" only when the test suite succeeded: + [ "$T" = "N" ] && R="?" || R="Y" +else + R="N" +fi [ -n "$COMMENT" ] && COMMENT=" $COMMENT" echo @@ -175,13 +226,29 @@ echo " ./configure works --+ | echo " | | | |" echo "Platform Compiler ngIRCd Date Tester C M T R *" echo "--------------------------- ------------ ---------- -------- -------- - - - - -" -type printf >/dev/null 2>&1 +command -v printf >/dev/null 2>&1 if [ $? -eq 0 ]; then - printf "%-27s %-12s %-10s %s %-8s %s %s %s %s%s" \ - "$PLATFORM" "$COMPILER" "$VERSION" "$DATE" "$USER" \ + printf "%-27s %-12s %-10s %s %-8s %s %s %s %s%s\n" \ + "$PLATFORM" "$COMPILER" "$VERSION" "$DATE" "$LOGNAME" \ "$C" "$M" "$T" "$R" "$COMMENT" else - echo "$PLATFORM $COMPILER $VERSION $DATE $USER" \ + echo "$PLATFORM $COMPILER $VERSION $DATE $LOGNAME" \ "$C" "$M" "$T" "$R" "$COMMENT" fi -echo; echo +echo + +double_check() { + echo "Please double check that the ngIRCd daemon starts up, runs and handles IRC" + echo "connections successfully!" +} + +if [ "$R_CHECK_Y" = "y" ]; then + echo "WARNING: Some tests have been skipped!" + double_check + echo +fi +if [ "$R" = "?" ]; then + echo "WARNING: The resulting binary passed simple tests, but the test suite failed!" + double_check + echo +fi