blob: 2cbd00b594edf062df01888fbc244f7f3ebc3864 [file] [log] [blame]
/*
* Copyright 2011 Google Inc.
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#ifndef skiatest_Test_DEFINED
#define skiatest_Test_DEFINED
#include "SkRefCnt.h"
#include "SkString.h"
#include "SkTRegistry.h"
class GrContext;
class SkGLContext;
namespace skiatest {
class Test;
class Reporter : public SkRefCnt {
public:
SK_DECLARE_INST_COUNT(Reporter)
Reporter();
enum Result {
kPassed, // must begin with 0
kFailed,
/////
kLastResult = kFailed
};
void resetReporting();
int countTests() const { return fTestCount; }
int countResults(Result r) {
SkASSERT((unsigned)r <= kLastResult);
return fResultCount[r];
}
void startTest(Test*);
void report(const char testDesc[], Result);
void endTest(Test*);
// helpers for tests
void assertTrue(bool cond, const char desc[]) {
if (!cond) {
this->report(desc, kFailed);
}
}
void assertFalse(bool cond, const char desc[]) {
if (cond) {
this->report(desc, kFailed);
}
}
void reportFailed(const char desc[]) {
this->report(desc, kFailed);
}
void reportFailed(const SkString& desc) {
this->report(desc.c_str(), kFailed);
}
bool getCurrSuccess() const {
return fCurrTestSuccess;
}
protected:
virtual void onStart(Test*) {}
virtual void onReport(const char desc[], Result) {}
virtual void onEnd(Test*) {}
private:
Test* fCurrTest;
int fTestCount;
int fResultCount[kLastResult+1];
bool fCurrTestSuccess;
typedef SkRefCnt INHERITED;
};
class Test {
public:
Test();
virtual ~Test();
Reporter* getReporter() const { return fReporter; }
void setReporter(Reporter*);
const char* getName();
bool run(); // returns true on success
protected:
virtual void onGetName(SkString*) = 0;
virtual void onRun(Reporter*) = 0;
private:
Reporter* fReporter;
SkString fName;
};
class GpuTest : public Test{
public:
GpuTest() : Test() {
fContext = GetContext();
}
static GrContext* GetContext();
static void DestroyContext();
protected:
GrContext* fContext;
private:
};
typedef SkTRegistry<Test*, void*> TestRegistry;
}
#define REPORTER_ASSERT(r, cond) \
do { \
if (!(cond)) { \
SkString desc; \
desc.printf("%s:%d: %s", __FILE__, __LINE__, #cond); \
r->reportFailed(desc); \
} \
} while(0)
#define REPORTER_ASSERT_MESSAGE(r, cond, message) \
do { \
if (!(cond)) { \
SkString desc; \
desc.printf("%s %s:%d: %s", message, __FILE__, __LINE__, #cond); \
r->reportFailed(desc); \
} \
} while(0)
#endif