Back to home page

Enduro/X

 
 

    


0001 #!/bin/bash
0002 ##
0003 ## @brief @(#) See README. Keygroup tests, limited by keys and by group..
0004 ##
0005 ## @file 17_run_grouplim.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 
0057 source ./test-func-include.sh
0058 
0059 #
0060 # Domain 1 - here client will live
0061 #
0062 set_dom1() {
0063     echo "Setting domain 1"
0064     . ../dom1.sh
0065     export NDRX_CONFIG=$TESTDIR/ndrxconfig-dom1.xml
0066     export NDRX_DMNLOG=$TESTDIR/ndrxd-dom1.log
0067     export NDRX_LOG=$TESTDIR/ndrx-dom1.log
0068     export TESTDIR_DB=$TESTDIR
0069     export TESTDIR_SHM=$TESTDIR
0070     export NDRX_CCTAG=dom1
0071 }
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 TESTDIR_DB=$TESTDIR/dom2
0080     export TESTDIR_SHM=$TESTDIR/dom2
0081     export NDRX_CCTAG=dom2
0082 }
0083 
0084 set_dom3() {
0085     echo "Setting domain 3"
0086     . ../dom3.sh
0087     export NDRX_CONFIG=$TESTDIR/ndrxconfig-dom3.xml
0088     export NDRX_DMNLOG=$TESTDIR/ndrxd-dom3.log
0089     export NDRX_LOG=$TESTDIR/ndrx-dom3.log
0090     export TESTDIR_DB=$TESTDIR/dom3
0091     export TESTDIR_SHM=$TESTDIR/dom3
0092     export NDRX_CCTAG=dom3
0093 }
0094 
0095 #
0096 # Generic exit function
0097 #
0098 function go_out {
0099     echo "Test exiting with: $1"
0100     
0101     set_dom1;
0102     xadmin stop -y
0103     xadmin down -y
0104 
0105 
0106     set_dom2;
0107     xadmin stop -y
0108     xadmin down -y
0109 
0110     set_dom3;
0111     xadmin stop -y
0112     xadmin down -y
0113 
0114     # If some alive stuff left...
0115     xadmin killall atmiclt48
0116 
0117     popd 2>/dev/null
0118     exit $1
0119 }
0120 
0121 rm *.log
0122 # Any bridges that are live must be killed!
0123 xadmin killall tpbridge
0124 
0125 echo "Booting domain 1"
0126 set_dom1;
0127 xadmin down -y
0128 xadmin start -y || go_out 1
0129 
0130 echo "Booting domain 2"
0131 set_dom2;
0132 xadmin down -y
0133 xadmin start -y || go_out 1
0134 
0135 echo "Booting domain 3"
0136 set_dom3;
0137 xadmin down -y
0138 xadmin start -y || go_out 1
0139 
0140 echo "Let clients to boot & links to establish..."
0141 sleep 60
0142 
0143 RET=0
0144 
0145 echo "Domain 1 info"
0146 set_dom1;
0147 xadmin psc
0148 xadmin ppm
0149 #xadmin sc -t CACHED
0150 xadmin pc
0151 
0152 echo "Domain 2 info"
0153 set_dom2;
0154 xadmin psc
0155 xadmin ppm
0156 xadmin sc -t CACHED
0157 xadmin pc
0158 
0159 echo "Domain 3 info"
0160 set_dom3;
0161 xadmin psc
0162 xadmin ppm
0163 xadmin sc -t CACHED
0164 xadmin pc
0165 
0166 
0167 echo "Running off client on domain 1"
0168 set_dom1;
0169 
0170 (time ./testtool48 -sTESTSV17 -b '{"T_STRING_FLD":"KEY1","T_STRING_2_FLD":"DOM1","T_SHORT_FLD":"1"}' \
0171     -m '{"T_STRING_FLD":"KEY1","T_STRING_2_FLD":"DOM1","T_SHORT_FLD":"1"}' \
0172     -cY -n50 -fY 2>&1) > ./17_testtool48.log
0173 
0174 if [ $? -ne 0 ]; then
0175     echo "testtool48 failed (1)"
0176     go_out 1
0177 fi
0178 
0179 (time ./testtool48 -sTESTSV17 -b '{"T_STRING_FLD":"KEY1","T_STRING_2_FLD":"DOM1","T_SHORT_FLD":"2"}' \
0180     -m '{"T_STRING_FLD":"KEY1","T_STRING_2_FLD":"DOM1","T_SHORT_FLD":"2"}' \
0181     -cY -n50 -fY 2>&1) >> ./17_testtool48.log
0182 
0183 if [ $? -ne 0 ]; then
0184     echo "testtool48 failed (2)"
0185     go_out 1
0186 fi
0187 
0188 
0189 (time ./testtool48 -sTESTSV17 -b '{"T_STRING_FLD":"KEY1","T_STRING_2_FLD":"DOM1","T_SHORT_FLD":"3"}' \
0190     -m '{"T_STRING_FLD":"KEY1","T_STRING_2_FLD":"DOM1","T_SHORT_FLD":"3"}' \
0191     -cY -n50 -fY 2>&1) >> ./17_testtool48.log
0192 
0193 if [ $? -ne 0 ]; then
0194     echo "testtool48 failed (3)"
0195     go_out 1
0196 fi
0197 
0198 (time ./testtool48 -sTESTSV17 -b '{"T_STRING_FLD":"KEY1","T_STRING_2_FLD":"DOM1","T_SHORT_FLD":"4"}' \
0199     -m '{"T_STRING_FLD":"KEY1","T_STRING_2_FLD":"DOM1","T_SHORT_FLD":"4"}' \
0200     -cY -n50 -fY 2>&1) >> ./17_testtool48.log
0201 
0202 if [ $? -ne 0 ]; then
0203     echo "testtool48 failed (4)"
0204     go_out 1
0205 fi
0206 
0207 (time ./testtool48 -sTESTSV17 -b '{"T_STRING_FLD":"KEY1","T_STRING_2_FLD":"DOM1","T_SHORT_FLD":"5"}' \
0208     -m '{"T_STRING_FLD":"KEY1","T_STRING_2_FLD":"DOM1","T_SHORT_FLD":"5"}' \
0209     -cY -n50 -fY 2>&1) >> ./17_testtool48.log
0210 
0211 if [ $? -ne 0 ]; then
0212     echo "testtool48 failed (5)"
0213     go_out 1
0214 fi
0215 
0216 (time ./testtool48 -sTESTSV17 -b '{"T_STRING_FLD":"KEY1","T_STRING_2_FLD":"DOM1","T_SHORT_FLD":"6"}' \
0217     -m '{"T_STRING_FLD":"KEY1","T_STRING_2_FLD":"DOM1","T_SHORT_FLD":"6"}' \
0218     -cY -n50 -fY 2>&1) >> ./17_testtool48.log
0219 
0220 if [ $? -ne 0 ]; then
0221     echo "testtool48 failed (6)"
0222     go_out 1
0223 fi
0224 
0225 echo "Letting tpcached to zap the keys..."
0226 sleep 7
0227 
0228 echo "DOM 1 testing"
0229 xadmin cs k@db17
0230 ensure_keys k@db17 5
0231 
0232 ensure_field g@db17 SV17KEY1 EX_CACHE_OPEXPR SV17KEY1-SV171 0
0233 ensure_field g@db17 SV17KEY1 EX_CACHE_OPEXPR SV17KEY1-SV172 1
0234 ensure_field g@db17 SV17KEY1 EX_CACHE_OPEXPR SV17KEY1-SV176 1
0235 
0236 
0237 echo "DOM 2 testing"
0238 set_dom2;
0239 xadmin cs k@db17
0240 ensure_keys k@db17 5
0241 
0242 ensure_field g@db17 SV17KEY1 EX_CACHE_OPEXPR SV17KEY1-SV171 0
0243 ensure_field g@db17 SV17KEY1 EX_CACHE_OPEXPR SV17KEY1-SV172 1
0244 ensure_field g@db17 SV17KEY1 EX_CACHE_OPEXPR SV17KEY1-SV176 1
0245 
0246 echo "DOM 3 testing"
0247 set_dom3;
0248 xadmin cs k@db17
0249 ensure_keys k@db17 5
0250 
0251 ensure_field g@db17 SV17KEY1 EX_CACHE_OPEXPR SV17KEY1-SV171 0
0252 ensure_field g@db17 SV17KEY1 EX_CACHE_OPEXPR SV17KEY1-SV172 1
0253 ensure_field g@db17 SV17KEY1 EX_CACHE_OPEXPR SV17KEY1-SV176 1
0254 
0255 echo "Testing group fifo zapping..."
0256 set_dom1;
0257 
0258 
0259 (time ./testtool48 -sTESTSV17 -b '{"T_STRING_FLD":"KEY2","T_STRING_2_FLD":"DOM1","T_SHORT_FLD":"3"}' \
0260     -m '{"T_STRING_FLD":"KEY2","T_STRING_2_FLD":"DOM1","T_SHORT_FLD":"3"}' \
0261     -cY -n50 -fY 2>&1) >> ./17_testtool48.log
0262 
0263 if [ $? -ne 0 ]; then
0264     echo "testtool48 failed (7)"
0265     go_out 1
0266 fi
0267 
0268 (time ./testtool48 -sTESTSV17 -b '{"T_STRING_FLD":"KEY3","T_STRING_2_FLD":"DOM1","T_SHORT_FLD":"3"}' \
0269     -m '{"T_STRING_FLD":"KEY3","T_STRING_2_FLD":"DOM1","T_SHORT_FLD":"3"}' \
0270     -cY -n50 -fY 2>&1) >> ./17_testtool48.log
0271 
0272 if [ $? -ne 0 ]; then
0273     echo "testtool48 failed (8)"
0274     go_out 1
0275 fi
0276 
0277 (time ./testtool48 -sTESTSV17 -b '{"T_STRING_FLD":"KEY4","T_STRING_2_FLD":"DOM1","T_SHORT_FLD":"3"}' \
0278     -m '{"T_STRING_FLD":"KEY4","T_STRING_2_FLD":"DOM1","T_SHORT_FLD":"3"}' \
0279     -cY -n50 -fY 2>&1) >> ./17_testtool48.log
0280 
0281 if [ $? -ne 0 ]; then
0282     echo "testtool48 failed (9)"
0283     go_out 1
0284 fi
0285 
0286 (time ./testtool48 -sTESTSV17 -b '{"T_STRING_FLD":"KEY5","T_STRING_2_FLD":"DOM1","T_SHORT_FLD":"3"}' \
0287     -m '{"T_STRING_FLD":"KEY5","T_STRING_2_FLD":"DOM1","T_SHORT_FLD":"3"}' \
0288     -cY -n50 -fY 2>&1) >> ./17_testtool48.log
0289 
0290 if [ $? -ne 0 ]; then
0291     echo "testtool48 failed (10)"
0292     go_out 1
0293 fi
0294 
0295 (time ./testtool48 -sTESTSV17 -b '{"T_STRING_FLD":"KEY6","T_STRING_2_FLD":"DOM1","T_SHORT_FLD":"3"}' \
0296     -m '{"T_STRING_FLD":"KEY6","T_STRING_2_FLD":"DOM1","T_SHORT_FLD":"3"}' \
0297     -cY -n50 -fY 2>&1) >> ./17_testtool48.log
0298 
0299 if [ $? -ne 0 ]; then
0300     echo "testtool48 failed (10)"
0301     go_out 1
0302 fi
0303 
0304 
0305 echo "Letting tpcached to zap the keys... (2)"
0306 sleep 7
0307 
0308 
0309 echo "OK so first group must be zapped, we have 5x groups now and 5x keys in total"
0310 
0311 echo "DOM 1 testing"
0312 xadmin cs k@db17
0313 xadmin cs g@db17
0314 
0315 ensure_keys k@db17 5
0316 ensure_keys g@db17 5
0317 
0318 ensure_field g@db17 SV17KEY1 EX_CACHE_OPEXPR SV17KEY1-SV173 0
0319 ensure_field g@db17 SV17KEY2 EX_CACHE_OPEXPR SV17KEY2-SV173 1
0320 ensure_field g@db17 SV17KEY3 EX_CACHE_OPEXPR SV17KEY3-SV173 1
0321 ensure_field g@db17 SV17KEY4 EX_CACHE_OPEXPR SV17KEY4-SV173 1
0322 ensure_field g@db17 SV17KEY5 EX_CACHE_OPEXPR SV17KEY5-SV173 1
0323 ensure_field g@db17 SV17KEY6 EX_CACHE_OPEXPR SV17KEY6-SV173 1
0324 ensure_field g@db17 SV17KEY6 EX_CACHE_OPEXPR SV17KEY7-SV173 0
0325 
0326 go_out $RET
0327 
0328 # vim: set ts=4 sw=4 et smartindent: