
See script directory for method. The script to run in the top level MaxScale directory is called maxscale-uncrustify.sh, which uses another script, list-src, from the same directory (so you need to set your PATH). The uncrustify version was 0.66.
43 lines
1.1 KiB
C++
43 lines
1.1 KiB
C++
/**
|
|
* @backend_auth_fail.cpp Repeatedly connect to maxscale while the backends reject all connections
|
|
*
|
|
* MaxScale should not crash
|
|
*/
|
|
|
|
#include "testconnections.h"
|
|
|
|
int main(int argc, char** argv)
|
|
{
|
|
MYSQL* mysql[1000];
|
|
TestConnections* Test = new TestConnections(argc, argv);
|
|
Test->stop_timeout();
|
|
Test->repl->execute_query_all_nodes((char*) "set global max_connections = 10;");
|
|
|
|
for (int x = 0; x < 3; x++)
|
|
{
|
|
Test->tprintf("Creating 100 connections...\n");
|
|
for (int i = 0; i < 100; i++)
|
|
{
|
|
Test->set_timeout(30);
|
|
mysql[i] = Test->maxscales->open_readconn_master_connection(0);
|
|
execute_query_silent(mysql[i], "select 1");
|
|
}
|
|
Test->stop_timeout();
|
|
|
|
for (int i = 0; i < 100; i++)
|
|
{
|
|
Test->set_timeout(30);
|
|
mysql_close(mysql[i]);
|
|
}
|
|
}
|
|
|
|
// Wait for the connections to clean up
|
|
Test->stop_timeout();
|
|
sleep(5);
|
|
|
|
Test->check_maxscale_alive(0);
|
|
int rval = Test->global_result;
|
|
delete Test;
|
|
return rval;
|
|
}
|