add tests
This commit is contained in:

committed by
Markus Mäkelä

parent
dbfd631fed
commit
8c6ca38a8a
69
maxscale-system-test/setup_binlog.cpp
Normal file
69
maxscale-system-test/setup_binlog.cpp
Normal file
@ -0,0 +1,69 @@
|
||||
/**
|
||||
* @file setup_binlog.cpp test of simple binlog router setup
|
||||
* - setup one master, one slave directly connected to real master and two slaves connected to binlog router
|
||||
* - create table and put data into it using connection to master
|
||||
* - check data using direct commection to all backend
|
||||
* - compare sha1 checksum of binlog file on master and on Maxscale machine
|
||||
* - START TRANSACTION
|
||||
* - SET autocommit = 0
|
||||
* - INSERT INTO t1 VALUES(111, 10)
|
||||
* - check SELECT * FROM t1 WHERE fl=10 - expect one row x=111
|
||||
* - ROLLBACK
|
||||
* - INSERT INTO t1 VALUES(112, 10)
|
||||
* - check SELECT * FROM t1 WHERE fl=10 - expect one row x=112 and no row with x=111
|
||||
* - DELETE FROM t1 WHERE fl=10
|
||||
* - START TRANSACTION
|
||||
* - INSERT INTO t1 VALUES(111, 10)
|
||||
* - check SELECT * FROM t1 WHERE fl=10 - expect one row x=111 from master and slave
|
||||
* - DELETE FROM t1 WHERE fl=10
|
||||
* - compare sha1 checksum of binlog file on master and on Maxscale machine
|
||||
* - Re-create t1 table via master
|
||||
* - STOP SLAVE against Maxscale binlog
|
||||
* - put data to t1
|
||||
* - START SLAVE against Maxscale binlog
|
||||
* - wait to let replication happens
|
||||
* - check data on all nodes
|
||||
* - chack sha1
|
||||
* - repeat last test with FLUSH LOGS on master 1. before putting data to Master 2. after putting data to master
|
||||
*/
|
||||
|
||||
|
||||
#include <iostream>
|
||||
#include "testconnections.h"
|
||||
#include "maxadmin_operations.h"
|
||||
#include "sql_t1.h"
|
||||
|
||||
#include "test_binlog_fnc.h"
|
||||
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
|
||||
TestConnections * Test = new TestConnections(argc, argv);
|
||||
Test->set_timeout(3000);
|
||||
int options_set = 3;
|
||||
if (Test->smoke)
|
||||
{
|
||||
options_set = 1;
|
||||
}
|
||||
|
||||
Test->repl->connect();
|
||||
execute_query(Test->repl->nodes[0], (char *) "DROP TABLE IF EXISTS t1;");
|
||||
Test->repl->close_connections();
|
||||
sleep(5);
|
||||
|
||||
for (int option = 0; option < options_set; option++)
|
||||
{
|
||||
Test->binlog_cmd_option = option;
|
||||
Test->start_binlog();
|
||||
test_binlog(Test);
|
||||
}
|
||||
|
||||
Test->check_log_err("SET NAMES utf8mb4", false);
|
||||
Test->check_log_err("set autocommit=1", false);
|
||||
Test->check_log_err("select USER()", false);
|
||||
|
||||
int rval = Test->global_result;
|
||||
delete Test;
|
||||
return rval;
|
||||
}
|
Reference in New Issue
Block a user