Back to home page

Enduro/X

 
 

    


0001 #!/bin/bash
0002 ##
0003 ## @brief @(#) Test001 - clusterised version
0004 ##
0005 ## @file run-dom-bench.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 TESTNO="001"
0037 export TESTNAME_SHORT="basiccall"
0038 export TESTNAME="test${TESTNO}_${TESTNAME_SHORT}"
0039 
0040 PWD=`pwd`
0041 if [ `echo $PWD | grep $TESTNAME ` ]; then
0042         # Do nothing 
0043         echo > /dev/null
0044 else
0045         # started from parent folder
0046         pushd .
0047         echo "Doing cd"
0048         cd $TESTNAME
0049 fi;
0050 
0051 . ../testenv.sh
0052 
0053 export TESTDIR="$NDRX_APPHOME/atmitest/$TESTNAME"
0054 export PATH=$PATH:$TESTDIR
0055 # Override timeout!
0056 export NDRX_TOUT=3
0057 
0058 #
0059 # Domain 1 - here client will live
0060 #
0061 function set_dom1 {
0062     echo "Setting domain 1"
0063     . ../dom1.sh
0064     export NDRX_CONFIG=$TESTDIR/ndrxconfig-dom1-bench.xml
0065     export NDRX_DMNLOG=$TESTDIR/ndrxd-dom1.log
0066     export NDRX_LOG=$TESTDIR/ndrx-dom1.log
0067     export NDRX_DEBUG_CONF=$TESTDIR/debug-dom1.conf
0068 }
0069 
0070 #
0071 # Domain 2 - here server will live
0072 #
0073 function set_dom2 {
0074     echo "Setting domain 2"
0075     . ../dom2.sh    
0076     export NDRX_CONFIG=$TESTDIR/ndrxconfig-dom2-bench.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     set_dom2;
0093     xadmin stop -y
0094     xadmin down -y
0095 
0096     # If some alive stuff left...
0097     killall -9 atmiclt1
0098 
0099     popd 2>/dev/null
0100     exit $1
0101 }
0102 
0103 #
0104 # Print domain statuses...
0105 #
0106 function print_domains {
0107 
0108     set_dom1;
0109     xadmin ppm
0110     xadmin psvc
0111     xadmin psc
0112 
0113     set_dom2;
0114     xadmin ppm
0115     xadmin psvc
0116     xadmin psc
0117 
0118 }
0119 
0120 
0121 rm *dom*.log
0122 
0123 set_dom1;
0124 xadmin down -y
0125 xadmin start -y || go_out 1
0126 
0127 set_dom2;
0128 xadmin down -y
0129 xadmin start -y || go_out 2
0130 
0131 #exit 0
0132 
0133 # Have some wait for ndrxd goes in service - wait for connection establishment.
0134 sleep 20
0135 
0136 print_domains;
0137 
0138 # Go to domain 1
0139 set_dom1;
0140 
0141 # Run the client test...
0142 echo "Will issue calls to clients:"
0143 sleep 1
0144 (./atmiclt1 2>&1 s :1:8:) > ./atmiclt1-dom1_1.log &
0145 (./atmiclt1 2>&1 s :1:8:) > ./atmiclt1-dom1_2.log &
0146 (./atmiclt1 2>&1 s :1:8:) > ./atmiclt1-dom1_3.log &
0147 (./atmiclt1 2>&1 s :1:8:) > ./atmiclt1-dom1_4.log &
0148 (./atmiclt1 2>&1 s :1:8:) > ./atmiclt1-dom1_5.log &
0149 (./atmiclt1 2>&1 s :1:8:) > ./atmiclt1-dom1_6.log &
0150 (./atmiclt1 2>&1 s :1:8:) > ./atmiclt1-dom1_7.log &
0151 (./atmiclt1 2>&1 s :1:8:) > ./atmiclt1-dom1_8.log &
0152 (./atmiclt1 2>&1 s :1:8:) > ./atmiclt1-dom1_9.log &
0153 (./atmiclt1 2>&1 s :1:8:) > ./atmiclt1-dom1_10.log &
0154 (./atmiclt1 2>&1 s :1:8:) > ./atmiclt1-dom1_11.log &
0155 (./atmiclt1 2>&1 s :1:8:) > ./atmiclt1-dom1_12.log &
0156 (./atmiclt1 2>&1 s :1:8:) > ./atmiclt1-dom1_13.log &
0157 (./atmiclt1 2>&1 s :1:8:) > ./atmiclt1-dom1_14.log &
0158 (./atmiclt1 2>&1 s :1:8:) > ./atmiclt1-dom1_15.log &
0159 (./atmiclt1 2>&1 s :1:8:) > ./atmiclt1-dom1_16.log &
0160 (./atmiclt1 2>&1 s :1:8:) > ./atmiclt1-dom1_17.log &
0161 (./atmiclt1 2>&1 s :1:8:) > ./atmiclt1-dom1_18.log &
0162 (./atmiclt1 2>&1 s :1:8:) > ./atmiclt1-dom1_19.log &
0163 (./atmiclt1 2>&1 s :1:8:) > ./atmiclt1-dom1_20.log &
0164 (./atmiclt1 2>&1 s :1:8:) > ./atmiclt1-dom1_21.log &
0165 (./atmiclt1 2>&1 s :1:8:) > ./atmiclt1-dom1_22.log &
0166 (./atmiclt1 2>&1 s :1:8:) > ./atmiclt1-dom1_23.log &
0167 $PSCMD | grep atmiclt1 | grep -v grep | wc
0168 (./atmiclt1 2>&1 s :1:8:) > ./atmiclt1-dom1_24.log 
0169 
0170 #sleep 5 # let other to complete... (sync..)
0171 RETP=`$PSCMD | grep atmiclt1 | grep -v grep`
0172 while [[ "X$RETP" != "X" ]]; do
0173     RETP=`$PSCMD | grep atmiclt1 | grep -v grep`
0174 done 
0175 
0176 RET=$?
0177 
0178 
0179 grep "Performance" atmiclt1-dom1*.log
0180 
0181 # Catch is there is test error!!!
0182 if [ "X`grep TESTERROR *.log`" != "X" ]; then
0183         echo "Test error detected!"
0184         RET=-2
0185 fi
0186 
0187 go_out $RET
0188 
0189 # vim: set ts=4 sw=4 et smartindent: