MXS-1452: Extend kill parsing test
The test now correctly checks for usernames and integer overflow.
This commit is contained in:
parent
96d160f897
commit
4ee5c991c2
@ -2,12 +2,15 @@
|
||||
|
||||
#include "../MySQLClient/mysql_client.cc"
|
||||
|
||||
#define NO_THREAD_ID 0
|
||||
|
||||
int test_one_query(const char *query, bool should_succeed, uint64_t expected_tid,
|
||||
int expected_kt)
|
||||
int expected_kt, std::string expected_user)
|
||||
{
|
||||
char *query_copy = MXS_STRDUP_A(query);
|
||||
uint64_t result_tid = 1111111;
|
||||
kill_type_t result_kt = KT_QUERY;
|
||||
std::string user;
|
||||
|
||||
/* If the parse fails, these should remain unchanged */
|
||||
if (!should_succeed)
|
||||
@ -15,11 +18,11 @@ int test_one_query(const char *query, bool should_succeed, uint64_t expected_tid
|
||||
result_tid = expected_tid;
|
||||
result_kt = (kill_type_t)expected_kt;
|
||||
}
|
||||
bool success = parse_kill_query(query_copy, &result_tid, &result_kt);
|
||||
bool success = parse_kill_query(query_copy, &result_tid, &result_kt, &user);
|
||||
MXS_FREE(query_copy);
|
||||
|
||||
if ((success == should_succeed) && (result_tid == expected_tid) &&
|
||||
(result_kt == expected_kt))
|
||||
if (success == should_succeed && result_tid == expected_tid &&
|
||||
result_kt == expected_kt && expected_user == user)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
@ -32,13 +35,15 @@ int test_one_query(const char *query, bool should_succeed, uint64_t expected_tid
|
||||
}
|
||||
if (result_tid != expected_tid)
|
||||
{
|
||||
printf("Expected thread id '%" PRIu64 "', got '%" PRIu64 "'.\n",
|
||||
expected_tid, result_tid);
|
||||
printf("Expected thread id '%" PRIu64 "', got '%" PRIu64 "'.\n", expected_tid, result_tid);
|
||||
}
|
||||
if (result_kt != expected_kt)
|
||||
{
|
||||
printf("Expected kill type '%u', got '%u'.\n",
|
||||
expected_kt, result_kt);
|
||||
printf("Expected kill type '%u', got '%u'.\n", expected_kt, result_kt);
|
||||
}
|
||||
if (expected_user != user)
|
||||
{
|
||||
printf("Expected user '%s', got '%s'.\n", expected_user.c_str(), user.c_str());
|
||||
}
|
||||
printf("\n");
|
||||
return 1;
|
||||
@ -50,6 +55,7 @@ typedef struct test_t
|
||||
bool should_succeed;
|
||||
uint64_t correct_id;
|
||||
int correct_kt;
|
||||
const char* correct_user;
|
||||
} test_t;
|
||||
|
||||
int main(int argc, char **argv)
|
||||
@ -66,10 +72,7 @@ int main(int argc, char **argv)
|
||||
{" kill connection 1A", false, 0, KT_CONNECTION},
|
||||
{" kill connection 1 A ", false, 0, KT_CONNECTION},
|
||||
{"kill query 7 ; select * ", false, 0, KT_CONNECTION},
|
||||
{
|
||||
"KIll query \t \n \t 12345678901234567890 \n \t ",
|
||||
true, 12345678901234567890ULL, KT_QUERY
|
||||
},
|
||||
{"KIll query 12345678901234567890", false, 0, KT_QUERY}, // 32-bit integer overflow
|
||||
{"KIll query \t \n \t 21 \n \t ", true, 21, KT_QUERY},
|
||||
{"KIll \t \n \t -6 \n \t ", false, 0, KT_CONNECTION},
|
||||
{"KIll 12345678901234567890123456 \n \t ", false, 0, KT_CONNECTION},
|
||||
@ -82,7 +85,9 @@ int main(int argc, char **argv)
|
||||
{" kill HARD 123", true, 123, KT_CONNECTION | KT_HARD},
|
||||
{" kill SOFT 123", true, 123, KT_CONNECTION | KT_SOFT},
|
||||
{"KIll soft query 21 ", true, 21, KT_QUERY | KT_SOFT},
|
||||
{"KIll query soft 21 ", false, 21, KT_QUERY}
|
||||
{"KIll query soft 21 ", false, 21, KT_QUERY},
|
||||
{"KIll query user maxuser ", true, NO_THREAD_ID, KT_QUERY, "maxuser"},
|
||||
{"KIll user query maxuser ", false, NO_THREAD_ID, KT_QUERY}
|
||||
};
|
||||
int result = 0;
|
||||
int arr_size = sizeof(tests) / sizeof(test_t);
|
||||
@ -92,7 +97,9 @@ int main(int argc, char **argv)
|
||||
bool should_succeed = tests[i].should_succeed;
|
||||
uint64_t expected_tid = tests[i].correct_id;
|
||||
int expected_kt = tests[i].correct_kt;
|
||||
result += test_one_query(query, should_succeed, expected_tid, expected_kt);
|
||||
std::string expected_user = tests[i].correct_user ? tests[i].correct_user : "";
|
||||
result += test_one_query(query, should_succeed, expected_tid,
|
||||
expected_kt, expected_user);
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user