Back to home page

Enduro/X

 
 

    


0001 /**
0002  * @brief Housekeeping testing
0003  *
0004  * @file atmiclt35.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 
0039 #include <atmi.h>
0040 #include <ubf.h>
0041 #include <ndebug.h>
0042 #include <test.fd.h>
0043 #include <ndrstandard.h>
0044 /*---------------------------Externs------------------------------------*/
0045 /*---------------------------Macros-------------------------------------*/
0046 /*---------------------------Enums--------------------------------------*/
0047 /*---------------------------Typedefs-----------------------------------*/
0048 /*---------------------------Globals------------------------------------*/
0049 /*---------------------------Statics------------------------------------*/
0050 /*---------------------------Prototypes---------------------------------*/
0051 
0052 /*
0053  * Do the test call to the server
0054  */
0055 void do_thread_work ( void *ptr )
0056 {
0057     char tmp[511];
0058     int i=0;
0059     
0060     /* we will configure to lower log level... with two messages one at lower another at higher*/
0061     snprintf(tmp, sizeof(tmp), "ndrx=4 file=./%s", (char *)ptr);
0062     
0063     if (EXSUCCEED!=tplogconfig(LOG_FACILITY_NDRX_THREAD, EXFAIL, tmp, "", ""))
0064     {
0065         NDRX_LOG(log_error, "TESTERROR! Failed to configure logger");
0066         exit(1);
0067     }
0068     
0069     do
0070     {
0071         i++;
0072         NDRX_LOG(log_debug, "HELLO LEV 5 - step %d", i);
0073         NDRX_LOG(log_info, "HELLO LEV 4 - step %d", i);
0074         usleep(1000);
0075     } while (1);
0076 }
0077 
0078 /*
0079  * Do the test call to the server
0080  */
0081 int main(int argc, char** argv) 
0082 {
0083     int i=0;
0084     pthread_t thread1, thread2;
0085     void *arg1 = "CLT1.log";
0086     void *arg2 = "CLT2.log";
0087     
0088     tpinit(NULL); /* pull off init from main thread too... */
0089     
0090     /* create threads 1 and 2 */    
0091     pthread_create (&thread1, NULL, (void *) &do_thread_work, arg1);
0092     pthread_create (&thread2, NULL, (void *) &do_thread_work, arg2);
0093 
0094     /* also main thread is doing writes  -> this will init form cpm... */
0095     do
0096     {
0097         i++;
0098         NDRX_LOG(log_debug, "HELLO LEV 5 - step %d", i);
0099         NDRX_LOG(log_info, "HELLO LEV 4 - step %d", i);
0100         usleep(1000);
0101     } while (1);
0102     
0103     exit(0);
0104 }
0105 
0106 /* vim: set ts=4 sw=4 et smartindent: */