added independent testing of the hint filter
This commit is contained in:
@ -1,6 +1,13 @@
|
||||
aux_source_directory(${CMAKE_SOURCE_DIR}/server/core CORE_ALL)
|
||||
foreach(VAR ${CORE_ALL})
|
||||
if(NOT( (${VAR} MATCHES "max[a-z_]*.c") OR (${VAR} MATCHES "gateway.c")))
|
||||
list(APPEND CORE ${VAR})
|
||||
endif()
|
||||
endforeach()
|
||||
|
||||
include_directories(${CMAKE_CURRENT_SOURCE_DIR})
|
||||
add_executable(harness_ui harness_ui.c harness_common.c)
|
||||
add_executable(harness harness_util.c harness_common.c)
|
||||
target_link_libraries(harness_ui log_manager utils pthread fullcore)
|
||||
target_link_libraries(harness log_manager utils pthread fullcore)
|
||||
add_test(TestHintfilter /bin/sh -c "${CMAKE_CURRENT_BINARY_DIR}/harness -i ${CMAKE_CURRENT_SOURCE_DIR}/hint_testing.input -o ${CMAKE_CURRENT_BINARY_DIR}/hint_testig.output -c ${CMAKE_CURRENT_SOURCE_DIR}/hint_testing.cnf -t 2 -s 10 && diff ${CMAKE_CURRENT_SOURCE_DIR}/hint_testing.expected ${CMAKE_CURRENT_BINARY_DIR}/hint_testig.output;exit $?")
|
||||
add_executable(harness harness_util.c harness_common.c ${CORE})
|
||||
target_link_libraries(harness_ui fullcore log_manager utils)
|
||||
target_link_libraries(harness fullcore)
|
||||
add_test(TestHintfilter /bin/sh -x -c "MAXSCALE_HOME=\"${CMAKE_BINARY_DIR}\" ${CMAKE_CURRENT_BINARY_DIR}/harness -i ${CMAKE_CURRENT_SOURCE_DIR}/hint_testing.input -o ${CMAKE_CURRENT_BINARY_DIR}/hint_testing.output -c ${CMAKE_CURRENT_SOURCE_DIR}/hint_testing.cnf -t 1 -s 1 && diff ${CMAKE_CURRENT_SOURCE_DIR}/hint_testing.expected ${CMAKE_CURRENT_BINARY_DIR}/hint_testing.output;exit $?")
|
||||
@ -68,7 +68,7 @@
|
||||
#include <atomic.h>
|
||||
#include <ini.h>
|
||||
#include <hint.h>
|
||||
|
||||
#include <modutil.h>
|
||||
/**
|
||||
* A single name-value pair and a link to the next item in the
|
||||
* configuration.
|
||||
|
||||
@ -158,12 +158,9 @@ int routeQuery(void* ins, void* session, GWBUF* queue)
|
||||
{
|
||||
|
||||
unsigned int buffsz = 0;
|
||||
unsigned char* ptr = (void*)queue->start;
|
||||
char *qstr;
|
||||
|
||||
buffsz += *ptr++;
|
||||
buffsz += *ptr++ << 8;
|
||||
buffsz += *ptr++ << 16;
|
||||
buffsz = (char*)queue->end - ((char*)queue->start + 5);
|
||||
|
||||
if(queue->hint){
|
||||
buffsz += 40;
|
||||
@ -175,12 +172,12 @@ int routeQuery(void* ins, void* session, GWBUF* queue)
|
||||
}
|
||||
}
|
||||
|
||||
qstr = calloc(buffsz,sizeof(char));
|
||||
qstr = calloc(buffsz + 1,sizeof(char));
|
||||
|
||||
if(qstr){
|
||||
memcpy(qstr,queue->start + 5,buffsz - 1);
|
||||
memcpy(qstr,queue->start + 5,buffsz);
|
||||
if(queue->hint){
|
||||
char *ptr = qstr + (int)(queue->end - 1 - (queue->start + 5));
|
||||
char *ptr = qstr + strlen(qstr);
|
||||
|
||||
switch(queue->hint->type){
|
||||
case HINT_ROUTE_TO_MASTER:
|
||||
@ -210,16 +207,17 @@ int routeQuery(void* ins, void* session, GWBUF* queue)
|
||||
default:
|
||||
sprintf(ptr,"|HINT_UNDEFINED");
|
||||
break;
|
||||
|
||||
}
|
||||
|
||||
ptr += strlen(ptr);
|
||||
ptr = qstr + strlen(qstr);
|
||||
if(queue->hint->data){
|
||||
sprintf(ptr,"|%s",(char*)queue->hint->data);
|
||||
ptr += strlen(ptr);
|
||||
ptr = qstr + strlen(qstr);
|
||||
}
|
||||
if(queue->hint->value){
|
||||
sprintf(ptr,"|%s",(char*)queue->hint->value);
|
||||
ptr += strlen(ptr);
|
||||
ptr = qstr + strlen(qstr);
|
||||
}
|
||||
}
|
||||
|
||||
@ -234,7 +232,7 @@ int routeQuery(void* ins, void* session, GWBUF* queue)
|
||||
}
|
||||
|
||||
if(instance.outfile>=0){
|
||||
write(instance.outfile,qstr,strnlen(qstr,buffsz));
|
||||
write(instance.outfile,qstr,strlen(qstr));
|
||||
write(instance.outfile,"\n",1);
|
||||
}
|
||||
|
||||
@ -508,7 +506,7 @@ int load_config( char* fname)
|
||||
if(!strcmp("module",item->name)){
|
||||
|
||||
if(instance.mod_dir){
|
||||
char* modstr = malloc(sizeof(char)*(strlen(instance.mod_dir) + strlen(item->value)));
|
||||
char* modstr = malloc(sizeof(char)*(strlen(instance.mod_dir) + strlen(item->value) + 1));
|
||||
strcpy(modstr,instance.mod_dir);
|
||||
strcat(modstr,"/");
|
||||
strcat(modstr,item->value);
|
||||
|
||||
@ -1,7 +1,7 @@
|
||||
select @@server_id; -- maxscale begin route to master
|
||||
select @@server_id;
|
||||
select @@server_id; -- maxscale begin route to master|HINT_ROUTE_TO_MASTER
|
||||
select @@server_id;|HINT_ROUTE_TO_MASTER
|
||||
select @@server_id; -- maxscale route to server server3|HINT_ROUTE_TO_NAMED_SERVER|server3
|
||||
select @@server_id;
|
||||
select @@server_id;|HINT_ROUTE_TO_MASTER
|
||||
select @@server_id; -- maxscale end
|
||||
select @@server_id; -- maxscale named1 prepare route to master
|
||||
select @@server_id; -- maxscale named1 begin|HINT_ROUTE_TO_MASTER
|
||||
@ -14,10 +14,10 @@ select @@server_id;|HINT_ROUTE_TO_NAMED_SERVER|server2
|
||||
select @@server_id; -- maxscale route to server server3|HINT_ROUTE_TO_NAMED_SERVER|server3
|
||||
select @@server_id;|HINT_ROUTE_TO_NAMED_SERVER|server2
|
||||
select @@server_id; -- maxscale end
|
||||
select @@server_id; # maxscale begin route to master
|
||||
select @@server_id;
|
||||
select @@server_id; # maxscale begin route to master|HINT_ROUTE_TO_MASTER
|
||||
select @@server_id;|HINT_ROUTE_TO_MASTER
|
||||
select @@server_id; # maxscale route to server server3|HINT_ROUTE_TO_NAMED_SERVER|server3
|
||||
select @@server_id;
|
||||
select @@server_id;|HINT_ROUTE_TO_MASTER
|
||||
select @@server_id; # maxscale end
|
||||
select @@server_id; # maxscale named2 prepare route to master
|
||||
select @@server_id; # maxscale named2 begin|HINT_ROUTE_TO_MASTER
|
||||
@ -30,19 +30,19 @@ select @@server_id;|HINT_ROUTE_TO_NAMED_SERVER|server2
|
||||
select @@server_id; # maxscale route to server server3|HINT_ROUTE_TO_NAMED_SERVER|server3
|
||||
select @@server_id;|HINT_ROUTE_TO_NAMED_SERVER|server2
|
||||
select @@server_id; # maxscale end
|
||||
select @@server_id/* maxscale begin route to master */;
|
||||
select @@server_id;
|
||||
select @@server_id/* maxscale route to server server3 */;|HINT_ROUTE_TO_NAMED_SERVER|*/;
|
||||
select @@server_id;
|
||||
select @@server_id/* maxscale begin route to master */;|HINT_ROUTE_TO_MASTER
|
||||
select @@server_id;|HINT_ROUTE_TO_MASTER
|
||||
select @@server_id/* maxscale route to server server3 */;|HINT_ROUTE_TO_NAMED_SERVER|server3
|
||||
select @@server_id;|HINT_ROUTE_TO_MASTER
|
||||
select @@server_id/* maxscale end */;
|
||||
select @@server_id/* maxscale named3 prepare route to master */;|HINT_ROUTE_TO_MASTER
|
||||
select @@server_id/* maxscale named3 begin */;
|
||||
select @@server_id;
|
||||
select @@server_id/* maxscale route to server server3 */;|HINT_ROUTE_TO_NAMED_SERVER|*/;
|
||||
select @@server_id;
|
||||
select @@server_id/* maxscale named3 prepare route to master */;
|
||||
select @@server_id/* maxscale named3 begin */;|HINT_ROUTE_TO_MASTER
|
||||
select @@server_id;|HINT_ROUTE_TO_MASTER
|
||||
select @@server_id/* maxscale route to server server3 */;|HINT_ROUTE_TO_NAMED_SERVER|server3
|
||||
select @@server_id;|HINT_ROUTE_TO_MASTER
|
||||
select @@server_id/* maxscale end */;
|
||||
select @@server_id/* maxscale shorthand3 begin route to server server2 */; |HINT_ROUTE_TO_NAMED_SERVER|*/;
|
||||
select @@server_id;|HINT_ROUTE_TO_NAMED_SERVER|*/;
|
||||
select @@server_id/* maxscale route to server server3 */;|HINT_ROUTE_TO_NAMED_SERVER|*/;
|
||||
select @@server_id;|HINT_ROUTE_TO_NAMED_SERVER|*/;
|
||||
select @@server_id/* maxscale shorthand3 begin route to server server2 */; |HINT_ROUTE_TO_NAMED_SERVER|server2
|
||||
select @@server_id;|HINT_ROUTE_TO_NAMED_SERVER|server2
|
||||
select @@server_id/* maxscale route to server server3 */;|HINT_ROUTE_TO_NAMED_SERVER|server3
|
||||
select @@server_id;|HINT_ROUTE_TO_NAMED_SERVER|server2
|
||||
select @@server_id/* maxscale end */;
|
||||
|
||||
Reference in New Issue
Block a user