607 lines
		
	
	
		
			21 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			607 lines
		
	
	
		
			21 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
 * This file is distributed as part of the MariaDB Corporation MaxScale.  It is free
 | 
						|
 * software: you can redistribute it and/or modify it under the terms of the
 | 
						|
 * GNU General Public License as published by the Free Software Foundation,
 | 
						|
 * version 2.
 | 
						|
 *
 | 
						|
 * This program is distributed in the hope that it will be useful, but WITHOUT
 | 
						|
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 | 
						|
 * FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more
 | 
						|
 * details.
 | 
						|
 *
 | 
						|
 * You should have received a copy of the GNU General Public License along with
 | 
						|
 * this program; if not, write to the Free Software Foundation, Inc., 51
 | 
						|
 * Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
 | 
						|
 *
 | 
						|
 * Copyright MariaDB Corporation Ab 2013-2014
 | 
						|
 */
 | 
						|
 | 
						|
 | 
						|
/** @file 
 | 
						|
@brief (brief description)
 | 
						|
 | 
						|
*/
 | 
						|
#include <stdio.h>
 | 
						|
#include <stdlib.h>
 | 
						|
#include <string.h>
 | 
						|
#include <skygw_utils.h>
 | 
						|
#include <log_manager.h>
 | 
						|
 | 
						|
typedef struct thread_st {
 | 
						|
        skygw_message_t* mes;
 | 
						|
        simple_mutex_t*  mtx;
 | 
						|
        size_t*          nactive;
 | 
						|
        pthread_t        tid;
 | 
						|
} thread_t;
 | 
						|
 | 
						|
static void* thr_run(void* data);
 | 
						|
static void* thr_run_morelog(void* data);
 | 
						|
 | 
						|
#define MAX_NTHR 256
 | 
						|
#define NITER 100
 | 
						|
 | 
						|
#if 1
 | 
						|
#  define TEST1
 | 
						|
#endif
 | 
						|
 | 
						|
#if 0
 | 
						|
#  define TEST2
 | 
						|
#endif
 | 
						|
 | 
						|
#define TEST3
 | 
						|
#define TEST4
 | 
						|
 | 
						|
int main(int argc, char* argv[])
 | 
						|
{
 | 
						|
        int           err = 0;
 | 
						|
        char*         logstr;
 | 
						|
        
 | 
						|
        int              i;
 | 
						|
        bool             succp;
 | 
						|
        skygw_message_t* mes;
 | 
						|
        simple_mutex_t*  mtx;
 | 
						|
        size_t           nactive;
 | 
						|
        thread_t**       thr = NULL;
 | 
						|
        time_t           t;
 | 
						|
        struct tm        tm;
 | 
						|
        char             c;
 | 
						|
        int              nthr = 0;
 | 
						|
        int              log_argc = 0;
 | 
						|
        char**           log_argv = NULL;
 | 
						|
 | 
						|
        while ((c = getopt(argc, argv, "t:")) != -1)
 | 
						|
        {
 | 
						|
                switch (c) {
 | 
						|
                case 't':
 | 
						|
                        nthr = atoi(optarg);
 | 
						|
                        break;
 | 
						|
 | 
						|
                default:
 | 
						|
                        break;
 | 
						|
                }
 | 
						|
        }
 | 
						|
 | 
						|
        if (nthr <= 0)
 | 
						|
        {
 | 
						|
                fprintf(stderr, "Thread count argument is zero or "
 | 
						|
                        "negative. Exiting.\n");
 | 
						|
                err = 1;
 | 
						|
                goto return_err;
 | 
						|
        }
 | 
						|
 | 
						|
        thr = (thread_t **)calloc(1, nthr*sizeof(thread_t*));
 | 
						|
        
 | 
						|
        if (thr == NULL)
 | 
						|
        {
 | 
						|
                fprintf(stderr, "Failed to allocate memory for thread "
 | 
						|
                        "structure. Exiting.\n");
 | 
						|
                err = 1;
 | 
						|
                goto return_err;
 | 
						|
            
 | 
						|
        }
 | 
						|
        i = atexit(skygw_logmanager_exit);
 | 
						|
        
 | 
						|
        if (i != 0) {
 | 
						|
                fprintf(stderr, "Couldn't register exit function.\n");
 | 
						|
        }
 | 
						|
        
 | 
						|
        succp = skygw_logmanager_init( log_argc, log_argv);
 | 
						|
        ss_dassert(succp);
 | 
						|
 | 
						|
        t = time(NULL);
 | 
						|
        tm = *(localtime(&t));
 | 
						|
        err = skygw_log_write_flush(LOGFILE_ERROR,
 | 
						|
                                    "%04d %02d/%02d %02d.%02d.%02d",
 | 
						|
                                    tm.tm_year+1900,
 | 
						|
                                    tm.tm_mon+1,
 | 
						|
                                    tm.tm_mday,
 | 
						|
                                    tm.tm_hour,
 | 
						|
                                    tm.tm_min,
 | 
						|
                                    tm.tm_sec);
 | 
						|
        
 | 
						|
        skygw_logmanager_init( log_argc, log_argv);
 | 
						|
        logstr = ("First write with flush.");
 | 
						|
        err = skygw_log_write_flush(LOGFILE_ERROR, logstr);
 | 
						|
 | 
						|
        logstr = ("Second write with flush.");
 | 
						|
        err = skygw_log_write_flush(LOGFILE_ERROR, logstr);
 | 
						|
 | 
						|
        logstr = ("Third write, no flush.");
 | 
						|
        err = skygw_log_write(LOGFILE_ERROR, logstr);
 | 
						|
 | 
						|
        logstr = ("Fourth write, no flush. Next flush only.");
 | 
						|
        err = skygw_log_write(LOGFILE_ERROR, logstr);
 | 
						|
 | 
						|
        err = skygw_log_flush(LOGFILE_ERROR);        
 | 
						|
        
 | 
						|
        logstr = "My name is %s %d years and %d months.";
 | 
						|
#if !defined(SS_DEBUG)
 | 
						|
        skygw_log_enable(LOGFILE_TRACE);
 | 
						|
#endif
 | 
						|
        err = skygw_log_write(LOGFILE_TRACE, logstr, "TraceyTracey", 3, 7);
 | 
						|
        skygw_log_flush(LOGFILE_TRACE);
 | 
						|
#if !defined(SS_DEBUG)
 | 
						|
        skygw_log_enable(LOGFILE_TRACE);
 | 
						|
#endif
 | 
						|
        logstr = "My name is Tracey Tracey 47 years and 7 months.";
 | 
						|
        err = skygw_log_write(LOGFILE_TRACE, logstr);
 | 
						|
#if !defined(SS_DEBUG)
 | 
						|
        skygw_log_enable(LOGFILE_TRACE);
 | 
						|
#endif        
 | 
						|
        logstr = "My name is Stacey %s";
 | 
						|
        err = skygw_log_write_flush(LOGFILE_TRACE, logstr, "           ");
 | 
						|
        skygw_logmanager_done();
 | 
						|
#if !defined(SS_DEBUG)
 | 
						|
        skygw_log_enable(LOGFILE_TRACE);
 | 
						|
#endif
 | 
						|
        logstr = "My name is Philip";
 | 
						|
        err = skygw_log_write(LOGFILE_TRACE, logstr);
 | 
						|
#if !defined(SS_DEBUG)
 | 
						|
        skygw_log_enable(LOGFILE_TRACE);
 | 
						|
#endif
 | 
						|
        logstr = "Philip.";
 | 
						|
        err = skygw_log_write(LOGFILE_TRACE, logstr);
 | 
						|
#if !defined(SS_DEBUG)
 | 
						|
        skygw_log_enable(LOGFILE_TRACE);
 | 
						|
#endif
 | 
						|
        logstr = "Ph%dlip.";
 | 
						|
        err = skygw_log_write(LOGFILE_TRACE, logstr, 1);
 | 
						|
        
 | 
						|
        skygw_logmanager_init( log_argc, log_argv);
 | 
						|
        logstr = ("A terrible error has occurred!");
 | 
						|
        err = skygw_log_write_flush(LOGFILE_ERROR, logstr);
 | 
						|
 | 
						|
        logstr = ("Hi, how are you?");
 | 
						|
        err = skygw_log_write(LOGFILE_MESSAGE, logstr);
 | 
						|
 | 
						|
        logstr = ("I'm doing fine!");
 | 
						|
        err = skygw_log_write(LOGFILE_MESSAGE, logstr);
 | 
						|
 | 
						|
        logstr = ("Rather more surprising, at least at first sight, is the fact that a reference to a[i] can also be written as *(a+i). In evaluating a[i], C converts it to *(a+i) immediately; the two forms are equivalent. Applying the operators & to both parts of this equivalence, it follows that &a[i] and a+i are also identical: a+i is the address of the i-th element beyond a.");
 | 
						|
        err = skygw_log_write(LOGFILE_ERROR, logstr);
 | 
						|
 | 
						|
        logstr = ("I was wondering, you know, it has been such a lovely weather whole morning and I thought that would you like to come to my place and have a little piece of cheese with us. Just me and my mom - and you, of course. Then, if you wish, we could listen to the radio and keep company for our little Steven, my mom's cat, you know.");
 | 
						|
        err = skygw_log_write(LOGFILE_MESSAGE, logstr);
 | 
						|
        skygw_logmanager_done();
 | 
						|
 | 
						|
#if defined(TEST1)
 | 
						|
        
 | 
						|
        mes = skygw_message_init();
 | 
						|
        mtx = simple_mutex_init(NULL, "testmtx");
 | 
						|
        /** Test starts */
 | 
						|
 | 
						|
        fprintf(stderr, "\nStarting test #1 \n");
 | 
						|
        
 | 
						|
        /** 1 */
 | 
						|
        for (i=0; i<nthr; i++) {
 | 
						|
                thr[i] = (thread_t*)calloc(1, sizeof(thread_t));
 | 
						|
                thr[i]->mes = mes;
 | 
						|
                thr[i]->mtx = mtx;
 | 
						|
                thr[i]->nactive = &nactive;
 | 
						|
        }
 | 
						|
        nactive = nthr;
 | 
						|
 | 
						|
        for (i=0; i<nthr; i++)  {
 | 
						|
                pthread_t p;
 | 
						|
                pthread_create(&p, NULL, thr_run, thr[i]);
 | 
						|
                thr[i]->tid = p;
 | 
						|
        }
 | 
						|
 | 
						|
        do {
 | 
						|
                skygw_message_wait(mes);
 | 
						|
                simple_mutex_lock(mtx, true);
 | 
						|
                if (nactive > 0) {
 | 
						|
                        simple_mutex_unlock(mtx);
 | 
						|
                        continue;
 | 
						|
                }
 | 
						|
                break;
 | 
						|
        } while(true);
 | 
						|
 | 
						|
        for (i=0; i<nthr; i++) {
 | 
						|
                pthread_join(thr[i]->tid, NULL);
 | 
						|
        }
 | 
						|
        /** This is to release memory */
 | 
						|
        skygw_logmanager_done();
 | 
						|
        
 | 
						|
        simple_mutex_unlock(mtx);
 | 
						|
        
 | 
						|
        for (i=0; i<nthr; i++) {
 | 
						|
                free(thr[i]);
 | 
						|
        }
 | 
						|
#endif
 | 
						|
 | 
						|
#if defined(TEST2)
 | 
						|
 | 
						|
        fprintf(stderr, "\nStarting test #2 \n");
 | 
						|
 | 
						|
        /** 2 */
 | 
						|
        for (i=0; i<nthr; i++) {
 | 
						|
                thr[i] = (thread_t*)calloc(1, sizeof(thread_t));
 | 
						|
                thr[i]->mes = mes;
 | 
						|
                thr[i]->mtx = mtx;
 | 
						|
                thr[i]->nactive = &nactive;
 | 
						|
        }
 | 
						|
        nactive = nthr;
 | 
						|
 | 
						|
        fprintf(stderr,
 | 
						|
                "\nLaunching %d threads, each iterating %d times.",
 | 
						|
                nthr,
 | 
						|
                NITER);
 | 
						|
        
 | 
						|
        for (i=0; i<nthr; i++)  {
 | 
						|
                pthread_t p;
 | 
						|
                pthread_create(&p, NULL, thr_run_morelog, thr[i]);
 | 
						|
                thr[i]->tid = p;
 | 
						|
        }
 | 
						|
 | 
						|
        fprintf(stderr, ".. done");
 | 
						|
 | 
						|
        fprintf(stderr, "\nStarting to wait threads.\n");
 | 
						|
        
 | 
						|
        do {
 | 
						|
                skygw_message_wait(mes);
 | 
						|
                simple_mutex_lock(mtx, true);
 | 
						|
                if (nactive > 0) {
 | 
						|
                        simple_mutex_unlock(mtx);
 | 
						|
                        continue;
 | 
						|
                }
 | 
						|
                break;
 | 
						|
        } while(true);
 | 
						|
 | 
						|
        for (i=0; i<nthr; i++) {
 | 
						|
                pthread_join(thr[i]->tid, NULL);
 | 
						|
        }
 | 
						|
        /** This is to release memory */
 | 
						|
        skygw_logmanager_done();
 | 
						|
        
 | 
						|
        simple_mutex_unlock(mtx);
 | 
						|
 | 
						|
        fprintf(stderr, "\nFreeing thread memory.");
 | 
						|
        
 | 
						|
        for (i=0; i<nthr; i++) {
 | 
						|
                free(thr[i]);
 | 
						|
        }
 | 
						|
 | 
						|
        /** Test ended here */
 | 
						|
        skygw_message_done(mes);
 | 
						|
        simple_mutex_done(mtx);
 | 
						|
#endif /* TEST 2 */
 | 
						|
        
 | 
						|
#if defined(TEST3)
 | 
						|
 | 
						|
        /**
 | 
						|
         * Test enable/disable log.
 | 
						|
         */
 | 
						|
#if !defined(SS_DEBUG)
 | 
						|
        skygw_log_enable(LOGFILE_TRACE);
 | 
						|
#endif
 | 
						|
        logstr = ("\tTEST 3 - test enabling and disabling logs.");
 | 
						|
        err = skygw_log_write(LOGFILE_ERROR, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
 | 
						|
        succp = skygw_logmanager_init(log_argc, log_argv);
 | 
						|
        ss_dassert(succp);
 | 
						|
 | 
						|
        skygw_log_disable(LOGFILE_TRACE);
 | 
						|
                
 | 
						|
        logstr = ("1.\tWrite once to ERROR and twice to MESSAGE log.");
 | 
						|
        err = skygw_log_write(LOGFILE_MESSAGE, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
        err = skygw_log_write(LOGFILE_TRACE, logstr);
 | 
						|
        ss_dassert(err != 0); /**< Must fail */
 | 
						|
        err = skygw_log_write(LOGFILE_ERROR, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
        
 | 
						|
        skygw_log_enable(LOGFILE_TRACE);
 | 
						|
 | 
						|
        logstr = ("2.\tWrite to once to ERROR, twice to MESSAGE and "
 | 
						|
                  "three times to TRACE log.");
 | 
						|
        err = skygw_log_write(LOGFILE_MESSAGE, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
        err = skygw_log_write(LOGFILE_TRACE, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
        err = skygw_log_write(LOGFILE_ERROR, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
        
 | 
						|
        skygw_log_disable(LOGFILE_ERROR);
 | 
						|
 | 
						|
        logstr = ("3.\tWrite to once to MESSAGE and twice to TRACE log.");
 | 
						|
        err = skygw_log_write(LOGFILE_MESSAGE, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
        err = skygw_log_write(LOGFILE_TRACE, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
        err = skygw_log_write(LOGFILE_ERROR, logstr);
 | 
						|
        ss_dassert(err != 0); /**< Must fail */
 | 
						|
 | 
						|
        skygw_log_disable(LOGFILE_MESSAGE);
 | 
						|
        skygw_log_disable(LOGFILE_TRACE);
 | 
						|
 | 
						|
        logstr = ("4.\tWrite to none.");
 | 
						|
        err = skygw_log_write(LOGFILE_MESSAGE, logstr);
 | 
						|
        ss_dassert(err != 0); /**< Must fail */
 | 
						|
        err = skygw_log_write(LOGFILE_TRACE, logstr);
 | 
						|
        ss_dassert(err != 0); /**< Must fail */
 | 
						|
        err = skygw_log_write(LOGFILE_ERROR, logstr);
 | 
						|
        ss_dassert(err != 0); /**< Must fail */
 | 
						|
 | 
						|
        skygw_log_enable(LOGFILE_ERROR);
 | 
						|
        skygw_log_enable(LOGFILE_MESSAGE);
 | 
						|
 | 
						|
        logstr = ("4.\tWrite once to ERROR and twice to MESSAGE log.");
 | 
						|
        err = skygw_log_write(LOGFILE_MESSAGE, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
        err = skygw_log_write(LOGFILE_TRACE, logstr);
 | 
						|
        ss_dassert(err != 0); /**< Must fail */
 | 
						|
        err = skygw_log_write(LOGFILE_ERROR, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
 | 
						|
        skygw_logmanager_done();
 | 
						|
        
 | 
						|
#endif /* TEST 3 */
 | 
						|
 | 
						|
#if defined(TEST4)
 | 
						|
        succp = skygw_logmanager_init(log_argc, log_argv);
 | 
						|
        ss_dassert(succp);
 | 
						|
#if !defined(SS_DEBUG)
 | 
						|
        skygw_log_enable(LOGFILE_TRACE);
 | 
						|
#endif
 | 
						|
        logstr = ("\tTEST 4 - test spreading logs down to other logs.");
 | 
						|
        err = skygw_log_write(LOGFILE_ERROR, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
 | 
						|
        logstr = ("1.\tWrite to ERROR and thus also to MESSAGE and TRACE logs.");
 | 
						|
        err = skygw_log_write(LOGFILE_ERROR, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
 | 
						|
        logstr = ("2.\tWrite to MESSAGE and thus to TRACE logs.");
 | 
						|
        err = skygw_log_write(LOGFILE_MESSAGE, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
 | 
						|
        logstr = ("3.\tWrite to TRACE log only.");
 | 
						|
        err = skygw_log_write(LOGFILE_TRACE, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
 | 
						|
        skygw_log_disable(LOGFILE_MESSAGE);
 | 
						|
 | 
						|
        logstr = ("4.\tWrite to ERROR and thus also to TRACE log. "
 | 
						|
                  "MESSAGE is disabled.");
 | 
						|
        err = skygw_log_write(LOGFILE_ERROR, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
        
 | 
						|
        logstr = ("5.\tThis should not appear anywhere since MESSAGE "
 | 
						|
                  "is disabled.");
 | 
						|
        err = skygw_log_write(LOGFILE_MESSAGE, logstr);
 | 
						|
        ss_dassert(err != 0);
 | 
						|
        
 | 
						|
        skygw_logmanager_done();
 | 
						|
 | 
						|
        succp = skygw_logmanager_init(log_argc, log_argv);
 | 
						|
        ss_dassert(succp);
 | 
						|
#if !defined(SS_DEBUG)
 | 
						|
        skygw_log_enable(LOGFILE_TRACE);
 | 
						|
#endif  
 | 
						|
        logstr = ("6.\tWrite to ERROR and thus also to MESSAGE and TRACE logs.");
 | 
						|
        err = skygw_log_write_flush(LOGFILE_ERROR, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
 | 
						|
        logstr = ("7.\tWrite to MESSAGE and thus to TRACE logs.");
 | 
						|
        err = skygw_log_write_flush(LOGFILE_MESSAGE, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
 | 
						|
        logstr = ("8.\tWrite to TRACE log only.");
 | 
						|
        skygw_log_enable(LOGFILE_TRACE);
 | 
						|
        err = skygw_log_write_flush(LOGFILE_TRACE, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
 | 
						|
        skygw_log_disable(LOGFILE_MESSAGE);
 | 
						|
 | 
						|
        logstr = ("9.\tWrite to ERROR and thus also to TRACE log. "
 | 
						|
                  "MESSAGE is disabled");
 | 
						|
        err = skygw_log_write_flush(LOGFILE_ERROR, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
        
 | 
						|
        logstr = ("10.\tThis should not appear anywhere since MESSAGE is "
 | 
						|
                  "disabled.");
 | 
						|
        err = skygw_log_write_flush(LOGFILE_MESSAGE, logstr);
 | 
						|
        ss_dassert(err != 0);
 | 
						|
 | 
						|
        skygw_log_enable(LOGFILE_MESSAGE);
 | 
						|
 | 
						|
        err = skygw_log_write(LOGFILE_ERROR,
 | 
						|
                              "11.\tWrite to all logs some formattings : "
 | 
						|
                              "%d %s %d",
 | 
						|
                              (int)3,
 | 
						|
                              "foo",
 | 
						|
                              (int)3);
 | 
						|
        err = skygw_log_write(LOGFILE_MESSAGE,
 | 
						|
                              "12.\tWrite to MESSAGE and TRACE log some "
 | 
						|
                              "formattings "
 | 
						|
                              ": %d %s %d",
 | 
						|
                              (int)3,
 | 
						|
                              "foo",
 | 
						|
                              (int)3);
 | 
						|
        err = skygw_log_write(LOGFILE_TRACE,
 | 
						|
                              "13.\tWrite to TRACE log some formattings "
 | 
						|
                              ": %d %s %d",
 | 
						|
                              (int)3,
 | 
						|
                              "foo",
 | 
						|
                              (int)3);
 | 
						|
                
 | 
						|
        ss_dassert(err == 0);
 | 
						|
 | 
						|
        
 | 
						|
        skygw_logmanager_done();
 | 
						|
 | 
						|
        
 | 
						|
#endif /* TEST 4 */
 | 
						|
        fprintf(stderr, ".. done.\n");
 | 
						|
return_err:
 | 
						|
        if (thr != NULL)
 | 
						|
        {
 | 
						|
                free(thr);
 | 
						|
        }
 | 
						|
        return err;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
static void* thr_run(
 | 
						|
        void* data)
 | 
						|
{
 | 
						|
        thread_t* td = (thread_t *)data;
 | 
						|
        char*     logstr;
 | 
						|
        int       err;
 | 
						|
 | 
						|
        skygw_logmanager_init( 0, NULL);
 | 
						|
        skygw_logmanager_done();
 | 
						|
        skygw_log_flush(LOGFILE_MESSAGE);
 | 
						|
        logstr = ("Hi, how are you?");
 | 
						|
        err = skygw_log_write(LOGFILE_MESSAGE, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
        skygw_logmanager_done();
 | 
						|
        skygw_log_flush(LOGFILE_TRACE);
 | 
						|
        skygw_log_flush(LOGFILE_MESSAGE);
 | 
						|
        logstr = ("I was wondering, you know, it has been such a lovely weather whole morning and I thought that would you like to come to my place and have a little piece of cheese with us. Just me and my mom - and you, of course. Then, if you wish, we could listen to the radio and keep company for our little Steven, my mom's cat, you know.");
 | 
						|
        ss_dassert(err == 0);
 | 
						|
        err = skygw_log_write(LOGFILE_MESSAGE, logstr);
 | 
						|
        skygw_logmanager_init( 0, NULL);
 | 
						|
        logstr = ("Testing. One, two, three\n");
 | 
						|
        err = skygw_log_write(LOGFILE_ERROR, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
        skygw_logmanager_init( 0, NULL);
 | 
						|
        skygw_logmanager_init( 0, NULL);
 | 
						|
        skygw_log_flush(LOGFILE_ERROR);
 | 
						|
        logstr = ("For automatic and register variables, it is done each time the function or block is entered.");
 | 
						|
 | 
						|
        skygw_log_enable(LOGFILE_TRACE);
 | 
						|
        err = skygw_log_write(LOGFILE_TRACE, logstr);
 | 
						|
        ss_dassert(err == 0);    
 | 
						|
        skygw_logmanager_done();
 | 
						|
        skygw_logmanager_init( 0, NULL);
 | 
						|
        logstr = ("Rather more surprising, at least at first sight, is the fact that a reference to a[i] can also be written as *(a+i). In evaluating a[i], C converts it to *(a+i) immediately; the two forms are equivalent. Applying the operatos & to both parts of this equivalence, it follows that &a[i] and a+i are also identical: a+i is the address of the i-th element beyond a.");
 | 
						|
        err = skygw_log_write(LOGFILE_ERROR, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
        skygw_logmanager_init( 0, NULL);
 | 
						|
        skygw_logmanager_done();
 | 
						|
        skygw_log_flush(LOGFILE_ERROR);
 | 
						|
        skygw_logmanager_done();
 | 
						|
        skygw_logmanager_done();
 | 
						|
        logstr = ("..and you?");
 | 
						|
        err = skygw_log_write(LOGFILE_MESSAGE, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
        skygw_logmanager_init( 0, NULL);
 | 
						|
        skygw_logmanager_init( 0, NULL);
 | 
						|
        logstr = ("For automatic and register variables, it is done each time the function or block is entered.");
 | 
						|
#if !defined(SS_DEBUG)
 | 
						|
        skygw_log_enable(LOGFILE_TRACE);
 | 
						|
#endif
 | 
						|
        err = skygw_log_write(LOGFILE_TRACE, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
        skygw_logmanager_init( 0, NULL);
 | 
						|
        logstr = ("Rather more surprising, at least at first sight, is the fact that a reference to a[i] can also be written as *(a+i). In evaluating a[i], C converts it to *(a+i) immediately; the two forms are equivalent. Applying the operatos & to both parts of this equivalence, it follows that &a[i] and a+i are also identical: a+i is the address of the i-th element beyond a.");
 | 
						|
        err = skygw_log_write(LOGFILE_ERROR, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
        skygw_logmanager_init( 0, NULL);
 | 
						|
        logstr = ("..... and you too?");
 | 
						|
        err = skygw_log_write(LOGFILE_MESSAGE, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
        skygw_logmanager_done();
 | 
						|
#if !defined(SS_DEBUG)
 | 
						|
        skygw_log_enable(LOGFILE_TRACE);
 | 
						|
#endif
 | 
						|
        skygw_log_flush(LOGFILE_TRACE);
 | 
						|
        logstr = ("For automatic and register variables, it is done each time the function or block is entered.");
 | 
						|
#if !defined(SS_DEBUG)
 | 
						|
        skygw_log_enable(LOGFILE_TRACE);
 | 
						|
#endif
 | 
						|
        err = skygw_log_write(LOGFILE_TRACE, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
        skygw_logmanager_done();
 | 
						|
        logstr = ("Testing. One, two, three, four\n");
 | 
						|
        err = skygw_log_write(LOGFILE_ERROR, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
        skygw_logmanager_init( 0, NULL);
 | 
						|
        logstr = ("Testing. One, two, three, .. where was I?\n");
 | 
						|
        err = skygw_log_write(LOGFILE_ERROR, logstr);
 | 
						|
        ss_dassert(err == 0);
 | 
						|
        skygw_logmanager_init( 0, NULL);
 | 
						|
        skygw_logmanager_init( 0, NULL);
 | 
						|
        skygw_logmanager_done();
 | 
						|
        simple_mutex_lock(td->mtx, true);
 | 
						|
        *td->nactive -= 1;
 | 
						|
        simple_mutex_unlock(td->mtx);
 | 
						|
        skygw_message_send(td->mes);
 | 
						|
        return NULL;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
static int nstr(
 | 
						|
        char** str_arr)
 | 
						|
{
 | 
						|
        int   i;
 | 
						|
 | 
						|
        for (i=0; str_arr[i] != NULL; i++) {
 | 
						|
        }
 | 
						|
        return i;
 | 
						|
}
 | 
						|
 | 
						|
char* logs[] = {
 | 
						|
        "foo",
 | 
						|
        "bar",
 | 
						|
        "done",
 | 
						|
        "critical test logging",
 | 
						|
        "longer          test                   l o g g g i n g",
 | 
						|
        "reeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeally loooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooong line",
 | 
						|
        "shoorter one",
 | 
						|
        "two",
 | 
						|
        "scrap : 834nuft984pnw8ynup4598yp8wup8upwn48t5gpn45",
 | 
						|
        "more the same : f98uft5p8ut2p44449upnt5",
 | 
						|
        "asdasd987987asdasd987987asdasd987987asdasd987987asdasd987987asdasd987987asdasd987987asdasd98987",
 | 
						|
        NULL
 | 
						|
};
 | 
						|
 | 
						|
 | 
						|
 | 
						|
static void* thr_run_morelog(
 | 
						|
        void* data)
 | 
						|
{
 | 
						|
        thread_t* td = (thread_t *)data;
 | 
						|
        int       err;
 | 
						|
        int       i;
 | 
						|
        int       nmsg;
 | 
						|
 | 
						|
        nmsg = nstr(logs);
 | 
						|
        
 | 
						|
        for (i=0; i<NITER; i++) {
 | 
						|
                char* str = logs[rand()%nmsg];
 | 
						|
                err = skygw_log_write((logfile_id_t)(rand()%(LOGFILE_LAST+1)),
 | 
						|
                                      "%s - iteration # %d",
 | 
						|
                                      str,
 | 
						|
                                      i);
 | 
						|
        }
 | 
						|
        simple_mutex_lock(td->mtx, true);
 | 
						|
        *td->nactive -= 1;
 | 
						|
        simple_mutex_unlock(td->mtx);
 | 
						|
        skygw_message_send(td->mes);        
 | 
						|
        return NULL;
 | 
						|
}
 |