Merge branch '2.3' into develop

This commit is contained in:
Markus Mäkelä
2019-02-13 13:35:07 +02:00
6 changed files with 112 additions and 25 deletions

View File

@ -917,7 +917,10 @@ add_test_executable(mxs2273_being_drained.cpp mxs2273_being_drained mxs2273_bein
add_test_executable(mxs2295_change_user_loop.cpp mxs2295_change_user_loop mxs2295_change_user_loop LABELS REPL_BACKEND)
# MXS-2300: Prune session command history
add_test_executable(mxs2300_history_pruning.cpp mxs2300_history_pruning mxs2300_history_pruning LABELS REPL_BACKEND)
add_test_executable(mxs2300_history_pruning.cpp mxs2300_history_pruning mxs2300_history_pruning LABELS readwritesplit REPL_BACKEND)
# MXS-2326: Routing hints aren't cloned in gwbuf_clone
add_test_executable(mxs2326_hint_clone.cpp mxs2326_hint_clone mxs2326_hint_clone LABELS readwritesplit REPL_BACKEND)
############################################
# BEGIN: binlogrouter and avrorouter tests #

View File

@ -0,0 +1,53 @@
[maxscale]
threads=###threads###
log_info=1
[server1]
type=server
address=###node_server_IP_1###
port=###node_server_port_1###
protocol=MySQLBackend
[server2]
type=server
address=###node_server_IP_2###
port=###node_server_port_2###
protocol=MySQLBackend
[server3]
type=server
address=###node_server_IP_3###
port=###node_server_port_3###
protocol=MySQLBackend
[server4]
type=server
address=###node_server_IP_4###
port=###node_server_port_4###
protocol=MySQLBackend
[MySQL Monitor]
type=monitor
module=mysqlmon
servers=server1,server2,server3,server4
user=maxskysql
password=skysql
monitor_interval=1000
[hint]
type=filter
module=hintfilter
[RW Split Router]
type=service
router=readwritesplit
servers=server1,server2,server3,server4
user=maxskysql
password=skysql
filters=hint
[RW Split Listener]
type=listener
service=RW Split Router
protocol=MySQLClient
port=4006

View File

@ -65,6 +65,7 @@ void test_watchdog(TestConnections& test, int argc, char* argv[])
if (test.global_result == 0)
{
test.tprintf("Maxscale was killed by systemd - ok");
test.maxscales->ssh_node_f(0, true, "rm -f /tmp/*core");
}
}
}

View File

@ -0,0 +1,29 @@
/**
* MXS-2326: Routing hints aren't cloned in gwbuf_clone
*/
#include "testconnections.h"
int main(int argc, char** argv)
{
TestConnections test(argc, argv);
Connection c = test.maxscales->rwsplit();
test.expect(c.connect(), "Connection should work: %s", c.error());
std::string correct_id = c.field("SELECT @@server_id -- maxscale route to server server4");
test.tprintf("Executing session command");
test.expect(c.query("SET @a = 1"), "SET should work: %s", c.error());
test.tprintf("Forcing a reconnection to occur on the next query by blocking the server");
test.repl->block_node(3);
test.maxscales->wait_for_monitor();
test.repl->unblock_node(3);
test.maxscales->wait_for_monitor();
test.tprintf("Executing a query with a routing hint to a server that the session is not connected to");
test.expect(c.check("SELECT @@server_id -- maxscale route to server server4",
correct_id), "Hint should be routed to the same server");
return test.global_result;
}

View File

@ -179,6 +179,7 @@ static GWBUF* gwbuf_clone_one(GWBUF* buf)
rval->end = buf->end;
rval->gwbuf_type = buf->gwbuf_type;
rval->tail = rval;
rval->hint = hint_dup(buf->hint);
rval->next = NULL;
return rval;