Back to home page

Enduro/X

 
 

    


0001 #!/bin/bash
0002 ##
0003 ## @brief @(#) Basic cache calls
0004 ##
0005 ## @file 01_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="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 #
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 NDRX_CCTAG=dom1
0069 }
0070 
0071 source ./test-func-include.sh
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 *dom*.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 RET=0
0101 
0102 xadmin psc
0103 xadmin ppm
0104 echo "Running off client"
0105 
0106 set_dom1;
0107 (time ./01_atmiclt48 2>&1) > ./01_atmiclt.log
0108 #(valgrind --leak-check=full --log-file="v.out" -v ./atmiclt48 2>&1) > ./atmiclt-dom1.log
0109 
0110 RET=$?
0111 
0112 echo "Show cache... "
0113 
0114 xadmin cs -d db01
0115 
0116 TMP=$?
0117 
0118 echo "xadmin ret $TMP"
0119 
0120 if [ $TMP -ne 0 ]; then
0121     echo "xadmin failed"
0122     go_out 1
0123 fi
0124 
0125 ensure_keys db01 40
0126 
0127 
0128 #
0129 # Test with out -d...
0130 #
0131 
0132 xadmin cs db01
0133 
0134 TMP=$?
0135 
0136 echo "xadmin ret $TMP"
0137 
0138 if [ $TMP -ne 0 ]; then
0139     echo "xadmin failed"
0140     go_out 2
0141 fi
0142 
0143 
0144 #
0145 # Dump record
0146 #
0147 xadmin cd -d db01 -k SV1HELLO-1 -i
0148 
0149 TMP=$?
0150 
0151 echo "xadmin ret $TMP"
0152 
0153 if [ $TMP -ne 0 ]; then
0154     echo "xadmin failed dump record failed"
0155     go_out 3
0156 fi
0157 
0158 
0159 #
0160 # Delete (invalidate) by regexp, all keys containing 2
0161 #
0162 
0163 xadmin ci -d db01 -k '.*2.*' -r
0164 
0165 TMP=$?
0166 
0167 echo "xadmin ret $TMP"
0168 
0169 if [ $TMP -ne 0 ]; then
0170     echo "xadmin failed dump record failed"
0171     go_out 4
0172 fi
0173 
0174 #
0175 # Validate record count
0176 #
0177 
0178 echo "After delete: "
0179 
0180 xadmin cs -d db01
0181 
0182 ensure_keys db01 27
0183 
0184 # Catch is there is test error!!!
0185 if [ "X`grep TESTERROR *.log`" != "X" ]; then
0186     echo "Test error detected!"
0187     go_out 5
0188 fi
0189 
0190 
0191 go_out $RET
0192 
0193 # vim: set ts=4 sw=4 et smartindent: