mirror of
https://github.com/minetest/irrlicht.git
synced 2025-01-14 20:00:28 +01:00
111 lines
4.5 KiB
C
111 lines
4.5 KiB
C
|
|
||
|
#ifndef _TEST_UTILS_H_
|
||
|
#define _TEST_UTILS_H_ 1
|
||
|
|
||
|
#include "irrlicht.h"
|
||
|
#include <assert.h>
|
||
|
|
||
|
// Small hack. Some newer X11 systems can't handle switching drivers too fast (causing BadWindow errors in X_ChangeWindowAttributes).
|
||
|
// Could be they don't like when Windows with different Visuals are created very quickly (it always happened after creating a new Window with different Visual to previous one).
|
||
|
// timeMs value set by try&error
|
||
|
#ifdef _IRR_POSIX_API_
|
||
|
#include <time.h>
|
||
|
#define SLOW_SWITCH \
|
||
|
do { \
|
||
|
struct timespec ts; \
|
||
|
const int timeMs = 250; \
|
||
|
ts.tv_sec = (time_t) (timeMs / 1000); \
|
||
|
ts.tv_nsec = (long) (timeMs % 1000) * 1000000; \
|
||
|
nanosleep(&ts, NULL);\
|
||
|
} while (false)
|
||
|
#else
|
||
|
#define SLOW_SWITCH
|
||
|
#endif
|
||
|
|
||
|
#define TestWithAllDrivers(X) \
|
||
|
logTestString("Running test " #X "\n"); \
|
||
|
for (u32 i=1; i<video::EDT_COUNT; ++i) \
|
||
|
if (video::E_DRIVER_TYPE(i) != video::DEPRECATED_EDT_DIRECT3D8_NO_LONGER_EXISTS && irr::IrrlichtDevice::isDriverSupported((irr::video::E_DRIVER_TYPE)i)) \
|
||
|
{\
|
||
|
SLOW_SWITCH; \
|
||
|
result &= X(video::E_DRIVER_TYPE(i));\
|
||
|
}
|
||
|
|
||
|
#define TestWithAllHWDrivers(X) \
|
||
|
SLOW_SWITCH; \
|
||
|
logTestString("Running test " #X "\n"); \
|
||
|
for (u32 i=video::EDT_DIRECT3D9; i<video::EDT_COUNT; ++i) \
|
||
|
if (irr::IrrlichtDevice::isDriverSupported((irr::video::E_DRIVER_TYPE)i)) \
|
||
|
{\
|
||
|
SLOW_SWITCH; \
|
||
|
result &= X(video::E_DRIVER_TYPE(i));\
|
||
|
}
|
||
|
|
||
|
// replacement for assert which does log the lines instead
|
||
|
#define assert_log(X) \
|
||
|
do { \
|
||
|
if ( !(X) ) \
|
||
|
{ \
|
||
|
logTestString("ASSERT in %s:%d: %s\n", __FILE__, __LINE__, #X); \
|
||
|
} \
|
||
|
} while (false)
|
||
|
|
||
|
//! Compare two files
|
||
|
/** \param fileName1 The first file for comparison.
|
||
|
\param fileName2 The second file for comparison.
|
||
|
\return true if the files are identical, false on any error or difference. */
|
||
|
extern bool binaryCompareFiles(const char * fileName1, const char * fileName2);
|
||
|
|
||
|
//! Compare two xml-files (which can have different types of text-encoding)
|
||
|
/** \param fs Filesystem which should be used.
|
||
|
\param fileName1 The first file for comparison.
|
||
|
\param fileName2 The second file for comparison.
|
||
|
\return true if the files are identical, false on any error or difference. */
|
||
|
extern bool xmlCompareFiles(irr::io::IFileSystem * fs, const char * fileName1, const char * fileName2);
|
||
|
|
||
|
//! Compare two images, returning the degree to which they match.
|
||
|
/** \param driver The Irrlicht video driver.
|
||
|
\param fileName1 The first image to compare.
|
||
|
\param fileName2 The second image to compare.
|
||
|
\return The match, from 0.f to 100.f */
|
||
|
extern float fuzzyCompareImages(irr::video::IVideoDriver * driver,
|
||
|
const char * fileName1, const char * fileName2);
|
||
|
|
||
|
//! Take a screenshot and compare it against a reference screenshot in the tests/media subdirectory
|
||
|
/** \param driver The Irrlicht video driver.
|
||
|
\param fileName The unique filename suffix that will be appended to the name of the video driver.
|
||
|
\param requiredMatch The degree to which the screenshot needs to match the reference image
|
||
|
in order to be considered a match.
|
||
|
\return true if the screenshot was taken and is identical to the reference image of the same name
|
||
|
in the tests/media directory, false on any error or difference. */
|
||
|
extern bool takeScreenshotAndCompareAgainstReference(irr::video::IVideoDriver * driver,
|
||
|
const char * fileName,
|
||
|
irr::f32 requiredMatch = 99.f);
|
||
|
|
||
|
//! Stabilize the screen background eg. eliminate problems like an aero transparency effects etc.
|
||
|
/** \param driver The Irrlicht video driver.
|
||
|
\return true if required color is the same as a window background color. */
|
||
|
extern void stabilizeScreenBackground(irr::video::IVideoDriver * driver,
|
||
|
irr::video::SColor color = irr::video::SColor(255, 255, 255, 255));
|
||
|
|
||
|
|
||
|
//! Opens a test log file, deleting any existing contents.
|
||
|
/** \param startNewLog true to create a new log file, false to append to an
|
||
|
existing one.
|
||
|
\param filename The filename to open
|
||
|
\return true if the test log file was opened, false on error. */
|
||
|
extern bool openTestLog(bool startNewLog, const char * filename = "tests.log");
|
||
|
|
||
|
//! Close the test log file opened with openTestLog()
|
||
|
extern void closeTestLog();
|
||
|
|
||
|
//! Log a string to the console and the test log file created by openTestLog().
|
||
|
/** \param format The format string
|
||
|
\... optional parameters */
|
||
|
extern void logTestString(const char * format, ...);
|
||
|
|
||
|
//! Return a drivername for the driver which is useable in filenames
|
||
|
extern irr::core::stringc shortDriverName(irr::video::IVideoDriver * driver);
|
||
|
|
||
|
#endif // _TEST_UTILS_H_
|