Add more output to binlog_change_master
Knowing the GTIDs before the MASTER_GTID_WAIT call should help us figure out why it doesn't seem to be working as expected.
This commit is contained in:
		| @ -3,6 +3,16 @@ | ||||
|  | ||||
| void run_test(TestConnections& test, std::function<void(MYSQL*)> cb) | ||||
| { | ||||
|     auto dump_gtid = [&](int i) { | ||||
|             std::string slave = get_row(test.repl->nodes[i], "SELECT @@gtid_slave_pos")[0]; | ||||
|             std::string binlog = get_row(test.repl->nodes[i], "SELECT @@gtid_binlog_pos")[0]; | ||||
|             std::string current = get_row(test.repl->nodes[i], "SELECT @@gtid_current_pos")[0]; | ||||
|  | ||||
|             test.tprintf( | ||||
|                 "Node %d: @@gtid_slave_pos = '%s', @@gtid_binlog_pos = '%s', @@gtid_current_pos = '%s'", | ||||
|                 i, slave.c_str(), binlog.c_str(), current.c_str()); | ||||
|         }; | ||||
|  | ||||
|     test.set_timeout(120); | ||||
|     test.start_binlog(0); | ||||
|     test.repl->connect(); | ||||
| @ -17,8 +27,10 @@ void run_test(TestConnections& test, std::function<void(MYSQL*)> cb) | ||||
|  | ||||
|     // Sync the candidate master | ||||
|     std::string binlog_pos = get_row(test.repl->nodes[0], "SELECT @@gtid_binlog_pos")[0]; | ||||
|     dump_gtid(0); | ||||
|     execute_query(test.repl->nodes[2], "SELECT MASTER_GTID_WAIT('%s', 120)", binlog_pos.c_str()); | ||||
|     execute_query(test.repl->nodes[2], "STOP SLAVE"); | ||||
|     dump_gtid(2); | ||||
|  | ||||
|     MYSQL* blr = open_conn_no_db(test.maxscales->binlog_port[0], | ||||
|                                  test.maxscales->IP[0], | ||||
| @ -39,7 +51,9 @@ void run_test(TestConnections& test, std::function<void(MYSQL*)> cb) | ||||
|  | ||||
|     // Sync a slave and verify all of the data is replicated | ||||
|     binlog_pos = get_row(test.repl->nodes[2], "SELECT @@gtid_binlog_pos")[0]; | ||||
|     dump_gtid(2); | ||||
|     execute_query(test.repl->nodes[3], "SELECT MASTER_GTID_WAIT('%s', 120)", binlog_pos.c_str()); | ||||
|     dump_gtid(0); | ||||
|     std::string sum = get_row(test.repl->nodes[3], "SELECT COUNT(*) FROM test.t1")[0]; | ||||
|  | ||||
|     test.expect(sum == "50", "Inserted 50 rows but only %s were replicated", sum.c_str()); | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 Markus Mäkelä
					Markus Mäkelä