Back to home page

Enduro/X

 
 

    


0001 #!/bin/bash
0002 ##
0003 ## @brief Remove dead (last) service queue, regarless of network connection - 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="test096_svcrmnet"
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_ULOG=$TESTDIR
0054 export NDRX_TOUT=10
0055 export NDRX_SILENT=Y
0056 
0057 #
0058 # Domain 1 - here client will live
0059 #
0060 set_dom1() {
0061     echo "Setting domain 1"
0062     . ../dom1.sh
0063     export NDRX_CONFIG=$TESTDIR/ndrxconfig-dom1.xml
0064     export NDRX_DMNLOG=$TESTDIR/ndrxd-dom1.log
0065     export NDRX_LOG=$TESTDIR/ndrx-dom1.log
0066     export NDRX_DEBUG_CONF=$TESTDIR/debug-dom1.conf
0067 }
0068 
0069 
0070 #
0071 # Domain 2 - here server will live
0072 #
0073 set_dom2() {
0074     echo "Setting domain 2"
0075     . ../dom2.sh    
0076     export NDRX_CONFIG=$TESTDIR/ndrxconfig-dom2.xml
0077     export NDRX_DMNLOG=$TESTDIR/ndrxd-dom2.log
0078     export NDRX_LOG=$TESTDIR/ndrx-dom2.log
0079     export NDRX_DEBUG_CONF=$TESTDIR/debug-dom2.conf
0080 }
0081 
0082 #
0083 # Generic exit function
0084 #
0085 function go_out {
0086     echo "Test exiting with: $1"
0087     
0088     set_dom1;
0089     xadmin stop -y
0090     xadmin down -y
0091 
0092 
0093     set_dom2;
0094     xadmin stop -y
0095     xadmin down -y
0096 
0097     # If some alive stuff left...
0098     xadmin killall atmiclt96
0099 
0100     popd 2>/dev/null
0101     exit $1
0102 }
0103 
0104 rm ULOG* 2>/dev/null
0105 rm *.log 2>/dev/null
0106 # Any bridges that are live must be killed!
0107 xadmin killall tpbridge
0108 
0109 set_dom1;
0110 xadmin down -y
0111 xadmin start -y || go_out 1
0112 
0113 
0114 set_dom2;
0115 xadmin down -y
0116 xadmin start -y || go_out 2
0117 
0118 
0119 echo "Wait for link..."
0120 sleep 30
0121 RET=0
0122 
0123 set_dom1;
0124 
0125 xadmin psc
0126 xadmin pqa
0127 xadmin psvc
0128 
0129 # domain 1 kill pid...
0130 KPID=`xadmin ps -p -a atmi.sv96 -b nre38Kff1kz -c "-i 511"`
0131 
0132 echo "Killing $KPID"
0133 kill -9 $KPID
0134 
0135 echo "Wait for housekeep..."
0136 sleep 5
0137 
0138 echo "Test service queue..."
0139 xadmin psc
0140 xadmin pqa
0141 xadmin psvc
0142 
0143 SVCQ=`xadmin pqa|grep TESTSV`
0144 
0145 if [ "X$SVCQ" != "X" ]; then
0146     echo "TESTSV Q must dissappear"
0147     go_out -1
0148 fi
0149 
0150 echo ">>> Checking that remove calls are still working..."
0151 ./atmiclt96 >atmiclt96.log
0152 
0153 RET=$?
0154 
0155 if [ "X$RET" != "X0" ]; then
0156     echo "./atmiclt96 failed"
0157     go_out $RET
0158 fi
0159 
0160 # Catch is there is test error!!!
0161 if [ "X`grep TESTERROR *.log`" != "X" ]; then
0162     echo "Test error detected!"
0163     RET=-2
0164 fi
0165 
0166 go_out $RET
0167 
0168 
0169 # vim: set ts=4 sw=4 et smartindent: