Signed-off-by: Paul Gofman <pgofman(a)codeweavers.com>
---
dlls/ntoskrnl.exe/tests/driver.c | 140 +--------------------------
dlls/ntoskrnl.exe/tests/utils.h | 160 +++++++++++++++++++++++++++++++
2 files changed, 162 insertions(+), 138 deletions(-)
create mode 100644 dlls/ntoskrnl.exe/tests/utils.h
diff --git a/dlls/ntoskrnl.exe/tests/driver.c b/dlls/ntoskrnl.exe/tests/driver.c
index beac9c2c25e..fa8d7b20e3e 100644
--- a/dlls/ntoskrnl.exe/tests/driver.c
+++ b/dlls/ntoskrnl.exe/tests/driver.c
@@ -35,6 +35,8 @@
#include "driver.h"
+#include "utils.h"
+
static const WCHAR device_name[] = {'\\','D','e','v','i','c','e',
'\\','W','i','n','e','T','e','s','t','D','r','i','v','e','r',0};
static const WCHAR upper_name[] = {'\\','D','e','v','i','c','e',
@@ -45,17 +47,6 @@ static const WCHAR driver_link[] = {'\\','D','o','s','D','e','v','i','c','e','s'
static DRIVER_OBJECT *driver_obj;
static DEVICE_OBJECT *lower_device, *upper_device;
-static HANDLE okfile;
-static LONG successes;
-static LONG failures;
-static LONG skipped;
-static LONG todo_successes;
-static LONG todo_failures;
-static int todo_level, todo_do_loop;
-static int running_under_wine;
-static int winetest_debug;
-static int winetest_report_success;
-
static POBJECT_TYPE *pExEventObjectType, *pIoFileObjectType, *pPsThreadType, *pIoDriverObjectType;
static PEPROCESS *pPsInitialSystemProcess;
static void *create_caller_thread;
@@ -64,133 +55,6 @@ static PETHREAD create_irp_thread;
NTSTATUS WINAPI ZwQueryInformationProcess(HANDLE,PROCESSINFOCLASS,void*,ULONG,ULONG*);
-static void kvprintf(const char *format, __ms_va_list ap)
-{
- static char buffer[512];
- IO_STATUS_BLOCK io;
- int len = vsnprintf(buffer, sizeof(buffer), format, ap);
- ZwWriteFile(okfile, NULL, NULL, NULL, &io, buffer, len, NULL, NULL);
-}
-
-static void WINAPIV kprintf(const char *format, ...)
-{
- __ms_va_list valist;
-
- __ms_va_start(valist, format);
- kvprintf(format, valist);
- __ms_va_end(valist);
-}
-
-static void WINAPIV vok_(const char *file, int line, int condition, const char *msg, __ms_va_list args)
-{
- const char *current_file;
-
- if (!(current_file = drv_strrchr(file, '/')) &&
- !(current_file = drv_strrchr(file, '\\')))
- current_file = file;
- else
- current_file++;
-
- if (todo_level)
- {
- if (condition)
- {
- kprintf("%s:%d: Test succeeded inside todo block: ", current_file, line);
- kvprintf(msg, args);
- InterlockedIncrement(&todo_failures);
- }
- else
- {
- if (winetest_debug > 0)
- {
- kprintf("%s:%d: Test marked todo: ", current_file, line);
- kvprintf(msg, args);
- }
- InterlockedIncrement(&todo_successes);
- }
- }
- else
- {
- if (!condition)
- {
- kprintf("%s:%d: Test failed: ", current_file, line);
- kvprintf(msg, args);
- InterlockedIncrement(&failures);
- }
- else
- {
- if (winetest_report_success)
- kprintf("%s:%d: Test succeeded\n", current_file, line);
- InterlockedIncrement(&successes);
- }
- }
-}
-
-static void WINAPIV ok_(const char *file, int line, int condition, const char *msg, ...)
-{
- __ms_va_list args;
- __ms_va_start(args, msg);
- vok_(file, line, condition, msg, args);
- __ms_va_end(args);
-}
-
-static void vskip_(const char *file, int line, const char *msg, __ms_va_list args)
-{
- const char *current_file;
-
- if (!(current_file = drv_strrchr(file, '/')) &&
- !(current_file = drv_strrchr(file, '\\')))
- current_file = file;
- else
- current_file++;
-
- kprintf("%s:%d: Tests skipped: ", current_file, line);
- kvprintf(msg, args);
- skipped++;
-}
-
-static void WINAPIV win_skip_(const char *file, int line, const char *msg, ...)
-{
- __ms_va_list args;
- __ms_va_start(args, msg);
- if (running_under_wine)
- vok_(file, line, 0, msg, args);
- else
- vskip_(file, line, msg, args);
- __ms_va_end(args);
-}
-
-static void winetest_start_todo( int is_todo )
-{
- todo_level = (todo_level << 1) | (is_todo != 0);
- todo_do_loop=1;
-}
-
-static int winetest_loop_todo(void)
-{
- int do_loop=todo_do_loop;
- todo_do_loop=0;
- return do_loop;
-}
-
-static void winetest_end_todo(void)
-{
- todo_level >>= 1;
-}
-
-static int broken(int condition)
-{
- return !running_under_wine && condition;
-}
-
-#define ok(condition, ...) ok_(__FILE__, __LINE__, condition, __VA_ARGS__)
-#define todo_if(is_todo) for (winetest_start_todo(is_todo); \
- winetest_loop_todo(); \
- winetest_end_todo())
-#define todo_wine todo_if(running_under_wine)
-#define todo_wine_if(is_todo) todo_if((is_todo) && running_under_wine)
-#define win_skip(...) win_skip_(__FILE__, __LINE__, __VA_ARGS__)
-
static void *get_proc_address(const char *name)
{
UNICODE_STRING name_u;
diff --git a/dlls/ntoskrnl.exe/tests/utils.h b/dlls/ntoskrnl.exe/tests/utils.h
new file mode 100644
index 00000000000..da0b02ac006
--- /dev/null
+++ b/dlls/ntoskrnl.exe/tests/utils.h
@@ -0,0 +1,160 @@
+/*
+ * ntoskrnl.exe testing framework
+ *
+ * Copyright 2015 Sebastian Lackner
+ * Copyright 2015 Michael Müller
+ * Copyright 2015 Christian Costa
+ * Copyright 2020 Paul Gofman for Codeweavers
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library 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
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
+ */
+
+static HANDLE okfile;
+static LONG successes;
+static LONG failures;
+static LONG skipped;
+static LONG todo_successes;
+static LONG todo_failures;
+static int todo_level, todo_do_loop;
+static int running_under_wine;
+static int winetest_debug;
+static int winetest_report_success;
+
+static inline void kvprintf(const char *format, __ms_va_list ap)
+{
+ static char buffer[512];
+ IO_STATUS_BLOCK io;
+ int len = vsnprintf(buffer, sizeof(buffer), format, ap);
+ ZwWriteFile(okfile, NULL, NULL, NULL, &io, buffer, len, NULL, NULL);
+}
+
+static inline void WINAPIV kprintf(const char *format, ...)
+{
+ __ms_va_list valist;
+
+ __ms_va_start(valist, format);
+ kvprintf(format, valist);
+ __ms_va_end(valist);
+}
+
+static inline void WINAPIV vok_(const char *file, int line, int condition, const char *msg, __ms_va_list args)
+{
+ const char *current_file;
+
+ if (!(current_file = drv_strrchr(file, '/')) &&
+ !(current_file = drv_strrchr(file, '\\')))
+ current_file = file;
+ else
+ current_file++;
+
+ if (todo_level)
+ {
+ if (condition)
+ {
+ kprintf("%s:%d: Test succeeded inside todo block: ", current_file, line);
+ kvprintf(msg, args);
+ InterlockedIncrement(&todo_failures);
+ }
+ else
+ {
+ if (winetest_debug > 0)
+ {
+ kprintf("%s:%d: Test marked todo: ", current_file, line);
+ kvprintf(msg, args);
+ }
+ InterlockedIncrement(&todo_successes);
+ }
+ }
+ else
+ {
+ if (!condition)
+ {
+ kprintf("%s:%d: Test failed: ", current_file, line);
+ kvprintf(msg, args);
+ InterlockedIncrement(&failures);
+ }
+ else
+ {
+ if (winetest_report_success)
+ kprintf("%s:%d: Test succeeded\n", current_file, line);
+ InterlockedIncrement(&successes);
+ }
+ }
+}
+
+static inline void WINAPIV ok_(const char *file, int line, int condition, const char *msg, ...)
+{
+ __ms_va_list args;
+ __ms_va_start(args, msg);
+ vok_(file, line, condition, msg, args);
+ __ms_va_end(args);
+}
+
+static inline void vskip_(const char *file, int line, const char *msg, __ms_va_list args)
+{
+ const char *current_file;
+
+ if (!(current_file = drv_strrchr(file, '/')) &&
+ !(current_file = drv_strrchr(file, '\\')))
+ current_file = file;
+ else
+ current_file++;
+
+ kprintf("%s:%d: Tests skipped: ", current_file, line);
+ kvprintf(msg, args);
+ skipped++;
+}
+
+static inline void WINAPIV win_skip_(const char *file, int line, const char *msg, ...)
+{
+ __ms_va_list args;
+ __ms_va_start(args, msg);
+ if (running_under_wine)
+ vok_(file, line, 0, msg, args);
+ else
+ vskip_(file, line, msg, args);
+ __ms_va_end(args);
+}
+
+static inline void winetest_start_todo( int is_todo )
+{
+ todo_level = (todo_level << 1) | (is_todo != 0);
+ todo_do_loop=1;
+}
+
+static inline int winetest_loop_todo(void)
+{
+ int do_loop=todo_do_loop;
+ todo_do_loop=0;
+ return do_loop;
+}
+
+static inline void winetest_end_todo(void)
+{
+ todo_level >>= 1;
+}
+
+static inline int broken(int condition)
+{
+ return !running_under_wine && condition;
+}
+
+#define ok(condition, ...) ok_(__FILE__, __LINE__, condition, __VA_ARGS__)
+#define todo_if(is_todo) for (winetest_start_todo(is_todo); \
+ winetest_loop_todo(); \
+ winetest_end_todo())
+#define todo_wine todo_if(running_under_wine)
+#define todo_wine_if(is_todo) todo_if((is_todo) && running_under_wine)
+#define win_skip(...) win_skip_(__FILE__, __LINE__, __VA_ARGS__)
--
2.26.2