Back to home page

Enduro/X

 
 

    


0001 #!/bin/bash
0002 ##
0003 ## @brief @(#) Test ndrxd ping procedures - test launcher (Bug #255)
0004 ##
0005 ## @file run.sh
0006 ##
0007 ## -----------------------------------------------------------------------------
0008 ## Enduro/X Middleware Platform for Distributed Transaction Processing
0009 ## Copyright (C) 2009-2016, ATR Baltic, Ltd. All Rights Reserved.
0010 ## Copyright (C) 2017-2023, Mavimax, Ltd. All Rights Reserved.
0011 ## This software is released under one of the following licenses:
0012 ## AGPL (with Java and Go exceptions) or Mavimax's license for commercial use.
0013 ## See LICENSE file for full text.
0014 ## -----------------------------------------------------------------------------
0015 ## AGPL license:
0016 ##
0017 ## This program is free software; you can redistribute it and/or modify it under
0018 ## the terms of the GNU Affero General Public License, version 3 as published
0019 ## by the Free Software Foundation;
0020 ##
0021 ## This program is distributed in the hope that it will be useful, but WITHOUT ANY
0022 ## WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
0023 ## PARTICULAR PURPOSE. See the GNU Affero General Public License, version 3
0024 ## for more details.
0025 ##
0026 ## You should have received a copy of the GNU Affero General Public License along 
0027 ## with this program; if not, write to the Free Software Foundation, Inc.,
0028 ## 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
0029 ##
0030 ## -----------------------------------------------------------------------------
0031 ## A commercial use license is available from Mavimax, Ltd
0032 ## contact@mavimax.com
0033 ## -----------------------------------------------------------------------------
0034 ##
0035 
0036 export TESTNAME="test044_ping"
0037 
0038 PWD=`pwd`
0039 if [ `echo $PWD | grep $TESTNAME ` ]; then
0040     # Do nothing 
0041     echo > /dev/null
0042 else
0043     # started from parent folder
0044     pushd .
0045     echo "Doing cd"
0046     cd $TESTNAME
0047 fi;
0048 
0049 . ../testenv.sh
0050 
0051 export TESTDIR="$NDRX_APPHOME/atmitest/$TESTNAME"
0052 export PATH=$PATH:$TESTDIR
0053 
0054 export NDRX_TOUT=2
0055 
0056 #
0057 # Domain 1 - here client will live
0058 #
0059 function set_dom1 {
0060     echo "Setting domain 1"
0061     . ../dom1.sh
0062     export NDRX_CONFIG=$TESTDIR/ndrxconfig-dom1.xml
0063     export NDRX_DMNLOG=$TESTDIR/ndrxd-dom1.log
0064     export NDRX_LOG=$TESTDIR/ndrx-dom1.log
0065     export NDRX_DEBUG_CONF=$TESTDIR/debug-dom1.conf
0066 }
0067 
0068 
0069 function get_pid {
0070 
0071     local retpid=""
0072     retpid=`$PSCMD | grep "\-i 3519" | grep -v grep | awk '{print $2}'`;
0073 
0074     echo $retpid
0075 }
0076 
0077 #
0078 # Generic exit function
0079 #
0080 go_out() {
0081     echo "Test exiting with: $1"
0082     
0083     set_dom1;
0084     xadmin stop -y
0085     xadmin down -y
0086 
0087     # If some alive stuff left...
0088     xadmin killall atmiclt44
0089 
0090     popd 2>/dev/null
0091     exit $1
0092 }
0093 
0094 rm *dom*.log
0095 # Any bridges that are live must be killed!
0096 xadmin killall tpbridge
0097 
0098 set_dom1;
0099 xadmin down -y
0100 xadmin start -y || go_out 1
0101 
0102 PROCPID=$(get_pid)   # or result=`myfunc`
0103 
0104 # Have some wait for ndrxd goes in service - wait for connection establishment.
0105 sleep 30
0106 
0107 # The case Bug #255 did restart server at particular configuration
0108 # when pings are performed at less time points than sanity checks
0109 # 
0110 PROCPID2=$(get_pid)   # or result=`myfunc`
0111 
0112 echo "PID [$PROCPID] vs [$PROCPID2]"
0113 
0114 if [ "X$PROCPID" != "X$PROCPID2" ]; then
0115 
0116         echo "PID Have changed [$PROCPID] vs [$PROCPID2]"
0117         go_out -1
0118 fi
0119 
0120 echo "Stopping..."
0121 cat << EOF | ud
0122 SRVCNM  TESTSV
0123 
0124 EOF
0125 
0126 sleep 60
0127 
0128 PROCPID2=$(get_pid)   # or result=`myfunc`
0129 
0130 echo "PID [$PROCPID] vs [$PROCPID2]"
0131 
0132 if [ "X$PROCPID" == "X$PROCPID2" ]; then
0133 
0134         echo "PID must be changed [$PROCPID] vs [$PROCPID2]!!"
0135         go_out -2
0136 fi
0137 
0138 
0139 RET=0
0140 
0141 xadmin psc
0142 xadmin ppm
0143 echo "Performing test..."
0144 
0145 # Catch is there is test error!!!
0146 if [ "X`grep TESTERROR *.log`" != "X" ]; then
0147         echo "Test error detected!"
0148         go_out -3
0149 fi
0150 
0151 go_out $RET
0152 
0153 # vim: set ts=4 sw=4 et smartindent: