113 lines
3.1 KiB
C
113 lines
3.1 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
|
|
*/
|
|
|
|
#include <unistd.h>
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <skygw_utils.h>
|
|
#include <log_manager.h>
|
|
|
|
int main(int argc, char** argv)
|
|
{
|
|
int iterations = 0, i, interval = 10;
|
|
int block_size;
|
|
int succp = 0, err = 0;
|
|
char cwd[1024];
|
|
char tmp[2048];
|
|
char *message;
|
|
char** optstr;
|
|
long msg_index = 1;
|
|
struct timespec ts1;
|
|
ts1.tv_sec = 0;
|
|
|
|
memset(cwd,0,1024);
|
|
if( argc <4){
|
|
fprintf(stderr,
|
|
"Log Manager Log Order Test\n"
|
|
"Writes an ascending number into the error log to determine if log writes are in order.\n"
|
|
"Usage:\t testorder <iterations> <frequency of log flushes> <size of message in bytes>\n");
|
|
return 1;
|
|
}
|
|
|
|
block_size = atoi(argv[3]);
|
|
if(block_size < 1 || block_size > 1024){
|
|
fprintf(stderr,"Message size too small or large, must be at least 1 byte long and must not exceed 1024 bytes.");
|
|
return 1;
|
|
}
|
|
|
|
|
|
if(getcwd(cwd,sizeof(cwd)) == NULL ||
|
|
(optstr = (char**)malloc(sizeof(char*)*4)) == NULL ||
|
|
(message = (char*)malloc(sizeof(char)*block_size))== NULL){
|
|
fprintf(stderr,"Fatal Error, exiting...");
|
|
return 1;
|
|
}
|
|
|
|
memset(tmp,0,1024);
|
|
|
|
sprintf(tmp,"%s",cwd);
|
|
optstr[0] = strdup("log_manager");
|
|
optstr[1] = strdup("-j");
|
|
optstr[2] = strdup(tmp);
|
|
optstr[3] = NULL;
|
|
|
|
iterations = atoi(argv[1]);
|
|
interval = atoi(argv[2]);
|
|
|
|
succp = skygw_logmanager_init( 3, optstr);
|
|
ss_dassert(succp);
|
|
|
|
skygw_log_disable(LOGFILE_TRACE);
|
|
skygw_log_disable(LOGFILE_MESSAGE);
|
|
skygw_log_disable(LOGFILE_DEBUG);
|
|
|
|
for(i = 0;i<iterations;i++){
|
|
|
|
sprintf(message,"message|%ld",msg_index++);
|
|
int msgsize = block_size - strlen(message);
|
|
if(msgsize < 0 || msgsize > 8192){
|
|
fprintf(stderr,"Error: Message too long");
|
|
break;
|
|
}
|
|
memset(message + strlen(message), ' ', msgsize);
|
|
memset(message + block_size - 1,'\0',1);
|
|
if(interval > 0 && i % interval == 0){
|
|
err = skygw_log_write_flush(LOGFILE_ERROR, message);
|
|
}else{
|
|
err = skygw_log_write(LOGFILE_ERROR, message);
|
|
}
|
|
if(err){
|
|
fprintf(stderr,"Error: log_manager returned %d",err);
|
|
break;
|
|
}
|
|
ts1.tv_nsec = 100*1000000;
|
|
nanosleep(&ts1, NULL);
|
|
}
|
|
|
|
skygw_log_flush(LOGFILE_ERROR);
|
|
skygw_logmanager_done();
|
|
free(message);
|
|
free(optstr[0]);
|
|
free(optstr[1]);
|
|
free(optstr[2]);
|
|
free(optstr[3]);
|
|
free(optstr);
|
|
return 0;
|
|
}
|