#!/bin/bash #!/bin/ksh # # This file is part of rasdaman community. # # Rasdaman community is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # Rasdaman community is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with rasdaman community. If not, see . # # Copyright 2003, 2004, 2005, 2006, 2007, 2008, 2009 Peter Baumann / # rasdaman GmbH. # # For more information please see # or contact Peter Baumann via . # # SYNOPSIS # test.sh # Description # Command-line utility for testing postgres connection leak # if we get "rasdaman error 801: RasManager Error: System overloaded, please try again later" or "rasdaman error 206" when we run a rasql it means memleak. # # PRECONDITIONS # 1)Postgres Server must be running # 2)Rasdaman Server must be running # 3)database RASBASE must exists # 4)rasql utility must be fully running # Usage: ./test.sh # # CHANGE HISTORY # 2010-10-31 J.Yu created # # Variables PROGNAME=`basename $0` DIR_NAME=$(dirname $0) LOG_DIR=$DIR_NAME LOG=$LOG_DIR/log OLDLOG=$LOG.save USERNAME=rasadmin PASSWORD=rasadmin DATABASE=RASBASE RASQL="rasql --quiet" RASDL="rasdl" CODE_OK=0 CODE_FAIL=255 #--------------- check if old logfile exists ---------------------------------- if [ -f $LOG ] then echo Old logfile found, copying it to $OLDLOG mv $LOG $OLDLOG fi echo "Test by:"$PROGNAME" at "`date`|tee $LOG #---------------------------Precondition------------------------------------------ # check the Postgres ps -e | grep --quiet post if [ $? -ne 0 ] then echo no postmaster available|tee -a $LOG exit $CODE_FAIL fi # check the Rasdaman ps -e | grep --quiet rasmgr if [ $? -ne 0 ] then echo no rasmgr available|tee -a $LOG exit $CODE_FAIL fi #--------------------------test------------------------------ # check leak by rasql if $RASQL -q "select r from RAS_COLLECTIONNAMES as r" --out string 2>&1 | grep --quiet -w -E "rasdaman error 801|rasdaman error 206" then echo "memleak"|tee -a $LOG exit $CODE_FAIL else echo "memleak test pass"|tee -a $LOG exit $CODE_OK fi