Add MariaDBMonitor Gtid unit test
Tests the class with different inputs. Also fixes a bug found by the test.
This commit is contained in:
parent
56c84541df
commit
eeb61216de
@ -139,6 +139,16 @@ uint64_t GtidList::events_ahead(const GtidList& rhs, substraction_mode_t domain_
|
||||
ind_rhs++;
|
||||
}
|
||||
}
|
||||
|
||||
// If LHS has domains with higher id:s than at RHS, those domains need to be iterated here.
|
||||
// This only affects the result if the LHS_ADD-mode is used.
|
||||
if (domain_substraction_mode == MISSING_DOMAIN_LHS_ADD)
|
||||
{
|
||||
for (; ind_lhs < n_lhs; ind_lhs++)
|
||||
{
|
||||
events += m_triplets[ind_lhs].m_sequence;
|
||||
}
|
||||
}
|
||||
return events;
|
||||
}
|
||||
|
||||
|
@ -1,3 +1,7 @@
|
||||
add_executable(test_cycle_find test_cycle_find.cc)
|
||||
target_link_libraries(test_cycle_find mariadbmon maxscale-common)
|
||||
add_test(test_mariadbmon_cycle_find test_cycle_find)
|
||||
add_test(test_mariadbmon_cycle_find test_cycle_find)
|
||||
|
||||
add_executable(test_gtid test_gtid.cc)
|
||||
target_link_libraries(test_gtid mariadbmon maxscale-common)
|
||||
add_test(test_mariadbmon_gtid test_gtid)
|
||||
|
123
server/modules/monitor/mariadbmon/test/test_gtid.cc
Normal file
123
server/modules/monitor/mariadbmon/test/test_gtid.cc
Normal file
@ -0,0 +1,123 @@
|
||||
/*
|
||||
* Copyright (c) 2018 MariaDB Corporation Ab
|
||||
*
|
||||
* Use of this software is governed by the Business Source License included
|
||||
* in the LICENSE.TXT file and at www.mariadb.com/bsl11.
|
||||
*
|
||||
* Change Date: 2022-01-01
|
||||
*
|
||||
* On the date above, in accordance with the Business Source License, use
|
||||
* of this software will be governed by version 2 or later of the General
|
||||
* Public License.
|
||||
*/
|
||||
|
||||
#include "../gtid.hh"
|
||||
#include "maxbase/log.hh"
|
||||
#include <iostream>
|
||||
#include <string>
|
||||
#include <maxbase/maxbase.hh>
|
||||
|
||||
using std::string;
|
||||
using std::cout;
|
||||
|
||||
/**
|
||||
* Test parsing.
|
||||
*
|
||||
* @return Number of errors
|
||||
*/
|
||||
int test1()
|
||||
{
|
||||
struct TestCase
|
||||
{
|
||||
string input;
|
||||
string result;
|
||||
};
|
||||
|
||||
std::vector<TestCase> cases = {
|
||||
{"0-1-1", "0-1-1"},
|
||||
{"4321-1234-4321", "4321-1234-4321"},
|
||||
{"blah", ""},
|
||||
{"1x2x3", ""},
|
||||
{"1-2-3-4", ""},
|
||||
{"45-54-123456789,0-1-2", "0-1-2,45-54-123456789"},
|
||||
{"1-1-1,2-2-2,287-234-134,9-9-9,7-7-7", "1-1-1,2-2-2,7-7-7,9-9-9,287-234-134"},
|
||||
{"1-1-1,3-3-3,a-b-c", ""},
|
||||
{"-2--2--2",""},
|
||||
{"2-2-i",""},
|
||||
{"2-i-2",""},
|
||||
{"i-2-2",""},
|
||||
{"1-1-1,",""},
|
||||
{"3-1-0,3-2-4", "3-1-0,3-2-4"}, // Invalid triplet, but this case is not detected by the parser.
|
||||
};
|
||||
|
||||
int errors = 0;
|
||||
for (auto& test_case : cases)
|
||||
{
|
||||
string output = GtidList::from_string(test_case.input).to_string();
|
||||
if (output != test_case.result)
|
||||
{
|
||||
cout << "Wrong result: '" << test_case.input << "' produced '" << output << "' while '" <<
|
||||
test_case.result << "' was expected.\n";
|
||||
errors++;
|
||||
}
|
||||
}
|
||||
return errors;
|
||||
}
|
||||
|
||||
/**
|
||||
* Test parsing + calculations
|
||||
*
|
||||
* @return Number of errors
|
||||
*/
|
||||
int test2()
|
||||
{
|
||||
using sub_mode = GtidList::substraction_mode_t;
|
||||
auto ignore = sub_mode::MISSING_DOMAIN_IGNORE;
|
||||
auto lhs_add = sub_mode::MISSING_DOMAIN_LHS_ADD;
|
||||
|
||||
struct TestCase
|
||||
{
|
||||
string input1;
|
||||
string input2;
|
||||
sub_mode mode;
|
||||
uint64_t result;
|
||||
};
|
||||
|
||||
std::vector<TestCase> cases = {
|
||||
{"1-2-3", "1-2-3", ignore, 0},
|
||||
{"1-2-3,2-3-4", "1-2-3", lhs_add, 4},
|
||||
{"1-2-3,2-3-4", "1-2-3", ignore, 0},
|
||||
{"3-2-1,4-3-2", "4-3-1,3-1-0", lhs_add, 2},
|
||||
{"1-2-3,2-2-4,3-2-5", "1-2-3", lhs_add, 9},
|
||||
{"1-1-1000000,2-2-2000000", "1-1-1,2-2-2", ignore, 2999997},
|
||||
{"4-4-4,7-4-7,5-4-5,6-4-6,", "1-4-1", lhs_add, 0},
|
||||
{"4-4-4,7-4-7,5-4-5,6-4-6", "1-4-1", lhs_add, 22},
|
||||
{"5-1-4,", "5-1-2", ignore, 0},
|
||||
};
|
||||
|
||||
int errors = 0;
|
||||
for (auto& test_case : cases)
|
||||
{
|
||||
auto gtid1 = GtidList::from_string(test_case.input1);
|
||||
auto gtid2 = GtidList::from_string(test_case.input2);
|
||||
auto output = gtid1.events_ahead(gtid2, test_case.mode);
|
||||
if (output != test_case.result)
|
||||
{
|
||||
cout << "Wrong result: '" << test_case.input1 << "' and '" << test_case.input2 <<
|
||||
"' produced '" << output << "' while '" << test_case.result << "' was expected.\n";
|
||||
errors++;
|
||||
}
|
||||
}
|
||||
return errors;
|
||||
}
|
||||
|
||||
int main()
|
||||
{
|
||||
maxbase::init();
|
||||
maxbase::Log log;
|
||||
|
||||
int result = 0;
|
||||
result += test1();
|
||||
result += test2();
|
||||
return result;
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user