From 5f8de423f190bbb79a62f804151bc24824fa32d8 Mon Sep 17 00:00:00 2001 From: "Matt A. Tobin" Date: Fri, 2 Feb 2018 04:16:08 -0500 Subject: Add m-esr52 at 52.6.0 --- gfx/2d/unittest/TestBase.h | 54 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 54 insertions(+) create mode 100644 gfx/2d/unittest/TestBase.h (limited to 'gfx/2d/unittest/TestBase.h') diff --git a/gfx/2d/unittest/TestBase.h b/gfx/2d/unittest/TestBase.h new file mode 100644 index 000000000..a57d6a730 --- /dev/null +++ b/gfx/2d/unittest/TestBase.h @@ -0,0 +1,54 @@ +/* -*- Mode: C++; tab-width: 20; indent-tabs-mode: nil; c-basic-offset: 2 -*- + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +#pragma once + +#include +#include + +#ifdef _MSC_VER +// On MSVC otherwise our generic member pointer trick doesn't work. +#pragma pointers_to_members(full_generality, single_inheritance) +#endif + +#define VERIFY(arg) if (!(arg)) { \ + LogMessage("VERIFY FAILED: "#arg"\n"); \ + mTestFailed = true; \ + } + +#define REGISTER_TEST(className, testName) \ + mTests.push_back(Test(static_cast(&className::testName), #testName, this)) + +class TestBase +{ +public: + TestBase() {} + + typedef void (TestBase::*TestCall)(); + + int RunTests(int *aFailures); + +protected: + static void LogMessage(std::string aMessage); + + struct Test { + Test(TestCall aCall, std::string aName, void *aImplPointer) + : funcCall(aCall) + , name(aName) + , implPointer(aImplPointer) + { + } + TestCall funcCall; + std::string name; + void *implPointer; + }; + std::vector mTests; + + bool mTestFailed; + +private: + // This doesn't really work with our generic member pointer trick. + TestBase(const TestBase &aOther); +}; -- cgit v1.2.3