Also proxy bumpTestCount.
Example output with -v -x:
...
Finished 127 tests, 0 failures, 0 skipped.
Ran 73094673 Internal tests.
BUG=
R=caryclark@google.com
Author: mtklein@google.com
Review URL: https://chromiumcodereview.appspot.com/13983011
git-svn-id: http://skia.googlecode.com/svn/trunk@8821 2bbb7eff-a529-9590-31e7-b0007b416f81
diff --git a/tests/Test.cpp b/tests/Test.cpp
index 07db969..5558a0b 100644
--- a/tests/Test.cpp
+++ b/tests/Test.cpp
@@ -60,7 +60,7 @@
namespace {
class LocalReporter : public Reporter {
public:
- explicit LocalReporter(const Reporter& reporterToMimic) : fReporter(reporterToMimic) {}
+ explicit LocalReporter(Reporter* reporterToMimic) : fReporter(reporterToMimic) {}
int failure_size() const { return fFailures.count(); }
const char* failure(int i) const { return fFailures[i].c_str(); }
@@ -72,16 +72,21 @@
}
}
+ // Proxy down to fReporter. We assume these calls are threadsafe.
virtual bool allowExtendedTest() const SK_OVERRIDE {
- return fReporter.allowExtendedTest();
+ return fReporter->allowExtendedTest();
}
virtual bool allowThreaded() const SK_OVERRIDE {
- return fReporter.allowThreaded();
+ return fReporter->allowThreaded();
+ }
+
+ virtual void bumpTestCount() SK_OVERRIDE {
+ fReporter->bumpTestCount();
}
private:
- const Reporter& fReporter;
+ Reporter* fReporter; // Unowned.
SkTArray<SkString> fFailures;
};
} // namespace
@@ -93,7 +98,7 @@
const SkMSec start = SkTime::GetMSecs();
// Run the test into a LocalReporter so we know if it's passed or failed without interference
// from other tests that might share fReporter.
- LocalReporter local(*fReporter);
+ LocalReporter local(fReporter);
this->onRun(&local);
fPassed = local.failure_size() == 0;
fElapsed = SkTime::GetMSecs() - start;