2018-10-22 22:44:18 +00:00
|
|
|
#include "test_assert.h"
|
|
|
|
|
2019-01-24 21:30:11 +00:00
|
|
|
#include <assert.h>
|
|
|
|
|
2018-10-03 19:04:14 +00:00
|
|
|
#ifdef _MSC_VER
|
|
|
|
# include <crtdbg.h>
|
2019-04-08 17:01:41 +00:00
|
|
|
# include <windows.h>
|
2018-10-03 19:04:14 +00:00
|
|
|
#endif
|
|
|
|
|
2018-09-24 19:03:31 +00:00
|
|
|
int testing_fails = 0;
|
2018-10-22 22:44:18 +00:00
|
|
|
static TestFailEventListener fail_listener_ = nullptr;
|
2018-09-24 19:03:31 +00:00
|
|
|
|
|
|
|
void TestFail(const char *expval, const char *val, const char *exp,
|
|
|
|
const char *file, int line, const char *func) {
|
2019-11-25 20:56:47 +00:00
|
|
|
TEST_OUTPUT_LINE("EXPECTED: \"%s\"", expval);
|
|
|
|
TEST_OUTPUT_LINE("VALUE: \"%s\"", val);
|
2018-10-03 19:04:14 +00:00
|
|
|
TEST_OUTPUT_LINE("TEST FAILED: %s:%d, %s in %s", file, line, exp,
|
|
|
|
func ? func : "");
|
2018-09-24 19:03:31 +00:00
|
|
|
testing_fails++;
|
2018-10-22 22:44:18 +00:00
|
|
|
|
|
|
|
// Notify, emulate 'gtest::OnTestPartResult' event handler.
|
2018-11-16 17:24:06 +00:00
|
|
|
if (fail_listener_) (*fail_listener_)(expval, val, exp, file, line, func);
|
2018-10-22 22:44:18 +00:00
|
|
|
|
2018-11-16 17:24:06 +00:00
|
|
|
assert(0); // ignored in Release if NDEBUG defined
|
2018-09-24 19:03:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void TestEqStr(const char *expval, const char *val, const char *exp,
|
2019-11-25 20:56:47 +00:00
|
|
|
const char *file, int line, const char *func) {
|
2020-03-02 18:15:23 +00:00
|
|
|
if (strcmp(expval, val) != 0) {
|
|
|
|
TestFail(expval, val, exp, file, line, func);
|
|
|
|
}
|
2018-09-24 19:03:31 +00:00
|
|
|
}
|
|
|
|
|
2019-01-24 21:30:11 +00:00
|
|
|
#if defined(FLATBUFFERS_MEMORY_LEAK_TRACKING) && defined(_MSC_VER) && \
|
|
|
|
defined(_DEBUG)
|
2019-11-07 20:22:54 +00:00
|
|
|
# define FLATBUFFERS_MEMORY_LEAK_TRACKING_MSVC
|
2018-10-03 19:04:14 +00:00
|
|
|
#endif
|
|
|
|
|
2018-10-22 22:44:18 +00:00
|
|
|
void InitTestEngine(TestFailEventListener listener) {
|
2018-10-03 19:04:14 +00:00
|
|
|
testing_fails = 0;
|
|
|
|
// Disable stdout buffering to prevent information lost on assertion or core
|
|
|
|
// dump.
|
|
|
|
setvbuf(stdout, NULL, _IONBF, 0);
|
|
|
|
setvbuf(stderr, NULL, _IONBF, 0);
|
|
|
|
|
2019-05-09 17:10:10 +00:00
|
|
|
flatbuffers::SetupDefaultCRTReportMode();
|
2018-10-03 19:04:14 +00:00
|
|
|
|
2019-05-09 17:10:10 +00:00
|
|
|
// clang-format off
|
2019-01-24 21:30:11 +00:00
|
|
|
|
|
|
|
#if defined(FLATBUFFERS_MEMORY_LEAK_TRACKING_MSVC)
|
|
|
|
// For more thorough checking:
|
|
|
|
// _CRTDBG_DELAY_FREE_MEM_DF | _CRTDBG_CHECK_ALWAYS_DF
|
|
|
|
auto flags = _CrtSetDbgFlag(_CRTDBG_REPORT_FLAG);
|
|
|
|
_CrtSetDbgFlag(flags | _CRTDBG_ALLOC_MEM_DF);
|
2018-10-03 19:04:14 +00:00
|
|
|
#endif
|
|
|
|
// clang-format on
|
2018-10-22 22:44:18 +00:00
|
|
|
|
|
|
|
fail_listener_ = listener;
|
2018-10-03 19:04:14 +00:00
|
|
|
}
|
2019-01-24 21:30:11 +00:00
|
|
|
|
|
|
|
int CloseTestEngine(bool force_report) {
|
|
|
|
if (!testing_fails || force_report) {
|
2019-11-07 20:22:54 +00:00
|
|
|
#if defined(FLATBUFFERS_MEMORY_LEAK_TRACKING_MSVC)
|
|
|
|
auto flags = _CrtSetDbgFlag(_CRTDBG_REPORT_FLAG);
|
|
|
|
flags &= ~_CRTDBG_DELAY_FREE_MEM_DF;
|
|
|
|
flags |= _CRTDBG_LEAK_CHECK_DF;
|
|
|
|
_CrtSetDbgFlag(flags);
|
|
|
|
#endif
|
2019-01-24 21:30:11 +00:00
|
|
|
}
|
|
|
|
return (0 != testing_fails);
|
|
|
|
}
|