Files
MaxScale/maxscale-system-test/mxs682_cyrillic.cpp
Niclas Antti c447e5cf15 Uncrustify maxscale
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.
2018-09-09 22:26:19 +03:00

76 lines
1.8 KiB
C++

/**
* @file mxs682_cyrillic.cpp put cyrillic letters to the table
* - put string with Cyrillic into table
* - check SELECT from backend
*/
#include <iostream>
#include <unistd.h>
#include "testconnections.h"
#include <iconv.h>
using namespace std;
void check_val(MYSQL* conn, TestConnections* Test)
{
char val[256];
Test->set_timeout(20);
find_field(conn, "SELECT * FROM t2", "x", val);
Test->tprintf("result: %s\n", val);
if (strcmp("Кот", val) != 0)
{
Test->add_result(1, "Wrong SELECT result: %s\n", val);
}
}
int main(int argc, char* argv[])
{
TestConnections* Test = new TestConnections(argc, argv);
Test->set_timeout(30);
Mariadb_nodes* nodes;
if (strstr(Test->test_name, "galera") != NULL)
{
nodes = Test->galera;
Test->tprintf("Galera!\n");
}
else
{
nodes = Test->repl;
}
Test->maxscales->connect_maxscale(0);
Test->set_timeout(30);
nodes->connect();
Test->set_timeout(30);
MYSQL* conn = Test->maxscales->conn_rwsplit[0];
execute_query_silent(conn, (char*) "DROP TABLE t2;");
Test->try_query(conn, (char*) "CREATE TABLE t2 (x varchar(10));");
char sql[256];
sprintf(sql, "INSERT INTO t2 VALUES (\"Кот\");");
Test->try_query(conn, "%s", sql);
Test->stop_timeout();
sleep(5);
Test->set_timeout(30);
check_val(Test->maxscales->conn_rwsplit[0], Test);
check_val(Test->maxscales->conn_master[0], Test);
check_val(Test->maxscales->conn_slave[0], Test);
for (int i = 0; i < Test->repl->N; i++)
{
Test->tprintf("Node %d\n", i);
check_val(nodes->nodes[i], Test);
}
Test->stop_timeout();
Test->check_maxscale_alive(0);
int rval = Test->global_result;
delete Test;
return rval;
}