![]() |
|
|||
0001 /** 0002 * @brief Try counter testing 0003 * 0004 * @file atmiclt21-try.c 0005 */ 0006 /* ----------------------------------------------------------------------------- 0007 * Enduro/X Middleware Platform for Distributed Transaction Processing 0008 * Copyright (C) 2009-2016, ATR Baltic, Ltd. All Rights Reserved. 0009 * Copyright (C) 2017-2023, Mavimax, Ltd. All Rights Reserved. 0010 * This software is released under one of the following licenses: 0011 * AGPL (with Java and Go exceptions) or Mavimax's license for commercial use. 0012 * See LICENSE file for full text. 0013 * ----------------------------------------------------------------------------- 0014 * AGPL license: 0015 * 0016 * This program is free software; you can redistribute it and/or modify it under 0017 * the terms of the GNU Affero General Public License, version 3 as published 0018 * by the Free Software Foundation; 0019 * 0020 * This program is distributed in the hope that it will be useful, but WITHOUT ANY 0021 * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A 0022 * PARTICULAR PURPOSE. See the GNU Affero General Public License, version 3 0023 * for more details. 0024 * 0025 * You should have received a copy of the GNU Affero General Public License along 0026 * with this program; if not, write to the Free Software Foundation, Inc., 0027 * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 0028 * 0029 * ----------------------------------------------------------------------------- 0030 * A commercial use license is available from Mavimax, Ltd 0031 * contact@mavimax.com 0032 * ----------------------------------------------------------------------------- 0033 */ 0034 #include <string.h> 0035 #include <stdio.h> 0036 #include <stdlib.h> 0037 #include <memory.h> 0038 #include <math.h> 0039 #include <unistd.h> 0040 0041 #include <atmi.h> 0042 #include <ubf.h> 0043 #include <ndebug.h> 0044 #include <test.fd.h> 0045 #include <ndrstandard.h> 0046 #include <nstopwatch.h> 0047 /*---------------------------Externs------------------------------------*/ 0048 /*---------------------------Macros-------------------------------------*/ 0049 /*---------------------------Enums--------------------------------------*/ 0050 /*---------------------------Typedefs-----------------------------------*/ 0051 /*---------------------------Globals------------------------------------*/ 0052 /*---------------------------Statics------------------------------------*/ 0053 /*---------------------------Prototypes---------------------------------*/ 0054 0055 /* 0056 * Do the test call to the server 0057 */ 0058 int main(int argc, char** argv) { 0059 0060 UBFH *p_ub = (UBFH *)tpalloc("UBF", NULL, 9216); 0061 long rsplen; 0062 int i=0; 0063 int ret=EXSUCCEED; 0064 0065 if (EXSUCCEED!=tpopen()) 0066 { 0067 NDRX_LOG(log_error, "TESTERROR: tpopen() fail: %d:[%s]", 0068 tperrno, tpstrerror(tperrno)); 0069 ret=EXFAIL; 0070 goto out; 0071 } 0072 0073 /***************************************************************************/ 0074 NDRX_LOG(log_debug, "Testing Bug #105"); 0075 /***************************************************************************/ 0076 0077 if (EXSUCCEED!=tpbegin(5, 0)) 0078 { 0079 NDRX_LOG(log_error, "TESTERROR: tpbegin() fail: %d:[%s]", 0080 tperrno, tpstrerror(tperrno)); 0081 ret=EXFAIL; 0082 goto out; 0083 } 0084 0085 Bchg(p_ub, T_STRING_FLD, 0, "TEST HELLO WORLD COMMIT", 0L); 0086 0087 /* Call Svc1 */ 0088 if (EXFAIL == (ret=tpcall("RUNTX", (char *)p_ub, 0L, (char **)&p_ub, &rsplen,0))) 0089 { 0090 NDRX_LOG(log_error, "TX3SVC failed: %s", tpstrerror(tperrno)); 0091 ret=EXFAIL; 0092 goto out; 0093 } 0094 0095 /* RM will give error, thus not complete commit. Prepare will be ok. */ 0096 if (EXSUCCEED==tpcommit(0)) 0097 { 0098 NDRX_LOG(log_error, "TESTERROR: tpcommit()==%d fail: %d:[%s]", 0099 ret, tperrno, tpstrerror(tperrno)); 0100 ret=EXFAIL; 0101 goto out; 0102 } 0103 0104 if (TPEHAZARD!=tperrno) 0105 { 0106 NDRX_LOG(log_error, "TESTERROR: Expected TPEHAZARD, Got tpcommit()==%d fail: %d:[%s]", 0107 ret, tperrno, tpstrerror(tperrno)); 0108 0109 ret=EXFAIL; 0110 goto out; 0111 } 0112 0113 /***************************************************************************/ 0114 NDRX_LOG(log_debug, "Done..."); 0115 /***************************************************************************/ 0116 out: 0117 if (EXSUCCEED!=tpclose()) 0118 { 0119 NDRX_LOG(log_error, "TESTERROR: tpclose() fail: %d:[%s]", 0120 tperrno, tpstrerror(tperrno)); 0121 ret=EXFAIL; 0122 } 0123 0124 0125 tpterm(); 0126 0127 NDRX_LOG(log_error, "Exiting with %d", ret); 0128 0129 return ret; 0130 } 0131 0132 /* vim: set ts=4 sw=4 et smartindent: */
[ Source navigation ] | [ Diff markup ] | [ Identifier search ] | [ general search ] |
This page was automatically generated by the 2.1.0 LXR engine. The LXR team |
![]() ![]() |