Back to home page

Enduro/X

 
 

    


0001 #!/bin/bash
0002 ##
0003 ## @brief Wait for ndrxd normal state - test launcher
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="test069_wnormal"
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 export NDRX_SILENT=Y
0054 export NDRX_TOUT=10
0055 
0056 #
0057 # Domain 1 - here client will live
0058 #
0059 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 #
0070 # Do the lengthy shutdown
0071 #
0072 function back_stop {
0073      
0074     echo "Run shutdown procedure"
0075     xadmin start -y
0076     xadmin stop -y
0077 
0078 }
0079 
0080 #
0081 # Generic exit function
0082 #
0083 function go_out {
0084     echo "Test exiting with: $1"
0085     
0086     set_dom1;
0087     xadmin stop -y
0088     xadmin down -y
0089 
0090 
0091 
0092     # If some alive stuff left...
0093     xadmin killall atmiclt69
0094 
0095     popd 2>/dev/null
0096     exit $1
0097 }
0098 
0099 rm *dom*.log
0100 # Any bridges that are live must be killed!
0101 xadmin killall tpbridge
0102 
0103 set_dom1;
0104 xadmin down -y
0105 xadmin start -y & 
0106 
0107 echo "let ndrxd to boot..."
0108 sleep 2
0109 
0110 echo "Start wait too short - fail"
0111 export NDRX_NORMWAITMAX=5
0112 xadmin start -y 
0113 RET=$?
0114 if [[ "X$RET" == "X0" ]]; then
0115     echo "Startup must be failed..."
0116     go_out -2
0117 fi
0118 
0119 
0120 echo "Start wait enough - ok"
0121 export NDRX_NORMWAITMAX=20
0122 xadmin start -y 
0123 RET=$?
0124 if [[ "X$RET" != "X0" ]]; then
0125     echo "Startup must be ok..."
0126     go_out -3
0127 fi
0128 
0129 #
0130 # Run the full shutdown in background
0131 #
0132 echo "Wait for full shutdown..."
0133 export NDRX_NORMWAITMAX=22
0134 xadmin stop -y
0135 
0136 echo "Start background..."
0137 # OK lets run the background start + shutdown...
0138 (back_stop) &
0139 sleep 2
0140 
0141 #
0142 # Too short..
0143 #
0144 echo "Shutdown wait too short, exit fail..."
0145 export NDRX_NORMWAITMAX=5
0146 xadmin stop -y 
0147 RET=$?
0148 
0149 if [[ "X$RET" == "X0" ]]; then
0150     echo "Stop must fail because attempts exceeded"
0151     go_out -4
0152 fi
0153 
0154 #
0155 # Now wait for pid...
0156 #
0157 echo "Forced stop, will wait until pid exits..."
0158 export NDRX_NORMWAITMAX=1
0159 xadmin stop -y -f
0160 RET=$?
0161 
0162 if [[ "X$RET" != "X0" ]]; then
0163     echo "Forced stop must be OK."
0164     go_out -5
0165 fi
0166 
0167 go_out $RET
0168 
0169 # vim: set ts=4 sw=4 et smartindent: