172 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			172 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
/**
 | 
						|
 * @file sharding.cpp - Schema router test and regression test for MXS-78, MXS-79
 | 
						|
 *
 | 
						|
 * @verbatim
 | 
						|
 *  [MySQL Monitor]
 | 
						|
 *  type=monitor
 | 
						|
 *  module=mysqlmon
 | 
						|
 *  servers= server1, server2,server3  ,server4
 | 
						|
 *  user=skysql
 | 
						|
 *  passwd= skysql
 | 
						|
 *
 | 
						|
 *  [Sharding router]
 | 
						|
 *  type=service
 | 
						|
 *  router=schemarouter
 | 
						|
 *  servers=server1,     server2,              server3,server4
 | 
						|
 *  user=skysql
 | 
						|
 *  passwd=skysql
 | 
						|
 *  auth_all_servers=1
 | 
						|
 *  filters=QLA
 | 
						|
 *
 | 
						|
 *  @endverbatim
 | 
						|
 * - stop all slaves in Master/Slave setup
 | 
						|
 * - restrt Maxscale
 | 
						|
 * - using direct connection to backend nodes
 | 
						|
 *    - create user0...userN users on all nodes
 | 
						|
 *    - create sharddb on all nodes
 | 
						|
 *    - create database 'shard_db%d" on node %d (% from 0 to N)
 | 
						|
 *    - GRANT SELECT,USAGE,CREATE ON shard_db.* TO 'user%d'@'%%' only on node %d
 | 
						|
 * - for every user%d
 | 
						|
 *   - open connection to schemarouter using user%d
 | 
						|
 * - CREATE TABLE table%d (x1 int, fl int)
 | 
						|
 * - check if Maxscale alive
 | 
						|
 */
 | 
						|
 | 
						|
 | 
						|
#include <iostream>
 | 
						|
#include "testconnections.h"
 | 
						|
 | 
						|
int main(int argc, char* argv[])
 | 
						|
{
 | 
						|
 | 
						|
    TestConnections* Test = new TestConnections(argc, argv);
 | 
						|
    Test->set_timeout(30);
 | 
						|
    int i, j;
 | 
						|
    char str[256];
 | 
						|
    char str1[256];
 | 
						|
    char user_str[256];
 | 
						|
    char pass_str[256];
 | 
						|
 | 
						|
    Test->repl->execute_query_all_nodes("STOP SLAVE");
 | 
						|
    Test->repl->connect();
 | 
						|
 | 
						|
    for (i = 0; i < Test->repl->N; i++)     // nodes
 | 
						|
    {
 | 
						|
        for (j = 0; j < Test->repl->N; j++)     // users
 | 
						|
        {
 | 
						|
            Test->set_timeout(30);
 | 
						|
            execute_query(Test->repl->nodes[i], "DROP USER 'user%d'@'%%';", j);
 | 
						|
            execute_query(Test->repl->nodes[i], "CREATE USER 'user%d'@'%%' IDENTIFIED BY 'pass%d';", j, j);
 | 
						|
            execute_query(Test->repl->nodes[i], "DROP DATABASE IF EXISTS shard_db");
 | 
						|
        }
 | 
						|
 | 
						|
        execute_query(Test->repl->nodes[i], "DROP DATABASE IF EXISTS shard_db%d", i);
 | 
						|
        execute_query(Test->repl->nodes[i], "CREATE DATABASE shard_db%d", i);
 | 
						|
    }
 | 
						|
    Test->stop_timeout();
 | 
						|
 | 
						|
    for (i = 0; i < Test->repl->N; i++)     // nodes
 | 
						|
    {
 | 
						|
        Test->set_timeout(30);
 | 
						|
        Test->tprintf("Node %d\t", i);
 | 
						|
        Test->tprintf("Creating shard_db\t");
 | 
						|
        execute_query(Test->repl->nodes[i], "CREATE DATABASE shard_db");
 | 
						|
        Test->add_result(execute_query(Test->repl->nodes[i],
 | 
						|
                                       "GRANT SELECT,USAGE,CREATE ON shard_db.* TO 'user%d'@'%%'",
 | 
						|
                                       i),
 | 
						|
                         "Query should succeed.");
 | 
						|
        execute_query(Test->repl->nodes[i], "FLUSH PRIVILEGES");
 | 
						|
    }
 | 
						|
 | 
						|
    Test->repl->close_connections();
 | 
						|
    Test->stop_timeout();
 | 
						|
 | 
						|
    MYSQL* conn;
 | 
						|
    for (i = 0; i < Test->repl->N; i++)
 | 
						|
    {
 | 
						|
        Test->set_timeout(30);
 | 
						|
        sprintf(user_str, "user%d", i);
 | 
						|
        sprintf(pass_str, "pass%d", i);
 | 
						|
        Test->tprintf("Open connection to Sharding router using %s %s\n", user_str, pass_str);
 | 
						|
        conn = open_conn_db(Test->maxscales->rwsplit_port[0],
 | 
						|
                            Test->maxscales->IP[0],
 | 
						|
                            (char*) "shard_db",
 | 
						|
                            user_str,
 | 
						|
                            pass_str,
 | 
						|
                            Test->ssl);
 | 
						|
        Test->add_result(execute_query(conn, "CREATE TABLE table%d (x1 int, fl int);", i),
 | 
						|
                         "Query should succeed.");
 | 
						|
    }
 | 
						|
    sleep(6); // The router is configured to refresh the shard map if older than 5 seconds.
 | 
						|
 | 
						|
    for (i = 0; i < Test->repl->N; i++)
 | 
						|
    {
 | 
						|
        Test->set_timeout(30);
 | 
						|
        sprintf(user_str, "user%d", i);
 | 
						|
        sprintf(pass_str, "pass%d", i);
 | 
						|
        Test->tprintf("Open connection to Sharding router using %s %s\n", user_str, pass_str);
 | 
						|
        conn = open_conn_db(Test->maxscales->rwsplit_port[0],
 | 
						|
                            Test->maxscales->IP[0],
 | 
						|
                            (char*) "shard_db",
 | 
						|
                            user_str,
 | 
						|
                            pass_str,
 | 
						|
                            Test->ssl);
 | 
						|
 | 
						|
        sprintf(str, "SHOW TABLES;");
 | 
						|
        Test->tprintf("%s\n", str);
 | 
						|
        sprintf(str1, "table%d", i);
 | 
						|
        Test->tprintf("Table should be %s\n", str1);
 | 
						|
        Test->add_result(execute_query_check_one(conn, str, str1), "check failed\n");
 | 
						|
        mysql_ping(conn);
 | 
						|
        mysql_close(conn);
 | 
						|
    }
 | 
						|
 | 
						|
    Test->maxscales->connect_rwsplit(0);
 | 
						|
 | 
						|
    Test->tprintf("Trying USE shard_db\n");
 | 
						|
    execute_query(Test->maxscales->conn_rwsplit[0], "USE shard_db");
 | 
						|
 | 
						|
    for (i = 0; i < Test->repl->N; i++)
 | 
						|
    {
 | 
						|
        Test->add_result(execute_query(Test->maxscales->conn_rwsplit[0], "USE shard_db%d", i),
 | 
						|
                         "Query should succeed.");
 | 
						|
    }
 | 
						|
 | 
						|
    mysql_close(Test->maxscales->conn_rwsplit[0]);
 | 
						|
 | 
						|
    Test->tprintf("Trying to connect with empty database name\n");
 | 
						|
    conn = open_conn_db(Test->maxscales->rwsplit_port[0],
 | 
						|
                        Test->maxscales->IP[0],
 | 
						|
                        (char*) "",
 | 
						|
                        user_str,
 | 
						|
                        pass_str,
 | 
						|
                        Test->ssl);
 | 
						|
    mysql_close(conn);
 | 
						|
 | 
						|
    Test->stop_timeout();
 | 
						|
    Test->log_excludes(0, "Length (0) is 0");
 | 
						|
    Test->log_excludes(0, "Unable to parse query");
 | 
						|
    Test->log_excludes(0, "query string allocation failed");
 | 
						|
 | 
						|
    Test->repl->connect();
 | 
						|
    /** Cleanup */
 | 
						|
    for (i = 0; i < Test->repl->N; i++)
 | 
						|
    {
 | 
						|
        for (j = 0; j < Test->repl->N; j++)
 | 
						|
        {
 | 
						|
            Test->set_timeout(30);
 | 
						|
            execute_query(Test->repl->nodes[i], "DROP USER 'user%d'@'%%';", j);
 | 
						|
            execute_query(Test->repl->nodes[i], "DROP DATABASE IF EXISTS shard_db");
 | 
						|
        }
 | 
						|
 | 
						|
        execute_query(Test->repl->nodes[i], "DROP DATABASE IF EXISTS shard_db%d", i);
 | 
						|
    }
 | 
						|
 | 
						|
    Test->repl->execute_query_all_nodes("START SLAVE");
 | 
						|
    sleep(1);
 | 
						|
    Test->repl->fix_replication();
 | 
						|
    int rval = Test->global_result;
 | 
						|
    delete Test;
 | 
						|
    return rval;
 | 
						|
}
 |