summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDan Goodliffe <dan@randomdan.homeip.net>2021-08-22 13:09:25 +0100
committerDan Goodliffe <dan@randomdan.homeip.net>2021-08-22 13:09:25 +0100
commitde50cd15f12216760bb746ec8936fc1501113425 (patch)
tree5046e4d35693de2e83b12881bc7cd7cf1a05e2d0
parentEnable numeric conversion warning and fix the fallout (diff)
downloadmygrate-de50cd15f12216760bb746ec8936fc1501113425.tar.bz2
mygrate-de50cd15f12216760bb746ec8936fc1501113425.tar.xz
mygrate-de50cd15f12216760bb746ec8936fc1501113425.zip
Add EventCounter class
-rw-r--r--lib/eventCounter.cpp30
-rw-r--r--lib/eventCounter.h22
-rw-r--r--test/Jamfile.jam1
-rw-r--r--test/helpers.cpp7
-rw-r--r--test/helpers.h6
-rw-r--r--test/test-counters.cpp84
6 files changed, 150 insertions, 0 deletions
diff --git a/lib/eventCounter.cpp b/lib/eventCounter.cpp
new file mode 100644
index 0000000..92383c5
--- /dev/null
+++ b/lib/eventCounter.cpp
@@ -0,0 +1,30 @@
+#include "eventCounter.h"
+#include <algorithm>
+
+namespace MyGrate {
+ void
+ EventCounter::tick(mariadb_rpl_event e)
+ {
+ counters[e]++;
+ }
+ const EventCounter::Counters &
+ EventCounter::getAll() const
+ {
+ return counters;
+ }
+ unsigned long
+ EventCounter::get(mariadb_rpl_event e) const
+ {
+ return counters[e];
+ }
+ bool
+ EventCounter::operator>=(const EventCounter & target) const
+ {
+ for (size_t e {}; e < ENUM_END_EVENT; e++) {
+ if (counters[e] < target.counters[e]) {
+ return false;
+ }
+ }
+ return true;
+ }
+}
diff --git a/lib/eventCounter.h b/lib/eventCounter.h
new file mode 100644
index 0000000..522310a
--- /dev/null
+++ b/lib/eventCounter.h
@@ -0,0 +1,22 @@
+#ifndef MYGRATE_EVENTCOUNTER_H
+#define MYGRATE_EVENTCOUNTER_H
+
+#include "mariadb_repl.h"
+#include <array>
+
+namespace MyGrate {
+ class EventCounter {
+ public:
+ using Counters = std::array<unsigned long, ENUM_END_EVENT>;
+
+ void tick(mariadb_rpl_event);
+ const Counters & getAll() const;
+ unsigned long get(mariadb_rpl_event) const;
+ bool operator>=(const EventCounter &) const;
+
+ protected:
+ Counters counters {};
+ };
+}
+
+#endif
diff --git a/test/Jamfile.jam b/test/Jamfile.jam
index 1f0dac3..16b7244 100644
--- a/test/Jamfile.jam
+++ b/test/Jamfile.jam
@@ -17,6 +17,7 @@ run test-rawDataReader.cpp ;
run test-bitset.cpp ;
run test-streams.cpp ;
run test-misc.cpp ;
+run test-counters.cpp : : : <library>testdb ;
run test-mysql.cpp : : : <library>testdb ;
run test-postgresql.cpp : -- : ../db/schema.sql : <library>testdb ;
run test-e2e.cpp : -- : ../db/schema.sql : <library>testdb <implicit-dependency>testdb ;
diff --git a/test/helpers.cpp b/test/helpers.cpp
index f4fc030..6cb6fdc 100644
--- a/test/helpers.cpp
+++ b/test/helpers.cpp
@@ -13,3 +13,10 @@ MemStream::flush()
{
fflush(s);
}
+
+EventCounterTarget &
+EventCounterTarget::add(mariadb_rpl_event e, unsigned long n)
+{
+ counters[e] += n;
+ return *this;
+}
diff --git a/test/helpers.h b/test/helpers.h
index 87ef31d..9596e12 100644
--- a/test/helpers.h
+++ b/test/helpers.h
@@ -5,6 +5,7 @@
#include <cstddef>
#include <cstdio>
#include <ctime>
+#include <eventCounter.h>
#include <iostream>
#include <memory>
#include <optional>
@@ -68,4 +69,9 @@ struct MemStream {
FILE * s;
};
+class EventCounterTarget : public MyGrate::EventCounter {
+public:
+ EventCounterTarget & add(mariadb_rpl_event, unsigned long);
+};
+
#endif
diff --git a/test/test-counters.cpp b/test/test-counters.cpp
new file mode 100644
index 0000000..1bc30dc
--- /dev/null
+++ b/test/test-counters.cpp
@@ -0,0 +1,84 @@
+#define BOOST_TEST_MODULE Counters
+#include <boost/test/unit_test.hpp>
+
+#include "helpers.h"
+
+BOOST_FIXTURE_TEST_SUITE(ec, EventCounterTarget);
+
+BOOST_AUTO_TEST_CASE(zero)
+{
+ std::array<unsigned long, ENUM_END_EVENT> z {};
+ BOOST_CHECK_EQUAL_COLLECTIONS(counters.begin(), counters.end(), z.begin(), z.end());
+}
+
+BOOST_AUTO_TEST_CASE(tick_getAll)
+{
+ BOOST_CHECK_EQUAL(&counters, &getAll());
+}
+
+BOOST_AUTO_TEST_CASE(tick_one)
+{
+ tick(ROTATE_EVENT);
+ BOOST_CHECK_EQUAL(get(ROTATE_EVENT), 1);
+}
+
+BOOST_AUTO_TEST_CASE(tick_three)
+{
+ add(ROTATE_EVENT, 3);
+ BOOST_CHECK_EQUAL(get(ROTATE_EVENT), 3);
+}
+
+BOOST_AUTO_TEST_CASE(tick_different)
+{
+ add(ROTATE_EVENT, 2).add(UPDATE_ROWS_EVENT_V1, 1);
+ BOOST_CHECK_EQUAL(get(ROTATE_EVENT), 2);
+ BOOST_CHECK_EQUAL(get(UPDATE_ROWS_EVENT_V1), 1);
+}
+
+BOOST_AUTO_TEST_CASE(compare_zero)
+{
+ EventCounter other;
+ BOOST_CHECK(other >= *this);
+}
+
+BOOST_AUTO_TEST_CASE(compare_one)
+{
+ EventCounter other;
+ tick(ROTATE_EVENT);
+
+ BOOST_CHECK(!(other >= *this));
+
+ other.tick(ROTATE_EVENT);
+ BOOST_CHECK(other >= *this);
+
+ other.tick(ROTATE_EVENT);
+ BOOST_CHECK(other >= *this);
+}
+
+BOOST_AUTO_TEST_CASE(compare_many)
+{
+ EventCounter other;
+ add(ROTATE_EVENT, 2).add(UPDATE_ROWS_EVENT_V1, 1);
+
+ BOOST_CHECK(!(other >= *this));
+
+ other.tick(UPDATE_ROWS_EVENT_V1);
+ BOOST_CHECK(!(other >= *this));
+
+ other.tick(UPDATE_ROWS_EVENT_V1);
+ BOOST_CHECK(!(other >= *this));
+
+ other.tick(ROTATE_EVENT);
+ BOOST_CHECK(!(other >= *this));
+
+ other.tick(ROTATE_EVENT);
+ BOOST_CHECK(other >= *this);
+
+ other.tick(ROTATE_EVENT);
+ BOOST_CHECK(other >= *this);
+
+ other.tick(UPDATE_ROWS_EVENT_V1);
+ BOOST_CHECK(other >= *this);
+}
+
+BOOST_AUTO_TEST_SUITE_END();