![]() |
|
|||
0001 /** 0002 * @brief tpadm .TMIB interface tests - server 0003 * 0004 * @file atmisv68.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 <stdio.h> 0035 #include <stdlib.h> 0036 #include <ndebug.h> 0037 #include <atmi.h> 0038 #include <ndrstandard.h> 0039 #include <ubf.h> 0040 #include <test.fd.h> 0041 #include <string.h> 0042 #include <unistd.h> 0043 #include "test68.h" 0044 0045 /*---------------------------Externs------------------------------------*/ 0046 /*---------------------------Macros-------------------------------------*/ 0047 /*---------------------------Enums--------------------------------------*/ 0048 /*---------------------------Typedefs-----------------------------------*/ 0049 /*---------------------------Globals------------------------------------*/ 0050 /*---------------------------Statics------------------------------------*/ 0051 /*---------------------------Prototypes---------------------------------*/ 0052 0053 /** 0054 * Have some conversational server 0055 * @param p_svc 0056 */ 0057 void CONVSV (TPSVCINFO *p_svc) 0058 { 0059 sleep(99); 0060 } 0061 0062 /** 0063 * Generate some failure 0064 * @param p_svc 0065 */ 0066 void FAILURESV (TPSVCINFO *p_svc) 0067 { 0068 tpreturn(TPFAIL, 0, NULL, 0, 0); 0069 } 0070 /** 0071 * Standard service entry 0072 */ 0073 void TESTSV (TPSVCINFO *p_svc) 0074 { 0075 int ret=EXSUCCEED; 0076 char testbuf[1024]; 0077 UBFH *p_ub = (UBFH *)p_svc->data; 0078 0079 NDRX_LOG(log_debug, "%s got call", __func__); 0080 0081 /* Just print the buffer */ 0082 Bprint(p_ub); 0083 0084 if (EXFAIL==Bget(p_ub, T_STRING_FLD, 0, testbuf, 0)) 0085 { 0086 NDRX_LOG(log_error, "TESTERROR: Failed to get T_STRING_FLD: %s", 0087 Bstrerror(Berror)); 0088 ret=EXFAIL; 0089 goto out; 0090 } 0091 0092 if (0!=strcmp(testbuf, VALUE_EXPECTED)) 0093 { 0094 NDRX_LOG(log_error, "TESTERROR: Expected: [%s] got [%s]", 0095 VALUE_EXPECTED, testbuf); 0096 ret=EXFAIL; 0097 goto out; 0098 } 0099 0100 /* TODO: Have some sleep each time 1 sec or 3 or 5 sec... 0101 * to measure min/max/last 0102 */ 0103 0104 out: 0105 tpreturn( ret==EXSUCCEED?TPSUCCESS:TPFAIL, 0106 0L, 0107 (char *)p_ub, 0108 0L, 0109 0L); 0110 } 0111 0112 /** 0113 * Do initialisation 0114 */ 0115 int NDRX_INTEGRA(tpsvrinit)(int argc, char **argv) 0116 { 0117 int ret = EXSUCCEED; 0118 NDRX_LOG(log_debug, "tpsvrinit called"); 0119 0120 if (EXSUCCEED!=tpadvertise("TESTSV", TESTSV)) 0121 { 0122 NDRX_LOG(log_error, "Failed to initialise TESTSV!"); 0123 EXFAIL_OUT(ret); 0124 } 0125 0126 if (EXSUCCEED!=tpadvertise("CONVSV", CONVSV)) 0127 { 0128 NDRX_LOG(log_error, "Failed to initialise CONVSV!"); 0129 EXFAIL_OUT(ret); 0130 } 0131 0132 if (EXSUCCEED!=tpadvertise("FAILSV", FAILURESV)) 0133 { 0134 NDRX_LOG(log_error, "Failed to initialise FAILSV!"); 0135 EXFAIL_OUT(ret); 0136 } 0137 0138 out: 0139 return ret; 0140 } 0141 0142 /** 0143 * Do de-initialisation 0144 */ 0145 void NDRX_INTEGRA(tpsvrdone)(void) 0146 { 0147 NDRX_LOG(log_debug, "tpsvrdone called"); 0148 } 0149 0150 /* 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 |
![]() ![]() |