2019-11-23 20:27:39 +08:00
|
|
|
/****************************************************************************
|
|
|
|
Copyright (c) 2013-2016 Chukong Technologies Inc.
|
|
|
|
Copyright (c) 2017-2018 Xiamen Yaji Software Co., Ltd.
|
|
|
|
|
2024-06-10 02:25:43 +08:00
|
|
|
https://axmol.dev/
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
of this software and associated documentation files (the "Software"), to deal
|
|
|
|
in the Software without restriction, including without limitation the rights
|
|
|
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
copies of the Software, and to permit persons to whom the Software is
|
|
|
|
furnished to do so, subject to the following conditions:
|
|
|
|
|
|
|
|
The above copyright notice and this permission notice shall be included in
|
|
|
|
all copies or substantial portions of the Software.
|
|
|
|
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
THE SOFTWARE.
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#ifndef _CPPTESTS_BASETEST_H__
|
|
|
|
#define _CPPTESTS_BASETEST_H__
|
|
|
|
|
2022-10-12 00:15:09 +08:00
|
|
|
#include "axmol.h"
|
2023-03-14 07:56:07 +08:00
|
|
|
#include "extensions/axmol-ext.h"
|
2023-06-11 13:08:08 +08:00
|
|
|
#include "GUI/ControlExtension/ControlExtensions.h"
|
|
|
|
#include "GUI/ScrollView/ScrollView.h"
|
|
|
|
#include "GUI/ScrollView/TableView.h"
|
2019-11-23 20:27:39 +08:00
|
|
|
#include "VisibleRect.h"
|
|
|
|
|
|
|
|
class TestSuite;
|
|
|
|
|
2023-02-23 09:50:36 +08:00
|
|
|
extern ax::Size g_resourceSize;
|
|
|
|
extern ax::Size g_designSize;
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/**
|
|
|
|
* Each test case should inherit from TestCase, and add to a TestSuite object.
|
|
|
|
*/
|
2022-10-18 19:17:36 +08:00
|
|
|
class TestCase : public ax::Scene
|
2019-11-23 20:27:39 +08:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
/** TestCase test type.*/
|
|
|
|
enum class Type
|
|
|
|
{
|
|
|
|
/** For testing whether test case not crash.*/
|
|
|
|
ROBUSTNESS,
|
|
|
|
/**
|
2021-12-31 12:12:40 +08:00
|
|
|
* For check the correctness of regular test cases.
|
2019-11-23 20:27:39 +08:00
|
|
|
* A test case passes only if the actual output equal to the expected output.
|
|
|
|
*/
|
|
|
|
UNIT,
|
|
|
|
/** @warning The test type is not achieved.*/
|
|
|
|
GRAPHICAL_STATIC,
|
|
|
|
/** @note It's mean the test case need test manually.*/
|
|
|
|
MANUAL
|
|
|
|
};
|
|
|
|
TestCase();
|
|
|
|
~TestCase();
|
|
|
|
|
|
|
|
virtual std::string title() const { return ""; }
|
|
|
|
virtual std::string subtitle() const { return ""; }
|
|
|
|
|
|
|
|
/** Returns the test type, the default type is Type::ROBUSTNESS.*/
|
|
|
|
virtual Type getTestType() const;
|
|
|
|
/** Returns the time the test case needs.*/
|
|
|
|
virtual float getDuration() const;
|
|
|
|
|
|
|
|
/** Returns the expected output.*/
|
|
|
|
virtual std::string getExpectedOutput() const { return ""; }
|
|
|
|
/** Returns the actual output.*/
|
|
|
|
virtual std::string getActualOutput() const { return ""; }
|
|
|
|
|
|
|
|
/** Callback functions.*/
|
2024-05-03 22:15:08 +08:00
|
|
|
virtual void restartTestCallback(ax::Object* sender);
|
|
|
|
virtual void nextTestCallback(ax::Object* sender);
|
|
|
|
virtual void priorTestCallback(ax::Object* sender);
|
|
|
|
virtual void onBackCallback(ax::Object* sender);
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* You should NEVER call this method, unless you know what you are doing.
|
|
|
|
*/
|
|
|
|
void setTestSuite(TestSuite* testSuite);
|
|
|
|
TestSuite* getTestSuite() const { return _testSuite; }
|
|
|
|
|
|
|
|
/** Returns the run time of test case.*/
|
|
|
|
float getRunTime() const { return _runTime; }
|
|
|
|
|
|
|
|
/**
|
|
|
|
* You should NEVER call this method, unless you know what you are doing.
|
|
|
|
*/
|
2021-12-31 12:12:40 +08:00
|
|
|
void setTestCaseName(std::string_view name) { _testCaseName = name; }
|
2019-11-23 20:27:39 +08:00
|
|
|
std::string getTestCaseName() const { return _testCaseName; }
|
|
|
|
|
2022-10-18 19:17:36 +08:00
|
|
|
const ax::Label* getSubtitleLable() const { return _subtitleLabel; }
|
|
|
|
const ax::MenuItemImage* getRestartTestItem() const { return _restartTestItem; }
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
virtual void onEnter() override;
|
2023-09-12 01:06:28 +08:00
|
|
|
virtual void onExit() override;
|
2022-03-18 21:46:07 +08:00
|
|
|
virtual bool init() override;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
protected:
|
2022-10-18 19:17:36 +08:00
|
|
|
ax::MenuItemImage* _priorTestItem;
|
|
|
|
ax::MenuItemImage* _restartTestItem;
|
|
|
|
ax::MenuItemImage* _nextTestItem;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2022-10-18 19:17:36 +08:00
|
|
|
ax::Label* _titleLabel;
|
|
|
|
ax::Label* _subtitleLabel;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
private:
|
|
|
|
TestSuite* _testSuite;
|
|
|
|
float _runTime;
|
|
|
|
std::string _testCaseName;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A TestBase object stores the following information about a test:
|
|
|
|
* - A pointer to the parent test(TestList or TestSuite).
|
|
|
|
* - Array of children test names.
|
|
|
|
* - A flag to indicate whether the test is a TestList object.
|
|
|
|
*
|
|
|
|
* @note You should not inherit from TestBase directly.
|
|
|
|
*/
|
2024-05-03 22:15:08 +08:00
|
|
|
class TestBase : public ax::Object
|
2019-11-23 20:27:39 +08:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
virtual ~TestBase();
|
|
|
|
|
|
|
|
/** Backs up one level. */
|
|
|
|
void backsUpOneLevel();
|
|
|
|
|
|
|
|
virtual void runThisTest() {}
|
|
|
|
|
|
|
|
bool isTestList() { return _isTestList; }
|
|
|
|
|
|
|
|
ssize_t getChildTestCount() { return _childTestNames.size(); }
|
|
|
|
|
|
|
|
/**
|
2021-12-31 12:12:40 +08:00
|
|
|
* You should NEVER call this method.
|
|
|
|
*/
|
2019-11-23 20:27:39 +08:00
|
|
|
void setTestParent(TestBase* parent) { _parentTest = parent; }
|
|
|
|
TestBase* getTestParent() { return _parentTest; }
|
|
|
|
|
2021-12-31 12:12:40 +08:00
|
|
|
void setTestName(std::string_view testName) { _testName = testName; }
|
2019-11-23 20:27:39 +08:00
|
|
|
std::string getTestName() const { return _testName; }
|
2021-12-31 12:12:40 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
protected:
|
|
|
|
TestBase();
|
|
|
|
|
|
|
|
std::string _testName;
|
|
|
|
TestBase* _parentTest;
|
|
|
|
bool _isTestList;
|
|
|
|
std::vector<std::string> _childTestNames;
|
|
|
|
};
|
|
|
|
|
|
|
|
class TestController;
|
|
|
|
|
|
|
|
/**
|
2021-12-31 12:12:40 +08:00
|
|
|
* TestSuite correspond to a group of test cases.
|
|
|
|
* @note Each test case should add to a TestSuite object.
|
|
|
|
*/
|
2019-11-23 20:27:39 +08:00
|
|
|
class TestSuite : public TestBase
|
|
|
|
{
|
|
|
|
public:
|
2022-10-18 19:17:36 +08:00
|
|
|
void addTestCase(std::string_view testName, std::function<ax::Scene*()> callback);
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
virtual void restartCurrTest();
|
|
|
|
virtual void enterNextTest();
|
|
|
|
virtual void enterPreviousTest();
|
|
|
|
|
|
|
|
int getCurrTestIndex() { return _currTestIndex; }
|
|
|
|
virtual void runThisTest() override;
|
|
|
|
|
|
|
|
private:
|
2022-10-18 19:17:36 +08:00
|
|
|
std::vector<std::function<ax::Scene*()>> _testCallbacks;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
int _currTestIndex;
|
|
|
|
friend class TestController;
|
|
|
|
};
|
|
|
|
|
2021-05-05 19:49:30 +08:00
|
|
|
class TestCustomTableView;
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/**
|
|
|
|
* An instance of TestList is a means for displaying hierarchical lists of TestSuite.
|
|
|
|
*/
|
2021-12-31 12:12:40 +08:00
|
|
|
class TestList : public TestBase,
|
2022-10-18 19:17:36 +08:00
|
|
|
public ax::extension::TableViewDataSource,
|
|
|
|
public ax::extension::TableViewDelegate
|
2019-11-23 20:27:39 +08:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
TestList();
|
2021-05-05 19:49:30 +08:00
|
|
|
~TestList();
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2021-12-31 12:12:40 +08:00
|
|
|
void addTest(std::string_view testName, std::function<TestBase*()> callback);
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
virtual void runThisTest() override;
|
|
|
|
|
2022-10-18 19:17:36 +08:00
|
|
|
virtual void tableCellTouched(ax::extension::TableView* table,
|
|
|
|
ax::extension::TableViewCell* cell) override;
|
|
|
|
virtual ax::extension::TableViewCell* tableCellAtIndex(ax::extension::TableView* table,
|
2021-12-31 12:12:40 +08:00
|
|
|
ssize_t idx) override;
|
2022-10-18 19:17:36 +08:00
|
|
|
virtual ax::Size tableCellSizeForIndex(ax::extension::TableView* table, ssize_t idx) override;
|
|
|
|
virtual ssize_t numberOfCellsInTableView(ax::extension::TableView* table) override;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2022-10-18 19:17:36 +08:00
|
|
|
virtual void scrollViewDidScroll(ax::extension::ScrollView* view) override {}
|
|
|
|
virtual void scrollViewDidZoom(ax::extension::ScrollView* view) override {}
|
2021-12-28 21:27:32 +08:00
|
|
|
|
2021-12-31 11:00:35 +08:00
|
|
|
void deatchTableView();
|
2021-12-31 12:12:40 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
private:
|
|
|
|
std::vector<std::function<TestBase*()>> _testCallbacks;
|
|
|
|
bool _cellTouchEnabled;
|
|
|
|
bool _shouldRestoreTableOffset;
|
2022-10-18 19:17:36 +08:00
|
|
|
ax::Vec2 _tableOffset;
|
2019-11-23 20:27:39 +08:00
|
|
|
friend class TestController;
|
2021-05-05 19:49:30 +08:00
|
|
|
TestCustomTableView* _tableView{};
|
2019-11-23 20:27:39 +08:00
|
|
|
};
|
|
|
|
|
2021-12-31 12:12:40 +08:00
|
|
|
#define ADD_TEST(__className__) addTest(#__className__, []() { return new __className__; });
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2021-12-31 12:12:40 +08:00
|
|
|
#define ADD_TEST_CASE(__className__) addTestCase(#__className__, []() { return __className__::create(); });
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2021-12-31 12:12:40 +08:00
|
|
|
#define DEFINE_TEST_LIST(__className__) \
|
|
|
|
class __className__ : public TestList \
|
|
|
|
{ \
|
|
|
|
public: \
|
|
|
|
__className__(); \
|
|
|
|
}
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2021-12-31 12:12:40 +08:00
|
|
|
#define DEFINE_TEST_SUITE(__className__) \
|
|
|
|
class __className__ : public TestSuite \
|
|
|
|
{ \
|
|
|
|
public: \
|
|
|
|
__className__(); \
|
|
|
|
}
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* BaseTest is retained for compatibility with older versions.
|
2021-12-31 12:12:40 +08:00
|
|
|
* @warning It should soon be removed.
|
2019-11-23 20:27:39 +08:00
|
|
|
*/
|
2022-10-18 19:17:36 +08:00
|
|
|
class BaseTest : public ax::Layer
|
2019-11-23 20:27:39 +08:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
virtual std::string title() const { return ""; }
|
2021-12-31 12:12:40 +08:00
|
|
|
virtual std::string subtitle() const { return ""; }
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2024-05-03 22:15:08 +08:00
|
|
|
virtual void restartCallback(ax::Object* sender) {}
|
|
|
|
virtual void nextCallback(ax::Object* sender) {}
|
|
|
|
virtual void backCallback(ax::Object* sender) {}
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2021-12-31 12:12:40 +08:00
|
|
|
virtual void onEnter() override {}
|
|
|
|
virtual void onExit() override {}
|
2019-11-23 20:27:39 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* defined(_CPPTESTS_BASETEST_H__) */
|