Back to home page

Enduro/X

 
 

    


0001 #!/bin/bash
0002 ##
0003 ## @brief @(#) See README. Test parallel operations
0004 ##
0005 ## @file 19_run_threads.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="test048_cache"
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 export NDRX_CCONFIG=`pwd`
0050 . ../testenv.sh
0051 
0052 export TESTDIR="$NDRX_APPHOME/atmitest/$TESTNAME"
0053 export PATH=$PATH:$TESTDIR
0054 export NDRX_TOUT=10
0055 export NDRX_ULOG=$TESTDIR
0056 export TESTDIR_DB=$TESTDIR
0057 export TESTDIR_SHM=$TESTDIR
0058 
0059 source ./test-func-include.sh
0060 
0061 #
0062 # Domain 1 - here client will live
0063 #
0064 set_dom1() {
0065     echo "Setting domain 1"
0066     . ../dom1.sh
0067     export NDRX_CONFIG=$TESTDIR/ndrxconfig-dom1.xml
0068     export NDRX_DMNLOG=$TESTDIR/ndrxd-dom1.log
0069     export NDRX_LOG=$TESTDIR/ndrx-dom1.log
0070     export NDRX_CCTAG=dom1
0071 }
0072 
0073 #
0074 # Generic exit function
0075 #
0076 function go_out {
0077     echo "Test exiting with: $1"
0078     
0079     set_dom1;
0080     xadmin stop -y
0081     xadmin down -y
0082 
0083 
0084 
0085     # If some alive stuff left...
0086     xadmin killall atmiclt48
0087 
0088     popd 2>/dev/null
0089     exit $1
0090 }
0091 
0092 rm *.log
0093 # Any bridges that are live must be killed!
0094 xadmin killall tpbridge
0095 
0096 set_dom1;
0097 xadmin down -y
0098 xadmin start -y || go_out 1
0099 
0100 #
0101 # Let clients to boot
0102 #
0103 sleep 5
0104 
0105 RET=0
0106 
0107 set_dom1;
0108 xadmin psc
0109 xadmin ppm
0110 xadmin pc
0111 
0112 echo "Running off client - add first rec to cache"
0113 
0114 (time ./testtool48 -sTESTSV19 -b '{"T_STRING_FLD":"KEY1"}' \
0115     -m '{"T_STRING_FLD":"KEY1"}' \
0116     -cY -n100 -fY 2>&1) > ./19_testtool48.log
0117 
0118 if [ $? -ne 0 ]; then
0119     echo "testtool48 failed (1)"
0120     go_out 1
0121 fi
0122 
0123 echo "Running threaded operations"
0124 (time ./testtool48 -sTESTSV19 -b '{"T_STRING_FLD":"KEY1"}' \
0125     -m '{"T_STRING_FLD":"KEY1"}' \
0126     -cY -n100 -fN -t5 2>&1) >> ./19_testtool48.log
0127 
0128 if [ $? -ne 0 ]; then
0129     echo "testtool48 failed (2)"
0130     go_out 2
0131 fi
0132 
0133 echo "Test MP..."
0134 
0135 (time ./testtool48 -sTESTSV19 -b '{"T_STRING_FLD":"KEY1"}' \
0136     -m '{"T_STRING_FLD":"KEY1"}' \
0137     -cY -n100 -fN 2>&1) >> ./19_testtool48_1.log & 
0138 
0139 (time ./testtool48 -sTESTSV19 -b '{"T_STRING_FLD":"KEY1"}' \
0140     -m '{"T_STRING_FLD":"KEY1"}' \
0141     -cY -n100 -fN 2>&1) >> ./19_testtool48_2.log & 
0142 
0143 
0144 (time ./testtool48 -sTESTSV19 -b '{"T_STRING_FLD":"KEY1"}' \
0145     -m '{"T_STRING_FLD":"KEY1"}' \
0146     -cY -n100 -fN 2>&1) >> ./19_testtool48_3.log & 
0147 
0148 (time ./testtool48 -sTESTSV19 -b '{"T_STRING_FLD":"KEY1"}' \
0149     -m '{"T_STRING_FLD":"KEY1"}' \
0150     -cY -n100 -fN 2>&1) >> ./19_testtool48_4.log & 
0151 
0152 (time ./testtool48 -sTESTSV19 -b '{"T_STRING_FLD":"KEY1"}' \
0153     -m '{"T_STRING_FLD":"KEY1"}' \
0154     -cY -n100 -fN 2>&1) >> ./19_testtool48_5.log & 
0155 
0156 (time ./testtool48 -sTESTSV19 -b '{"T_STRING_FLD":"KEY1"}' \
0157     -m '{"T_STRING_FLD":"KEY1"}' \
0158     -cY -n100 -fN 2>&1) >> ./19_testtool48_6.log & 
0159 
0160 
0161 
0162 (time ./testtool48 -sTESTSV19 -b '{"T_STRING_FLD":"KEY1"}' \
0163     -m '{"T_STRING_FLD":"KEY1"}' \
0164     -cY -n100 -fN 2>&1) >> ./19_testtool48_6.log & 
0165 
0166 (time ./testtool48 -sTESTSV19 -b '{"T_STRING_FLD":"KEY1"}' \
0167     -m '{"T_STRING_FLD":"KEY1"}' \
0168     -cY -n100 -fN 2>&1) >> ./19_testtool48_7.log & 
0169 
0170 
0171 (time ./testtool48 -sTESTSV19 -b '{"T_STRING_FLD":"KEY1"}' \
0172     -m '{"T_STRING_FLD":"KEY1"}' \
0173     -cY -n100 -fN 2>&1) >> ./19_testtool48_8.log & 
0174 
0175 
0176 (time ./testtool48 -sTESTSV19 -b '{"T_STRING_FLD":"KEY1"}' \
0177     -m '{"T_STRING_FLD":"KEY1"}' \
0178     -cY -n100 -fN 2>&1) >> ./19_testtool48_9.log & 
0179 
0180 (time ./testtool48 -sTESTSV19 -b '{"T_STRING_FLD":"KEY1"}' \
0181     -m '{"T_STRING_FLD":"KEY1"}' \
0182     -cY -n100 -fN 2>&1) >> ./19_testtool48_10.log & 
0183 
0184 FAIL=0
0185 
0186 
0187 for job in `jobs -p`
0188 do
0189 echo $job
0190     wait $job || let "FAIL+=1"
0191 done
0192 
0193 echo "FAIL=$FAIL"
0194 
0195 if [ $FAIL -ne 0 ]; then
0196     echo "some process failed!!!"
0197     go_out 3
0198 fi
0199 
0200 go_out $RET
0201 # vim: set ts=4 sw=4 et smartindent: