161 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			161 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /**
 | |
|  * @file bug649.cpp regression case for bug 649 ("Segfault using RW Splitter")
 | |
|  * @verbatim
 | |
| 
 | |
| [RW_Router]
 | |
| type=service
 | |
| router=readconnroute
 | |
| servers=server1
 | |
| user=skysql
 | |
| passwd=skysql
 | |
| version_string=5.1-OLD-Bored-Mysql
 | |
| filters=DuplicaFilter
 | |
| 
 | |
| [RW_Split]
 | |
| type=service
 | |
| router=readwritesplit
 | |
| servers=server1,server3,server2
 | |
| user=skysql
 | |
| passwd=skysql
 | |
| 
 | |
| [DuplicaFilter]
 | |
| type=filter
 | |
| module=tee
 | |
| service=RW_Split
 | |
| 
 | |
|    @endverbatim
 | |
|  * - Connect to RWSplit
 | |
|  * - create load on RWSplit (25 threads doing long INSERTs in the loop)
 | |
|  * - block Mariadb server on Master node by Firewall
 | |
|  * - unblock Mariadb server
 | |
|  * - check if Maxscale is alive
 | |
|  * - reconnect and check if query execution is ok
 | |
|  */
 | |
| 
 | |
| 
 | |
| #include <iostream>
 | |
| #include "testconnections.h"
 | |
| #include "sql_t1.h"
 | |
| 
 | |
| pthread_mutex_t mutex1 = PTHREAD_MUTEX_INITIALIZER;
 | |
| int exit_flag = 0;
 | |
| 
 | |
| TestConnections * Test ;
 | |
| 
 | |
| char sql[1000000];
 | |
| 
 | |
| void *parall_traffic( void *ptr );
 | |
| 
 | |
| int main(int argc, char *argv[])
 | |
| {
 | |
|     int threads_num = 20;
 | |
|     pthread_t parall_traffic1[threads_num];
 | |
|     int check_iret[threads_num];
 | |
| 
 | |
|     Test = new TestConnections(argc, argv);
 | |
|     int time_to_run = (Test->smoke) ? 10 : 30;
 | |
|     Test->set_timeout(10);
 | |
| 
 | |
|     Test->tprintf("Connecting to RWSplit %s\n", Test->maxscales->IP[0]);
 | |
|     Test->maxscales->connect_rwsplit(0);
 | |
| 
 | |
|     Test->repl->connect();
 | |
|     Test->tprintf("Drop t1 if exists\n");
 | |
|     execute_query(Test->repl->nodes[0], "DROP TABLE IF EXISTS t1;");
 | |
|     Test->tprintf("Create t1\n");
 | |
|     Test->add_result(create_t1(Test->repl->nodes[0]), "t1 creation Failed\n");
 | |
|     Test->repl->close_connections();
 | |
| 
 | |
|     Test->stop_timeout();
 | |
|     sleep(5);
 | |
| 
 | |
|     create_insert_string(sql, 65000, 1);
 | |
|     Test->tprintf("Creating query threads\n", time_to_run);
 | |
|     for (int j = 0; j < threads_num; j++)
 | |
|     {
 | |
|         Test->set_timeout(20);
 | |
|         check_iret[j] = pthread_create(¶ll_traffic1[j], NULL, parall_traffic, NULL);
 | |
|     }
 | |
| 
 | |
|     Test->stop_timeout();
 | |
|     Test->tprintf("Waiting %d seconds\n", time_to_run);
 | |
|     sleep(time_to_run);
 | |
| 
 | |
|     Test->tprintf("Setup firewall to block mysql on master\n");
 | |
|     Test->repl->block_node(0);
 | |
|     fflush(stdout);
 | |
| 
 | |
|     Test->tprintf("Waiting %d seconds\n", time_to_run);
 | |
|     sleep(time_to_run);
 | |
| 
 | |
|     Test->set_timeout(30);
 | |
|     Test->tprintf("Trying query to RWSplit, expecting failure, but not a crash\n");
 | |
|     if (execute_query_silent(Test->maxscales->conn_rwsplit[0], (char *) "show processlist;") == 0)
 | |
|     {
 | |
|         Test->add_result(1, "Failure is expected, but query is ok\n");
 | |
|     }
 | |
| 
 | |
|     Test->stop_timeout();
 | |
|     sleep(time_to_run);
 | |
| 
 | |
|     Test->tprintf("Setup firewall back to allow mysql\n");
 | |
|     Test->repl->unblock_node(0);
 | |
|     fflush(stdout);
 | |
|     Test->stop_timeout();
 | |
|     sleep(time_to_run);
 | |
|     exit_flag = 1;
 | |
|     for (int i = 0; i < threads_num; i++)
 | |
|     {
 | |
|         Test->set_timeout(30);
 | |
|         pthread_join(parall_traffic1[i], NULL);
 | |
|         Test->tprintf("exit %d\n", i);
 | |
|     }
 | |
|     Test->stop_timeout();
 | |
|     sleep(5);
 | |
| 
 | |
|     Test->set_timeout(20);
 | |
|     Test->tprintf("Checking Maxscale is alive\n");
 | |
|     Test->check_maxscale_alive(0);
 | |
| 
 | |
|     Test->set_timeout(20);
 | |
|     Test->tprintf("Reconnecting to RWSplit ...\n");
 | |
|     Test->maxscales->connect_rwsplit(0);
 | |
|     Test->tprintf("                        ... and trying query\n");
 | |
|     Test->try_query(Test->maxscales->conn_rwsplit[0], (char *) "show processlist;");
 | |
|     Test->maxscales->close_rwsplit(0);
 | |
| 
 | |
|     /** Clean up */
 | |
|     Test->repl->connect();
 | |
|     execute_query(Test->repl->nodes[0], "DROP TABLE IF EXISTS t1;");
 | |
| 
 | |
|     int rval = Test->global_result;
 | |
|     delete Test;
 | |
|     return rval;
 | |
| }
 | |
| 
 | |
| 
 | |
| void *parall_traffic( void *ptr )
 | |
| {
 | |
|     MYSQL * conn;
 | |
|     mysql_thread_init();
 | |
|     conn = Test->maxscales->open_rwsplit_connection(0);
 | |
|     if ((conn != NULL) && (mysql_errno(conn) == 0))
 | |
|     {
 | |
|         while (exit_flag == 0)
 | |
|         {
 | |
|             execute_query_silent(conn, sql);
 | |
|             fflush(stdout);
 | |
|         }
 | |
|     }
 | |
|     else
 | |
|     {
 | |
|         Test->tprintf("Error opening connection");
 | |
|     }
 | |
| 
 | |
|     if (conn != NULL )
 | |
|     {
 | |
|         mysql_close(conn);
 | |
|     }
 | |
|     return NULL;
 | |
| }
 | 
