summaryrefslogtreecommitdiff
path: root/test/src/fixture_log_observer.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'test/src/fixture_log_observer.cpp')
-rw-r--r--test/src/fixture_log_observer.cpp105
1 files changed, 105 insertions, 0 deletions
diff --git a/test/src/fixture_log_observer.cpp b/test/src/fixture_log_observer.cpp
new file mode 100644
index 0000000000..302fdc7081
--- /dev/null
+++ b/test/src/fixture_log_observer.cpp
@@ -0,0 +1,105 @@
+#include <mbgl/test/fixture_log_observer.hpp>
+#include <mbgl/test/util.hpp>
+
+namespace mbgl {
+
+FixtureLog::Message::Message(EventSeverity severity_,
+ Event event_,
+ int64_t code_,
+ const std::string& msg_)
+ : severity(severity_), event(event_), code(code_), msg(msg_) {
+}
+
+bool FixtureLog::Message::operator==(const Message& rhs) const {
+ return severity == rhs.severity && event == rhs.event && code == rhs.code && msg == rhs.msg;
+}
+
+FixtureLog::Message::Message() : severity(), event(), code(), msg() {
+}
+
+FixtureLog::Observer::Observer(FixtureLog* log_) : log(log_) {
+}
+
+FixtureLog::Observer::~Observer() {
+ if (log) {
+ log->observer = nullptr;
+ }
+ std::cerr << unchecked();
+}
+
+bool FixtureLog::Observer::onRecord(EventSeverity severity,
+ Event event,
+ int64_t code,
+ const std::string& msg) {
+ std::lock_guard<std::mutex> lock(messagesMutex);
+
+ messages.emplace_back(severity, event, code, msg);
+
+ return true;
+}
+
+bool FixtureLog::Observer::empty() const {
+ std::lock_guard<std::mutex> lock(messagesMutex);
+
+ return messages.empty();
+}
+
+size_t FixtureLog::Observer::count(const Message& message) const {
+ std::lock_guard<std::mutex> lock(messagesMutex);
+
+ size_t message_count = 0;
+ for (const auto& msg : messages) {
+ if (msg == message) {
+ message_count++;
+ msg.checked = true;
+ }
+ }
+ return message_count;
+}
+
+FixtureLog::FixtureLog() : observer(new FixtureLogObserver(this)) {
+ Log::setObserver(std::unique_ptr<Log::Observer>(observer));
+}
+
+bool FixtureLog::empty() const {
+ return observer ? observer->empty() : true;
+}
+
+size_t FixtureLog::count(const FixtureLog::Message& message) const {
+ return observer ? observer->count(message) : 0;
+}
+
+FixtureLog::~FixtureLog() {
+ if (observer) {
+ Log::removeObserver();
+ }
+}
+
+std::vector<FixtureLog::Message> FixtureLogObserver::unchecked() const {
+ std::lock_guard<std::mutex> lock(messagesMutex);
+
+ std::vector<Message> unchecked_messages;
+ for (const auto& msg : messages) {
+ if (!msg.checked) {
+ unchecked_messages.push_back(msg);
+ msg.checked = true;
+ }
+ }
+ return unchecked_messages;
+}
+
+::std::ostream& operator<<(::std::ostream& os, const std::vector<FixtureLog::Message>& messages) {
+ for (const auto& message : messages) {
+ os << "- " << message;
+ }
+ return os;
+}
+
+::std::ostream& operator<<(::std::ostream& os, const FixtureLog::Message& message) {
+ os << "[\"" << message.severity << "\", \"" << message.event << "\"";
+ os << ", " << message.code;
+ os << ", \"" << message.msg << "\"";
+ return os << "]" << std::endl;
+}
+
+} // namespace mbgl