21#ifndef __WINE_WINE_TEST_H
22#define __WINE_WINE_TEST_H
31#pragma GCC diagnostic push
32#pragma GCC diagnostic ignored "-Wunused-function"
36#error config.h should not be used in Wine tests
38#ifdef __WINE_WINE_LIBRARY_H
39#error wine/library.h should not be used in Wine tests
41#ifdef __WINE_WINE_UNICODE_H
42#error wine/unicode.h should not be used in Wine tests
44#ifdef __WINE_WINE_DEBUG_H
45#error wine/debug.h should not be used in Wine tests
49# define __WINE_PRINTF_ATTR(fmt,args) __attribute__((format (printf,fmt,args)))
51# define __WINE_PRINTF_ATTR(fmt,args)
58#ifndef INVALID_FILE_ATTRIBUTES
59#define INVALID_FILE_ATTRIBUTES (~0u)
61#ifndef INVALID_SET_FILE_POINTER
62#define INVALID_SET_FILE_POINTER (~0u)
127#define START_TEST(name) \
128 static void func_##name(void); \
129 const struct test winetest_testlist[] = { { #name, func_##name }, { 0, 0 } }; \
130 static void func_##name(void)
132#define START_TEST(name) EXTERN_C void func_##name(void)
135#ifdef WINETEST_NO_LINE_NUMBERS
136# define subtest_(file, line) (winetest_set_location(file, 0), 0) ? (void)0 : winetest_subtest
137# define ignore_exceptions_(file, line) (winetest_set_location(file, 0), 0) ? (void)0 : winetest_ignore_exceptions
138# define ok_(file, line) (winetest_set_location(file, 0), 0) ? (void)0 : winetest_ok
139# define skip_(file, line) (winetest_set_location(file, 0), 0) ? (void)0 : winetest_skip
140# define win_skip_(file, line) (winetest_set_location(file, 0), 0) ? (void)0 : winetest_win_skip
141# define trace_(file, line) (winetest_set_location(file, 0), 0) ? (void)0 : winetest_trace
142# define wait_child_process_(file, line) (winetest_set_location(file, 0), 0) ? (void)0 : winetest_wait_child_process
144# define subtest_(file, line) (winetest_set_location(file, line), 0) ? (void)0 : winetest_subtest
145# define ignore_exceptions_(file, line) (winetest_set_location(file, line), 0) ? (void)0 : winetest_ignore_exceptions
146# define ok_(file, line) (winetest_set_location(file, line), 0) ? (void)0 : winetest_ok
147# define skip_(file, line) (winetest_set_location(file, line), 0) ? (void)0 : winetest_skip
148# define win_skip_(file, line) (winetest_set_location(file, line), 0) ? (void)0 : winetest_win_skip
149# define trace_(file, line) (winetest_set_location(file, line), 0) ? (void)0 : winetest_trace
150# define wait_child_process_(file, line) (winetest_set_location(file, line), 0) ? (void)0 : winetest_wait_child_process
153#define subtest subtest_(__FILE__, __LINE__)
154#define ignore_exceptions ignore_exceptions_(__FILE__, __LINE__)
155#define ok ok_(__FILE__, __LINE__)
156#define skip skip_(__FILE__, __LINE__)
157#define win_skip win_skip_(__FILE__, __LINE__)
158#define trace trace_(__FILE__, __LINE__)
159#define wait_child_process wait_child_process_(__FILE__, __LINE__)
161#define flaky_if(is_flaky) for (winetest_start_flaky(is_flaky); \
162 winetest_loop_flaky(); \
163 winetest_end_flaky())
164#define flaky flaky_if(TRUE)
165#define flaky_wine flaky_if(winetest_platform_is_wine)
166#define flaky_wine_if(is_flaky) flaky_if((is_flaky) && winetest_platform_is_wine)
168#define todo_if(is_todo) for (winetest_start_todo(is_todo); \
169 winetest_loop_todo(); \
172#define todo_ros todo_if(!strcmp(winetest_platform, "reactos"))
173#define todo_ros_if(is_todo) todo_if((is_todo) && !strcmp(winetest_platform, "reactos"))
175#define todo_wine todo_ros
176#define todo_wine_if todo_ros_if
178#define todo_wine todo_if(!strcmp(winetest_platform, "wine"))
179#define todo_wine_if(is_todo) todo_if((is_todo) && !strcmp(winetest_platform, "wine"))
183# define ARRAY_SIZE(x) (sizeof(x) / sizeof((x)[0]))
196#if defined(WINETEST_MSVC_IDE_FORMATTING)
205 data->current_file++;
221#if defined(WINETEST_MSVC_IDE_FORMATTING)
222# define __winetest_file_line_prefix "%s(%d)"
224# define __winetest_file_line_prefix "%s:%d"
270 for (
i = 0;
i <
data->context_count; ++
i)
289#ifndef USE_WINE_TODOS
298 static LONG line_counters[16384];
334 if (
data->todo_level)
340 if ((
data->nocount_level & 2) == 0)
352 if ((
data->nocount_level & 1) == 0)
363 if ((
data->nocount_level & 2) == 0)
373 if ((
data->nocount_level & 1) == 0)
440#
if !defined(USE_WINE_TODOS) || defined(USE_WIN_SKIP)
465 data->flaky_level = (
data->flaky_level << 1) | (is_flaky != 0);
466 data->flaky_do_loop = 1;
472 int do_flaky =
data->flaky_do_loop;
473 data->flaky_do_loop = 0;
480 data->flaky_level >>= 1;
493 data->todo_level = (
data->todo_level << 1) | (is_todo != 0);
494 data->todo_do_loop=1;
501 data->todo_do_loop=0;
508 data->todo_level >>= 1;
547 data->context[
data->context_count][
sizeof(
data->context[
data->context_count]) - 1] = 0;
549 ++
data->context_count;
556 if (
data->context_count)
557 --
data->context_count;
617static HANDLE winetest_mutex;
620static int winetest_argc;
621static char** winetest_argv;
623static const struct test *current_test;
635static DWORD tls_index;
654static void exit_process(
int code )
664 if (!winetest_mutex)
return;
693 *pargv = winetest_argv;
694 return winetest_argc;
702 fprintf(
stdout,
"%s: child process wait failed\n", current_test->name );
716 current_test->name, (
unsigned)
exit_code );
724static const struct test *find_test(
const char *
name )
744static void list_tests(
void)
755#pragma warning(disable:28182)
777 fprintf(
stdout,
"\n%s: %d tests executed (%d marked as todo, %d %s), %d skipped.\n",
806 if (
data->current_file)
807 printf(
"%s:%d: this is the last test seen before the exception\n",
808 data->current_file,
data->current_line );
810 printf(
"%04x:%s:%s unhandled exception %08x at %p\n",
835 winetest_argc =
argc;
836 winetest_argv =
argv;
864#ifdef NONAMELESSUNION
886#ifdef NONAMELESSSTRUCT
909#ifdef WINETEST_USE_DBGSTR_LONGLONG
919#if defined(__oaidl_h__) && defined(V_VT)
920extern const char *wine_dbgstr_variant(
const VARIANT *
var);
944#define ros_skip_flaky for (winetest_start_nocount(3); \
945 winetest_loop_nocount(); \
946 winetest_end_nocount())
948#define disable_success_count for (winetest_start_nocount(1); \
949 winetest_loop_nocount(); \
950 winetest_end_nocount())
952#define skip_2k3_crash if (_winver < 0x600) skip("Test skipped, because it crashes on win 2003\n"); else
953#define skip_2k3_fail if (_winver < 0x600) skip("Test skipped, because it fails on win 2003\n"); else
955#define ok_hex_(file, line, expression, result) \
957 int _value = (expression); \
958 int _result = (result); \
959 ok_(file, line)(_value == _result, "Wrong value for '%s', expected: " #result " (0x%x), got: 0x%x\n", \
960 #expression, _result, _value); \
962#define ok_hex(expression, result) ok_hex_(__FILE__, __LINE__, expression, result)
964#define ok_dec_(file, line, expression, result) \
966 int _value = (expression); \
967 int _result = (result); \
968 ok_(file, line)(_value == _result, "Wrong value for '%s', expected: " #result " (%d), got: %d\n", \
969 #expression, _result, _value); \
971#define ok_dec(expression, result) ok_dec_(__FILE__, __LINE__, expression, result)
973#define ok_ptr_(file, line, expression, result) \
975 const void *_value = (expression); \
976 const void *_result = (result); \
977 ok_(file, line)(_value == _result, "Wrong value for '%s', expected: " #result " (%p), got: %p\n", \
978 #expression, _result, _value); \
980#define ok_ptr(expression, result) ok_ptr_(__FILE__, __LINE__, expression, result)
982#define ok_size_t_(file, line, expression, result) \
984 size_t _value = (expression); \
985 size_t _result = (result); \
986 ok_(file, line)(_value == _result, "Wrong value for '%s', expected: " #result " (%Ix), got: %Ix\n", \
987 #expression, _result, _value); \
989#define ok_size_t(expression, result) ok_size_t_(__FILE__, __LINE__, expression, result)
991#define ok_char(expression, result) ok_hex(expression, result)
993#define ok_err_(file, line, error) \
994 ok_(file, line)(GetLastError() == (error), "Wrong last error. Expected " #error ", got 0x%lx\n", GetLastError())
995#define ok_err(error) ok_err_(__FILE__, __LINE__, error)
997#define ok_str_(file, line, x, y) \
998 ok_(file, line)(strcmp(x, y) == 0, "Wrong string. Expected '%s', got '%s'\n", y, x)
999#define ok_str(x, y) ok_str_(__FILE__, __LINE__, x, y)
1001#define ok_wstr_(file, line, x, y) \
1002 ok_(file, line)(wcscmp(x, y) == 0, "Wrong string. Expected '%S', got '%S'\n", y, x)
1003#define ok_wstr(x, y) ok_wstr_(__FILE__, __LINE__, x, y)
1005#define ok_long(expression, result) ok_hex(expression, result)
1006#define ok_int(expression, result) ok_dec(expression, result)
1007#define ok_int_(file, line, expression, result) ok_dec_(file, line, expression, result)
1008#define ok_ntstatus(status, expected) ok_hex(status, expected)
1009#define ok_hdl ok_ptr
1011#define is_reactos() \
1012 (*(unsigned*)((size_t)0x7FFE0FFC) == 0x8EAC705)
1015#define KUSER_SHARED_DATA_UMPTR 0x7FFE0000
1016#define GetMajorNTVersion() (*(ULONG*)(KUSER_SHARED_DATA_UMPTR + 0x026C))
1017#define GetMinorNTVersion() (*(ULONG*)(KUSER_SHARED_DATA_UMPTR + 0x0270))
1018#define GetNTVersion() ((GetMajorNTVersion() << 8) | GetMinorNTVersion())
1027void winetest_print(
const char*
msg, ...)
1049 data->todo_do_loop = 1;
1056 data->todo_do_loop = 0;
1063 data->nocount_level >>= 2;
1091 if (!
str)
return "(null)";
1111 case '\n': *
dst++ =
'\\'; *
dst++ =
'n';
break;
1112 case '\r': *
dst++ =
'\\'; *
dst++ =
'r';
break;
1113 case '\t': *
dst++ =
'\\'; *
dst++ =
't';
break;
1114 case '"': *
dst++ =
'\\'; *
dst++ =
'"';
break;
1115 case '\\': *
dst++ =
'\\'; *
dst++ =
'\\';
break;
1117 if (
c >=
' ' &&
c <= 126)
1142 static const char hex[16] = {
'0',
'1',
'2',
'3',
'4',
'5',
'6',
'7',
'8',
'9',
'a',
'b',
'c',
'd',
'e',
'f'};
1145 if (!
str)
return "(null)";
1153 if (
n == -1)
for (
n = 0;
str[
n];
n++) ;
1161 case '\n': *
dst++ =
'\\'; *
dst++ =
'n';
break;
1162 case '\r': *
dst++ =
'\\'; *
dst++ =
'r';
break;
1163 case '\t': *
dst++ =
'\\'; *
dst++ =
't';
break;
1164 case '"': *
dst++ =
'\\'; *
dst++ =
'"';
break;
1165 case '\\': *
dst++ =
'\\'; *
dst++ =
'\\';
break;
1167 if (
c <
' ' ||
c >= 127)
1170 *
dst++ =
hex[(
c >> 12) & 0x0f];
1171 *
dst++ =
hex[(
c >> 8) & 0x0f];
1172 *
dst++ =
hex[(
c >> 4) & 0x0f];
1196 if (!
guid)
return "(null)";
1198 sprintf(
res,
"{%08x-%04x-%04x-%02x%02x-%02x%02x%02x%02x%02x%02x}",
1209 if (!
point)
return "(null)";
1211#ifdef __ROS_LONG64__
1224 if (!
size)
return "(null)";
1226#ifdef __ROS_LONG64__
1239 if (!
rect)
return "(null)";
1241#ifdef __ROS_LONG64__
1250#ifdef WINETEST_USE_DBGSTR_LONGLONG
1257 sprintf(
res,
"%lx%08lx", (
unsigned long)(
ll >> 32), (
unsigned long)
ll );
1265#if defined(__oaidl_h__) && defined(V_VT)
1266const char *wine_dbgstr_variant(
const VARIANT *
var)
1268 static char buf[400];
1276 return "{VT_EMPTY}";
1302#pragma GCC diagnostic pop
#define InterlockedIncrement
static const char * wine_dbgstr_point(const POINT *ppt)
static const char * wine_dbgstr_size(const SIZE *psize)
static const char * wine_dbgstr_rect(const RECT *prc)
static INT do_loop(const PropSheetInfo *psInfo)
const char * wine_dbgstr_an(const char *str, int n)
#define GetProcAddress(x, y)
static __inline const char * debugstr_an(const char *s, int n)
static __inline const char * wine_dbgstr_longlong(ULONGLONG ll)
#define GetEnvironmentVariableA(x, y, z)
UINT WINAPI SetErrorMode(IN UINT uMode)
BOOL NTAPI IsBadStringPtrW(IN LPCWSTR lpsz, IN UINT_PTR ucchMax)
HMODULE WINAPI DECLSPEC_HOTPATCH GetModuleHandleA(LPCSTR lpModuleName)
BOOL WINAPI GetExitCodeProcess(IN HANDLE hProcess, IN LPDWORD lpExitCode)
VOID WINAPI ExitProcess(IN UINT uExitCode)
LPVOID WINAPI TlsGetValue(IN DWORD Index)
BOOL WINAPI TlsSetValue(IN DWORD Index, IN LPVOID Value)
ULONG WINAPI DECLSPEC_HOTPATCH GetTickCount(void)
DWORD WINAPI DECLSPEC_HOTPATCH TlsAlloc(void)
int WINAPIV fprintf(FILE *file, const char *format,...)
int CDECL vfprintf(FILE *file, const char *format, va_list valist)
int CDECL fflush(FILE *file)
int CDECL setvbuf(FILE *file, char *buf, int mode, size_t size)
_ACRTIMP int __cdecl atoi(const char *)
_ACRTIMP size_t __cdecl strlen(const char *)
_ACRTIMP int __cdecl strcmp(const char *, const char *)
_ACRTIMP int __cdecl strncmp(const char *, const char *, size_t)
_ACRTIMP char *__cdecl strrchr(const char *, int)
static const char * debugstr_variant(const VARIANT *var)
static LPSTR get_temp_buffer(void)
GLuint GLuint GLsizei count
GLint GLenum GLsizei GLsizei GLsizei GLint GLsizei const GLvoid * data
GLsizei const GLchar *const * strings
GLenum GLuint GLenum GLsizei const GLchar * buf
GLsizeiptr const GLvoid GLenum usage
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint i
#define EXCEPTION_EXECUTE_HANDLER
LONG winetest_get_successes(void)
void winetest_end_nocount(void)
void winetest_start_nocount(unsigned int flags)
int winetest_loop_nocount(void)
static int running_under_wine(void)
#define SEM_FAILCRITICALERRORS
#define SEM_NOGPFAULTERRORBOX
const struct test winetest_testlist[]
const char int int int static __inline const char * wine_dbgstr_a(const char *s)
static __inline const char * wine_dbgstr_guid(const GUID *id)
static const char winetest_color_dark_purple[]
static void winetest_end_todo(void)
void void winetest_trace(const char *msg,...) __WINE_PRINTF_ATTR(1
#define __winetest_file_line_prefix
const char * winetest_platform
LONG winetest_flaky_failures
static void winetest_start_todo(int is_todo)
static void winetest_subtest(const char *name)
static void winetest_print_location(const char *msg,...) __WINE_PRINTF_ATTR(1
static LONG winetest_get_failures(void)
static const char winetest_color_reset[]
static void winetest_push_context(const char *fmt,...) __WINE_PRINTF_ATTR(1
static void winetest_print_context(const char *msgtype)
void winetest_print_lock(void)
static int winetest_vok(int condition, const char *msg, va_list args)
static void winetest_pop_context(void)
LONG winetest_todo_failures
LONG winetest_muted_todo_successes
int winetest_vprintf(const char *msg, va_list args)
static void winetest_add_failures(LONG new_failures)
static int winetest_loop_flaky(void)
static const char winetest_color_blue[]
void winetest_skip(const char *msg,...) __WINE_PRINTF_ATTR(1
static const char winetest_color_green[]
static int winetest_printf(const char *msg,...) __WINE_PRINTF_ATTR(1
static const char * winetest_elapsed(char *buffer)
void winetest_ok(int condition, const char *msg,...) __WINE_PRINTF_ATTR(2
static LONG winetest_add_line(void)
static void winetest_start_flaky(int is_flaky)
static int winetest_loop_todo(void)
void static void winetest_win_skip(const char *msg,...) __WINE_PRINTF_ATTR(1
#define __WINE_PRINTF_ATTR(fmt, args)
LONG winetest_todo_successes
void winetest_print_unlock(void)
void void static void winetest_vskip(const char *msg, va_list args)
static const char winetest_color_dark_red[]
int winetest_get_mainargs(char ***pargv)
void winetest_wait_child_process(HANDLE process)
LONG winetest_muted_traces
int winetest_mute_threshold
int winetest_platform_is_wine
static const char winetest_color_bright_purple[]
LONG winetest_muted_skipped
static void winetest_ignore_exceptions(BOOL ignore)
static const char winetest_color_bright_red[]
int winetest_report_success
static void winetest_end_flaky(void)
static void winetest_set_location(const char *file, int line)
int winetest_report_flaky
static const char winetest_color_yellow[]
struct winetest_thread_data * winetest_get_thread_data(void)
int winetest_get_time(void)
static void release_temp_buffer(char *buffer, size_t size)
XML_HIDDEN void xmlParserErrors const char const xmlChar const xmlChar * str2
XML_HIDDEN void xmlParserErrors const char const xmlChar * str1
static char argv0[MAX_PATH]
PEXCEPTION_RECORD ExceptionRecord
unsigned int context_count
unsigned int nocount_level
const char * current_file
DWORD WINAPI WaitForSingleObject(IN HANDLE hHandle, IN DWORD dwMilliseconds)
BOOL WINAPI DECLSPEC_HOTPATCH ReleaseMutex(IN HANDLE hMutex)
HANDLE WINAPI DECLSPEC_HOTPATCH CreateMutexA(IN LPSECURITY_ATTRIBUTES lpMutexAttributes OPTIONAL, IN BOOL bInitialOwner, IN LPCSTR lpName OPTIONAL)
DWORD WINAPI GetLastError(void)
DWORD WINAPI GetCurrentProcessId(void)