Mercurial > fife-parpg
view ext/UnitTest++/src/tests/RecordingReporter.h @ 215:5f5f8ca6db93
- added indicator for the active layer (no color indication, unfortunately pychan can't style widgets once they were stylized(), which is true for the editor application)
- added autoselection for a different layer if the active layer becomes invisible (which works but has no checks if the new active layer is invisible)
author | chewie@33b003aa-7bff-0310-803a-e67f0ece8222 |
---|---|
date | Tue, 17 Mar 2009 23:18:11 +0000 |
parents | 0d325e9d5953 |
children |
line wrap: on
line source
#ifndef UNITTEST_RECORDINGREPORTER_H #define UNITTEST_RECORDINGREPORTER_H #include "../TestReporter.h" #include <cstring> #include "../TestDetails.h" struct RecordingReporter : public UnitTest::TestReporter { private: enum { kMaxStringLength = 256 }; public: RecordingReporter() : testRunCount(0) , testFailedCount(0) , lastFailedLine(0) , testFinishedCount(0) , lastFinishedTestTime(0) , summaryTotalTestCount(0) , summaryFailedTestCount(0) , summaryFailureCount(0) , summarySecondsElapsed(0) { lastStartedSuite[0] = '\0'; lastStartedTest[0] = '\0'; lastFailedFile[0] = '\0'; lastFailedSuite[0] = '\0'; lastFailedTest[0] = '\0'; lastFailedMessage[0] = '\0'; lastFinishedSuite[0] = '\0'; lastFinishedTest[0] = '\0'; } virtual void ReportTestStart(UnitTest::TestDetails const& test) { ++testRunCount; std::strcpy(lastStartedSuite, test.suiteName); std::strcpy(lastStartedTest, test.testName); } virtual void ReportFailure(UnitTest::TestDetails const& test, char const* failure) { ++testFailedCount; std::strcpy(lastFailedFile, test.filename); lastFailedLine = test.lineNumber; std::strcpy(lastFailedSuite, test.suiteName); std::strcpy(lastFailedTest, test.testName); std::strcpy(lastFailedMessage, failure); } virtual void ReportTestFinish(UnitTest::TestDetails const& test, float testDuration) { ++testFinishedCount; std::strcpy(lastFinishedSuite, test.suiteName); std::strcpy(lastFinishedTest, test.testName); lastFinishedTestTime = testDuration; } virtual void ReportSummary(int totalTestCount, int failedTestCount, int failureCount, float secondsElapsed) { summaryTotalTestCount = totalTestCount; summaryFailedTestCount = failedTestCount; summaryFailureCount = failureCount; summarySecondsElapsed = secondsElapsed; } int testRunCount; char lastStartedSuite[kMaxStringLength]; char lastStartedTest[kMaxStringLength]; int testFailedCount; char lastFailedFile[kMaxStringLength]; int lastFailedLine; char lastFailedSuite[kMaxStringLength]; char lastFailedTest[kMaxStringLength]; char lastFailedMessage[kMaxStringLength]; int testFinishedCount; char lastFinishedSuite[kMaxStringLength]; char lastFinishedTest[kMaxStringLength]; float lastFinishedTestTime; int summaryTotalTestCount; int summaryFailedTestCount; int summaryFailureCount; float summarySecondsElapsed; }; #endif