summaryrefslogtreecommitdiff
path: root/test/fixtures/fixture_log.hpp
diff options
context:
space:
mode:
Diffstat (limited to 'test/fixtures/fixture_log.hpp')
-rw-r--r--test/fixtures/fixture_log.hpp98
1 files changed, 15 insertions, 83 deletions
diff --git a/test/fixtures/fixture_log.hpp b/test/fixtures/fixture_log.hpp
index 8df16e3086..bc7c9fab31 100644
--- a/test/fixtures/fixture_log.hpp
+++ b/test/fixtures/fixture_log.hpp
@@ -9,27 +9,17 @@
#include <cstdarg>
#include <iostream>
-
namespace mbgl {
class FixtureLogBackend : public LogBackend, private util::noncopyable {
public:
struct LogMessage {
- inline LogMessage(EventSeverity severity_, Event event_, int64_t code_, const std::string &msg_)
- : severity(severity_), event(event_), code(code_), msg(msg_) {}
- inline LogMessage(EventSeverity severity_, Event event_, int64_t code_)
- : severity(severity_), event(event_), code(code_), msg() {}
- inline LogMessage(EventSeverity severity_, Event event_, const std::string &msg_)
- : severity(severity_), event(event_), code(), msg(msg_) {}
- inline LogMessage(EventSeverity severity_, Event event_)
- : severity(severity_), event(event_), code(), msg() {}
+ LogMessage(EventSeverity severity_, Event event_, int64_t code_, const std::string &msg_);
+ LogMessage(EventSeverity severity_, Event event_, int64_t code_);
+ LogMessage(EventSeverity severity_, Event event_, const std::string &msg_);
+ LogMessage(EventSeverity severity_, Event event_);
- inline bool operator==(const LogMessage &rhs) const {
- return (!severity || !rhs.severity || severity.get() == rhs.severity.get()) &&
- (!event || !rhs.event || event.get() == rhs.event.get()) &&
- (!code || !rhs.code || code.get() == rhs.code.get()) &&
- (!msg || !rhs.msg || msg.get() == rhs.msg.get());
- }
+ bool operator==(const LogMessage &rhs) const;
const mapbox::util::optional<EventSeverity> severity;
const mapbox::util::optional<Event> event;
@@ -39,81 +29,23 @@ public:
mutable bool checked = false;
};
- inline ~FixtureLogBackend();
-
- inline void record(EventSeverity severity, Event event, const std::string &msg) {
- messages.emplace_back(severity, event, msg);
- }
-
- inline void record(EventSeverity severity, Event event, const char* format, ...) {
- va_list args;
- va_start(args, format);
- const size_t len = vsnprintf(NULL, 0, format, args);
- va_end(args);
- std::unique_ptr<char[]> buffer(new char[len + 1]);
- va_start(args, format);
- vsnprintf(buffer.get(), len + 1, format, args);
- va_end(args);
- messages.emplace_back(severity, event, std::string { buffer.get(), len });
- }
-
- inline void record(EventSeverity severity, Event event, int64_t code) {
- messages.emplace_back(severity, event, code);
- }
+ ~FixtureLogBackend();
- inline void record(EventSeverity severity, Event event, int64_t code, const std::string &msg) {
- messages.emplace_back(severity, event, code, msg);
- }
+ inline void record(EventSeverity severity, Event event, const std::string &msg);
+ inline void record(EventSeverity severity, Event event, const char *format, ...);
+ inline void record(EventSeverity severity, Event event, int64_t code);
+ inline void record(EventSeverity severity, Event event, int64_t code, const std::string &msg);
- inline size_t count(const LogMessage &message) const;
- inline std::vector<LogMessage> unchecked() const;
+ size_t count(const LogMessage &message) const;
+ std::vector<LogMessage> unchecked() const;
public:
std::vector<LogMessage> messages;
};
-inline ::std::ostream& operator<<(::std::ostream& os, const std::vector<FixtureLogBackend::LogMessage>& messages);
-inline ::std::ostream& operator<<(::std::ostream& os, const FixtureLogBackend::LogMessage& message);
-
-FixtureLogBackend::~FixtureLogBackend() {
- std::cerr << unchecked();
-}
-
-size_t FixtureLogBackend::count(const LogMessage &message) const {
- size_t message_count = 0;
- for (const LogMessage &msg : messages) {
- if (msg == message) {
- message_count++;
- msg.checked = true;
- }
- }
- return message_count;
-}
-
-std::vector<FixtureLogBackend::LogMessage> FixtureLogBackend::unchecked() const {
- std::vector<LogMessage> unchecked_messages;
- for (const LogMessage &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<FixtureLogBackend::LogMessage>& messages) {
- for (const FixtureLogBackend::LogMessage &message : messages) {
- os << "- " << message;
- }
- return os;
-}
-
-::std::ostream& operator<<(::std::ostream& os, const FixtureLogBackend::LogMessage& message) {
- os << "[\"" << message.severity.get() << "\", \"" << message.event.get() << "\"";
- if (message.code) os << ", " << message.code.get();
- if (message.msg) os << ", \"" << message.msg.get() << "\"";
- return os << "]" << std::endl;
-}
+::std::ostream &operator<<(::std::ostream &os,
+ const std::vector<FixtureLogBackend::LogMessage> &messages);
+::std::ostream &operator<<(::std::ostream &os, const FixtureLogBackend::LogMessage &message);
}