2010-06-26 13:07:13 +00:00
|
|
|
/* ScummVM - Graphic Adventure Engine
|
|
|
|
*
|
|
|
|
* ScummVM is the legal property of its developers, whose names
|
|
|
|
* are too numerous to list here. Please refer to the COPYRIGHT
|
|
|
|
* file distributed with this source distribution.
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
2014-02-18 01:34:25 +00:00
|
|
|
*
|
2010-06-26 13:07:13 +00:00
|
|
|
*/
|
|
|
|
|
2010-06-26 21:28:50 +00:00
|
|
|
#ifndef TESTBED_TESTSUITE_H
|
|
|
|
#define TESTBED_TESTSUITE_H
|
2010-06-01 18:06:31 +00:00
|
|
|
|
2011-04-24 08:34:27 +00:00
|
|
|
#include "common/array.h"
|
|
|
|
#include "common/rect.h"
|
|
|
|
#include "common/scummsys.h"
|
2010-06-01 18:06:31 +00:00
|
|
|
#include "common/system.h"
|
2010-06-02 04:45:44 +00:00
|
|
|
#include "common/str.h"
|
2011-04-24 08:34:27 +00:00
|
|
|
#include "graphics/font.h"
|
2010-06-01 18:06:31 +00:00
|
|
|
|
2010-07-19 21:12:17 +00:00
|
|
|
#include "graphics/fontman.h"
|
2010-06-06 14:06:51 +00:00
|
|
|
|
2010-10-02 01:05:16 +00:00
|
|
|
#include "testbed/config-params.h"
|
|
|
|
|
2010-06-01 18:06:31 +00:00
|
|
|
namespace Testbed {
|
|
|
|
|
2010-06-06 14:06:51 +00:00
|
|
|
enum {
|
|
|
|
kColorBlack = 0,
|
|
|
|
kColorWhite = 1,
|
2010-07-25 20:50:59 +00:00
|
|
|
kColorCustom = 2,
|
|
|
|
kColorSpecial = 5 ///< some random number
|
2010-06-06 14:06:51 +00:00
|
|
|
};
|
|
|
|
|
2010-06-14 20:15:15 +00:00
|
|
|
enum OptionSelected {
|
|
|
|
kOptionLeft = 1,
|
|
|
|
kOptionRight = 0
|
|
|
|
};
|
|
|
|
|
2010-07-05 21:29:15 +00:00
|
|
|
enum {
|
|
|
|
kEngineQuit = 0,
|
|
|
|
kSkipNext = 1,
|
|
|
|
kLoopNormal = 2,
|
|
|
|
// Event handling time,(in ms) used in parseEvent()
|
|
|
|
kEventHandlingTime = 50
|
|
|
|
};
|
|
|
|
|
2010-08-09 20:10:53 +00:00
|
|
|
enum TestExitStatus {
|
|
|
|
kTestPassed = 0,
|
|
|
|
kTestSkipped,
|
|
|
|
kTestFailed
|
|
|
|
};
|
|
|
|
|
|
|
|
typedef TestExitStatus (*InvokingFunction)();
|
2010-06-01 18:06:31 +00:00
|
|
|
|
2010-06-02 04:45:44 +00:00
|
|
|
/**
|
|
|
|
* This represents a feature to be tested
|
|
|
|
*/
|
|
|
|
|
2010-06-01 18:06:31 +00:00
|
|
|
struct Test {
|
2010-07-01 12:30:56 +00:00
|
|
|
Test(Common::String name, InvokingFunction f, bool interactive) : featureName(name) {
|
|
|
|
driver = f;
|
|
|
|
enabled = true;
|
|
|
|
passed = false;
|
|
|
|
isInteractive = interactive;
|
|
|
|
}
|
|
|
|
const Common::String featureName; ///< Name of feature to be tested
|
|
|
|
InvokingFunction driver; ///< Pointer to the function that will invoke this feature test
|
2010-06-02 04:45:44 +00:00
|
|
|
bool enabled; ///< Decides whether or not this test is to be executed
|
|
|
|
bool passed; ///< Collects and stores result of this feature test
|
2010-07-01 12:30:56 +00:00
|
|
|
bool isInteractive; ///< Decides if the test is interactive or not, An interactive testsuite may have non-interactive tests, hence this change.
|
2010-06-01 18:06:31 +00:00
|
|
|
};
|
|
|
|
|
2010-06-02 04:45:44 +00:00
|
|
|
|
2010-06-01 18:06:31 +00:00
|
|
|
/**
|
|
|
|
* The basic Testsuite class
|
|
|
|
* All the other testsuites would inherit it and override its virtual methods
|
|
|
|
*/
|
|
|
|
|
|
|
|
class Testsuite {
|
|
|
|
public:
|
2010-06-26 14:29:50 +00:00
|
|
|
Testsuite();
|
2010-07-14 14:12:42 +00:00
|
|
|
virtual ~Testsuite();
|
2010-06-13 19:19:06 +00:00
|
|
|
int getNumTests() const { return _testsToExecute.size(); }
|
|
|
|
int getNumTestsPassed() const { return _numTestsPassed; }
|
2010-08-09 20:10:53 +00:00
|
|
|
int getNumTestsSkipped() const { return _numTestsSkipped; }
|
2010-06-13 19:19:06 +00:00
|
|
|
int getNumTestsFailed() const { return _numTestsExecuted - _numTestsPassed; }
|
2010-06-26 14:29:50 +00:00
|
|
|
void genReport() const;
|
2010-07-01 12:30:56 +00:00
|
|
|
bool isEnabled() const { return _isTsEnabled; }
|
2010-07-10 19:24:12 +00:00
|
|
|
virtual void enable(bool flag) {
|
2010-07-01 12:30:56 +00:00
|
|
|
_isTsEnabled = flag;
|
|
|
|
}
|
2010-07-24 16:05:19 +00:00
|
|
|
bool enableTest(const Common::String &testName, bool enable);
|
2010-07-30 13:54:25 +00:00
|
|
|
void reset();
|
2010-08-14 08:32:39 +00:00
|
|
|
|
2010-06-06 14:06:51 +00:00
|
|
|
/**
|
|
|
|
* Prompts for User Input in form of "Yes" or "No" for interactive tests
|
|
|
|
* e.g: "Is this like you expect?" "Yes" or "No"
|
|
|
|
*
|
|
|
|
* @param textToDisplay Display text
|
|
|
|
* @return true if "Yes" false otherwise
|
2010-07-14 14:12:42 +00:00
|
|
|
*/
|
2010-06-26 14:29:50 +00:00
|
|
|
static bool handleInteractiveInput(const Common::String &textToDisplay, const char *opt1 = "Yes", const char *opt2 = "No", OptionSelected result = kOptionLeft);
|
2010-07-14 14:12:42 +00:00
|
|
|
|
2011-06-06 22:49:58 +00:00
|
|
|
static void displayMessage(const Common::String &textToDisplay, const char *defaultButton = "OK");
|
2010-07-14 14:12:42 +00:00
|
|
|
static Common::Rect writeOnScreen(const Common::String &textToDisplay, const Common::Point &pt, bool flag = false);
|
2010-06-26 14:29:50 +00:00
|
|
|
static void clearScreen(const Common::Rect &rect);
|
2010-07-25 20:50:59 +00:00
|
|
|
static void clearEntireScreen() {
|
|
|
|
const int width = g_system->getWidth();
|
|
|
|
const int height = g_system->getHeight();
|
|
|
|
Common::Rect r(0, 0, width, height);
|
|
|
|
clearScreen(r);
|
|
|
|
}
|
2010-06-26 14:29:50 +00:00
|
|
|
static void clearScreen();
|
|
|
|
static void clearScreen(bool flag);
|
2010-06-02 04:45:44 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Adds a test to the list of tests to be executed
|
|
|
|
*
|
|
|
|
* @param name the string description of the test, for display purposes
|
|
|
|
* @param f pointer to the function that invokes this test
|
2010-07-01 12:30:56 +00:00
|
|
|
* @param isInteractive decides if the test is to be executed in interactive mode/ default true
|
2010-06-02 04:45:44 +00:00
|
|
|
*/
|
2010-07-01 12:30:56 +00:00
|
|
|
void addTest(const Common::String &name, InvokingFunction f, bool isInteractive = true);
|
2010-06-26 14:29:50 +00:00
|
|
|
|
2010-06-02 04:45:44 +00:00
|
|
|
/**
|
|
|
|
* The driver function for the testsuite
|
|
|
|
* All code should go in here.
|
|
|
|
*/
|
2010-06-26 14:29:50 +00:00
|
|
|
virtual void execute();
|
2010-07-05 21:29:15 +00:00
|
|
|
static uint parseEvents();
|
2010-07-14 14:12:42 +00:00
|
|
|
|
2010-06-13 19:19:06 +00:00
|
|
|
virtual const char *getName() const = 0;
|
2010-07-18 09:08:18 +00:00
|
|
|
virtual const char *getDescription() const = 0;
|
2010-06-01 18:06:31 +00:00
|
|
|
|
2010-06-29 22:46:56 +00:00
|
|
|
static void logPrintf(const char *s, ...) GCC_PRINTF(1, 2);
|
|
|
|
static void logDetailedPrintf(const char *s, ...) GCC_PRINTF(1, 2);
|
2011-06-06 22:49:58 +00:00
|
|
|
|
2010-07-19 21:12:17 +00:00
|
|
|
// Progress bar (Information Display) related methods.
|
2010-08-14 08:32:39 +00:00
|
|
|
/**
|
2010-07-19 21:12:17 +00:00
|
|
|
* Display region is in the bottom. Probably 1/4th of the game screen.
|
|
|
|
* It contains:
|
|
|
|
* 1) Information about executing testsuite.
|
|
|
|
* 2) Total progress within this testsuite.
|
|
|
|
* 3) Total overall progress in the number of testsuites
|
|
|
|
*/
|
|
|
|
|
|
|
|
static Common::Point getDisplayRegionCoordinates() {
|
|
|
|
Common::Point pt(0, 0);
|
|
|
|
// start from bottom
|
|
|
|
pt.y = g_system->getHeight();
|
|
|
|
// Will Contain 3 lines
|
2010-10-02 01:05:16 +00:00
|
|
|
pt.y -= (FontMan.getFontByUsage(ConfParams.getCurrentFontUsageType())->getFontHeight() * 3 + 15); // Buffer of 5 pixels per line
|
2010-07-19 21:12:17 +00:00
|
|
|
return pt;
|
|
|
|
}
|
|
|
|
|
|
|
|
static uint getLineSeparation() {
|
2010-10-02 01:05:16 +00:00
|
|
|
return FontMan.getFontByUsage(ConfParams.getCurrentFontUsageType())->getFontHeight() + 5;
|
2010-07-19 21:12:17 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void updateStats(const char *prefix, const char *info, uint numTests, uint testNum, Common::Point pt);
|
2010-07-24 16:05:19 +00:00
|
|
|
const Common::Array<Test *>& getTestList() { return _testsToExecute; }
|
2010-07-29 13:09:14 +00:00
|
|
|
int getNumTestsEnabled();
|
2010-07-19 21:12:17 +00:00
|
|
|
|
2010-06-02 13:56:04 +00:00
|
|
|
protected:
|
2010-07-14 19:44:51 +00:00
|
|
|
Common::Array<Test *> _testsToExecute; ///< List of tests to be executed
|
2010-06-06 14:06:51 +00:00
|
|
|
int _numTestsPassed; ///< Number of tests passed
|
2010-07-14 14:12:42 +00:00
|
|
|
int _numTestsExecuted; ///< Number of tests executed
|
2010-08-09 20:10:53 +00:00
|
|
|
int _numTestsSkipped;
|
2010-07-01 12:30:56 +00:00
|
|
|
bool _isTsEnabled;
|
2010-06-26 14:29:50 +00:00
|
|
|
|
2010-06-29 22:46:56 +00:00
|
|
|
private:
|
2011-06-06 22:49:58 +00:00
|
|
|
|
2010-06-29 22:46:56 +00:00
|
|
|
/**
|
2010-10-02 01:05:16 +00:00
|
|
|
* Used from the code to decide if the engine needs to exit
|
2010-07-19 21:12:17 +00:00
|
|
|
*/
|
2010-10-02 01:05:16 +00:00
|
|
|
uint _toQuit;
|
2010-06-02 13:56:04 +00:00
|
|
|
};
|
2010-06-01 18:06:31 +00:00
|
|
|
|
2010-07-14 19:44:51 +00:00
|
|
|
} // End of namespace Testbed
|
2010-06-01 18:06:31 +00:00
|
|
|
|
2010-07-14 19:44:51 +00:00
|
|
|
#endif // TESTBED_TESTSUITE_H
|