[PATCH vkd3d 1/9] tests: Introduce vkd3d_test_set_context().

Józef Kucia joseph.kucia at gmail.com
Tue Dec 11 08:47:57 CST 2018


From: Józef Kucia <jkucia at codeweavers.com>

Useful for table-based tests.

Signed-off-by: Józef Kucia <jkucia at codeweavers.com>
---
 include/private/vkd3d_test.h | 31 +++++++++++++++++++++++++------
 tests/d3d12.c                |  3 +++
 2 files changed, 28 insertions(+), 6 deletions(-)

diff --git a/include/private/vkd3d_test.h b/include/private/vkd3d_test.h
index a2649dd64f76..ccc5350a2acb 100644
--- a/include/private/vkd3d_test.h
+++ b/include/private/vkd3d_test.h
@@ -93,6 +93,8 @@ static struct
 
     unsigned int todo_level;
     bool todo_do_loop;
+
+    char context[1024];
 } vkd3d_test_state;
 
 static bool
@@ -116,13 +118,13 @@ vkd3d_test_check_ok(unsigned int line, bool result, const char *fmt, va_list arg
     {
         if (result)
         {
-            printf("%s:%d Todo succeeded: ", vkd3d_test_name, line);
+            printf("%s:%d%s: Todo succeeded: ", vkd3d_test_name, line, vkd3d_test_state.context);
             vprintf(fmt, args);
             InterlockedIncrement(&vkd3d_test_state.todo_success_count);
         }
         else
         {
-            printf("%s:%d: Todo: ", vkd3d_test_name, line);
+            printf("%s:%d%s: Todo: ", vkd3d_test_name, line, vkd3d_test_state.context);
             vprintf(fmt, args);
             InterlockedIncrement(&vkd3d_test_state.todo_count);
         }
@@ -130,12 +132,12 @@ vkd3d_test_check_ok(unsigned int line, bool result, const char *fmt, va_list arg
     else if (result)
     {
         if (vkd3d_test_state.debug_level > 1)
-            printf("%s:%d: Test succeeded.\n", vkd3d_test_name, line);
+            printf("%s:%d%s: Test succeeded.\n", vkd3d_test_name, line, vkd3d_test_state.context);
         InterlockedIncrement(&vkd3d_test_state.success_count);
     }
     else
     {
-        printf("%s:%d: Test failed: ", vkd3d_test_name, line);
+        printf("%s:%d%s: Test failed: ", vkd3d_test_name, line, vkd3d_test_state.context);
         vprintf(fmt, args);
         InterlockedIncrement(&vkd3d_test_state.failure_count);
     }
@@ -156,7 +158,7 @@ vkd3d_test_skip(unsigned int line, const char *fmt, ...)
 {
     va_list args;
     va_start(args, fmt);
-    printf("%s:%d: Test skipped: ", vkd3d_test_name, line);
+    printf("%s:%d%s: Test skipped: ", vkd3d_test_name, line, vkd3d_test_state.context);
     vprintf(fmt, args);
     va_end(args);
     InterlockedIncrement(&vkd3d_test_state.skip_count);
@@ -167,7 +169,7 @@ vkd3d_test_trace(unsigned int line, const char *fmt, ...)
 {
     va_list args;
     va_start(args, fmt);
-    printf("%s:%d: ", vkd3d_test_name, line);
+    printf("%s:%d%s: ", vkd3d_test_name, line, vkd3d_test_state.context);
     vprintf(fmt, args);
     va_end(args);
 }
@@ -304,6 +306,23 @@ static inline void vkd3d_test_end_todo(void)
     vkd3d_test_state.todo_level >>= 1;
 }
 
+static inline void vkd3d_test_set_context(const char *fmt, ...)
+{
+    va_list args;
+
+    if (!fmt)
+    {
+        vkd3d_test_state.context[0] = '\0';
+        return;
+    }
+
+    vkd3d_test_state.context[0] = ':';
+    va_start(args, fmt);
+    vsnprintf(&vkd3d_test_state.context[1], sizeof(vkd3d_test_state.context) - 1, fmt, args);
+    va_end(args);
+    vkd3d_test_state.context[sizeof(vkd3d_test_state.context) - 1] = '\0';
+}
+
 #define run_test(test_pfn) \
         vkd3d_run_test(#test_pfn, test_pfn)
 
diff --git a/tests/d3d12.c b/tests/d3d12.c
index 1598910718f4..03308639e4e1 100644
--- a/tests/d3d12.c
+++ b/tests/d3d12.c
@@ -18734,6 +18734,8 @@ static void test_instance_id(void)
 
     for (i = 0; i < ARRAY_SIZE(tests); ++i)
     {
+        vkd3d_test_set_context("Test %u", i);
+
         layout_desc[1].InstanceDataStepRate = tests[i].color_step_rate;
         input_layout.pInputElementDescs = layout_desc;
         input_layout.NumElements = ARRAY_SIZE(layout_desc);
@@ -18784,6 +18786,7 @@ static void test_instance_id(void)
         ID3D12PipelineState_Release(context.pipeline_state);
         context.pipeline_state = NULL;
     }
+    vkd3d_test_set_context(NULL);
 
     ID3D12CommandSignature_Release(command_signature);
     ID3D12Resource_Release(argument_buffer);
-- 
2.19.2




More information about the wine-devel mailing list