Add trace function (same as in the perl framework).

Add support for todo tests.
Make it possible to specify a printf-style message in ok.
Include windef.h in test.h for compiling tests on Windows.
This commit is contained in:
Francois Gouget 2002-03-22 00:58:00 +00:00 committed by Alexandre Julliard
parent d677edf9e4
commit 58ed1f173d
2 changed files with 97 additions and 7 deletions

View File

@ -21,16 +21,32 @@
#ifndef __WINE_TEST_H #ifndef __WINE_TEST_H
#define __WINE_TEST_H #define __WINE_TEST_H
#include <stdarg.h>
#include "windef.h"
/* debug level */ /* debug level */
extern int winetest_debug; extern int winetest_debug;
/* current platform */ /* current platform */
extern const char *winetest_platform; extern const char *winetest_platform;
extern void winetest_ok( int condition, const char *msg, const char *file, int line ); typedef int (*winetest_ok_funcptr)( int condition, const char *msg, ...);
typedef void (*winetest_trace_funcptr)( const char *msg, ...);
extern winetest_ok_funcptr winetest_set_ok_location( const char* file, int line );
extern winetest_trace_funcptr winetest_set_trace_location( const char* file, int line );
extern void winetest_start_todo( const char* platform );
extern int winetest_loop_todo(void);
extern void winetest_end_todo( const char* platform );
#define START_TEST(name) void func_##name(void) #define START_TEST(name) void func_##name(void)
#define ok(test,msg) winetest_ok( (test), (msg), __FILE__, __LINE__ ) #define ok (*winetest_set_ok_location(__FILE__, __LINE__))
#define trace (*winetest_set_trace_location(__FILE__, __LINE__))
#define todo(platform) for (winetest_start_todo(platform); \
winetest_loop_todo(); \
winetest_end_todo(platform))
#define todo_wine todo("wine")
#endif /* __WINE_TEST_H */ #endif /* __WINE_TEST_H */

View File

@ -23,6 +23,8 @@
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#include "wine/test.h"
/* debug level */ /* debug level */
int winetest_debug = 1; int winetest_debug = 1;
@ -37,12 +39,18 @@ struct test
extern const struct test winetest_testlist[]; extern const struct test winetest_testlist[];
static const struct test *current_test; /* test currently being run */ static const struct test *current_test; /* test currently being run */
/* FIXME: Access to all the following variables must be protected in a
* multithread test. Either via thread local storage or via critical sections
*/
static const char* current_file; /* file of current check */
static int current_line; /* line of current check */
static int successes; /* number of successful tests */ static int successes; /* number of successful tests */
static int failures; /* number of failures */ static int failures; /* number of failures */
static int todo_successes; /* number of successful tests inside todo block */ static int todo_successes; /* number of successful tests inside todo block */
static int todo_failures; /* number of failures inside todo block */ static int todo_failures; /* number of failures inside todo block */
static int todo_level; /* current todo nesting level */ static int todo_level; /* current todo nesting level */
static int todo_do_loop;
/* /*
* Checks condition. * Checks condition.
@ -51,17 +59,29 @@ static int todo_level; /* current todo nesting level */
* - msg test description; * - msg test description;
* - file - test application source code file name of the check * - file - test application source code file name of the check
* - line - test application source code file line number of the check * - line - test application source code file line number of the check
* Return:
* 0 if condition does not have the expected value, 1 otherwise
*/ */
void winetest_ok( int condition, const char *msg, const char *file, int line ) int winetest_ok( int condition, const char *msg, ... )
{ {
va_list valist;
if (todo_level) if (todo_level)
{ {
if (condition) if (condition)
{ {
fprintf( stderr, "%s:%d: Test succeeded inside todo block", file, line ); fprintf( stderr, "%s:%d: Test succeeded inside todo block",
if (msg && msg[0]) fprintf( stderr, ": %s", msg ); current_file, current_line );
if (msg && msg[0])
{
va_start(valist, msg);
fprintf(stderr,": ");
vfprintf(stderr, msg, valist);
va_end(valist);
}
fputc( '\n', stderr ); fputc( '\n', stderr );
todo_failures++; todo_failures++;
return 0;
} }
else todo_successes++; else todo_successes++;
} }
@ -69,15 +89,69 @@ void winetest_ok( int condition, const char *msg, const char *file, int line )
{ {
if (!condition) if (!condition)
{ {
fprintf( stderr, "%s:%d: Test failed", file, line ); fprintf( stderr, "%s:%d: Test failed",
if (msg && msg[0]) fprintf( stderr, ": %s", msg ); current_file, current_line );
if (msg && msg[0])
{
va_start(valist, msg);
fprintf( stderr,": ");
vfprintf(stderr, msg, valist);
va_end(valist);
}
fputc( '\n', stderr ); fputc( '\n', stderr );
failures++; failures++;
return 0;
} }
else successes++; else successes++;
} }
return 1;
} }
winetest_ok_funcptr winetest_set_ok_location( const char* file, int line )
{
current_file=file;
current_line=line;
return &winetest_ok;
}
void winetest_trace( const char *msg, ... )
{
va_list valist;
if (winetest_debug > 0)
{
va_start(valist, msg);
vfprintf(stderr, msg, valist);
va_end(valist);
}
}
winetest_trace_funcptr winetest_set_trace_location( const char* file, int line )
{
current_file=file;
current_line=line;
return &winetest_trace;
}
void winetest_start_todo( const char* platform )
{
if (strcmp(winetest_platform,platform)==0)
todo_level++;
todo_do_loop=1;
}
int winetest_loop_todo(void)
{
int do_loop=todo_do_loop;
todo_do_loop=0;
return do_loop;
}
void winetest_end_todo( const char* platform )
{
if (strcmp(winetest_platform,platform)==0)
todo_level--;
}
/* Find a test by name */ /* Find a test by name */
static const struct test *find_test( const char *name ) static const struct test *find_test( const char *name )