![]() |
|
|||
0001 /** 0002 * @brief Check Bug #501 - firstly process dies, then slow start. At shutdown gets started... - server 0003 * 0004 * @file atmisv77.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 <errno.h> 0044 #include "test77.h" 0045 0046 /*---------------------------Externs------------------------------------*/ 0047 /*---------------------------Macros-------------------------------------*/ 0048 /*---------------------------Enums--------------------------------------*/ 0049 /*---------------------------Typedefs-----------------------------------*/ 0050 /*---------------------------Globals------------------------------------*/ 0051 /*---------------------------Statics------------------------------------*/ 0052 /*---------------------------Prototypes---------------------------------*/ 0053 0054 /** 0055 * Standard service entry 0056 */ 0057 void TESTSV (TPSVCINFO *p_svc) 0058 { 0059 int ret=EXSUCCEED; 0060 char testbuf[1024]; 0061 UBFH *p_ub = (UBFH *)p_svc->data; 0062 0063 NDRX_LOG(log_debug, "%s got call", __func__); 0064 0065 /* Just print the buffer */ 0066 Bprint(p_ub); 0067 0068 if (EXFAIL==Bget(p_ub, T_STRING_FLD, 0, testbuf, 0)) 0069 { 0070 NDRX_LOG(log_error, "TESTERROR: Failed to get T_STRING_FLD: %s", 0071 Bstrerror(Berror)); 0072 ret=EXFAIL; 0073 goto out; 0074 } 0075 0076 if (0!=strcmp(testbuf, VALUE_EXPECTED)) 0077 { 0078 NDRX_LOG(log_error, "TESTERROR: Expected: [%s] got [%s]", 0079 VALUE_EXPECTED, testbuf); 0080 ret=EXFAIL; 0081 goto out; 0082 } 0083 0084 0085 out: 0086 tpreturn( ret==EXSUCCEED?TPSUCCESS:TPFAIL, 0087 0L, 0088 (char *)p_ub, 0089 0L, 0090 0L); 0091 } 0092 0093 /** 0094 * Do initialisation 0095 */ 0096 int NDRX_INTEGRA(tpsvrinit)(int argc, char **argv) 0097 { 0098 int ret = EXSUCCEED; 0099 NDRX_LOG(log_debug, "tpsvrinit called"); 0100 0101 if (EXSUCCEED!=tpadvertise("TESTSV", TESTSV)) 0102 { 0103 NDRX_LOG(log_error, "Failed to initialise TESTSV!"); 0104 EXFAIL_OUT(ret); 0105 } 0106 0107 /* if this is first time, then we shall create a file 0108 * and then fail. 0109 * 0110 * If file exists, then we sleep for some 10 seconds. 0111 * 0112 * mean while shell script will request shutdown. 0113 * 0114 * Expected output is process shut-down 0115 * but as of Bug #501 the shutdown process shows that this binary is 0116 * started. 0117 */ 0118 0119 if (ndrx_file_exists("./first-indicator.txt")) 0120 { 0121 sleep(10); 0122 } 0123 else 0124 { 0125 if (EXSUCCEED!=ndrx_file_touch("./first-indicator.txt")) 0126 { 0127 int err = errno; 0128 NDRX_LOG(log_error, "TESTERROR! Failed to create indicator: %s", 0129 tpstrerror(err)); 0130 } 0131 EXFAIL_OUT(ret); 0132 } 0133 out: 0134 return ret; 0135 } 0136 0137 /** 0138 * Do de-initialisation 0139 */ 0140 void NDRX_INTEGRA(tpsvrdone)(void) 0141 { 0142 NDRX_LOG(log_debug, "tpsvrdone called"); 0143 } 0144 0145 /* 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 |
![]() ![]() |