=?UTF-8?Q?J=C3=B3zef=20Kucia=20?=: d3d11/tests: Add test for creating deferred contexts.
Alexandre Julliard
julliard at winehq.org
Mon May 6 15:38:50 CDT 2019
Module: wine
Branch: master
Commit: 214c44e2dee7c13188a16d7bd3308491e8613bd5
URL: https://source.winehq.org/git/wine.git/?a=commit;h=214c44e2dee7c13188a16d7bd3308491e8613bd5
Author: Józef Kucia <jkucia at codeweavers.com>
Date: Mon May 6 14:03:24 2019 +0200
d3d11/tests: Add test for creating deferred contexts.
Signed-off-by: Józef Kucia <jkucia at codeweavers.com>
Signed-off-by: Henri Verbeet <hverbeet at codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard at winehq.org>
---
dlls/d3d11/tests/d3d11.c | 52 ++++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 52 insertions(+)
diff --git a/dlls/d3d11/tests/d3d11.c b/dlls/d3d11/tests/d3d11.c
index 2850d59..b1148cd 100644
--- a/dlls/d3d11/tests/d3d11.c
+++ b/dlls/d3d11/tests/d3d11.c
@@ -2185,6 +2185,57 @@ static void test_get_immediate_context(void)
ok(!refcount, "Device has %u references left.\n", refcount);
}
+static void test_create_deferred_context(void)
+{
+ ULONG refcount, expected_refcount;
+ struct device_desc device_desc;
+ ID3D11DeviceContext *context;
+ ID3D11Device *device;
+ HRESULT hr;
+
+ device_desc.feature_level = NULL;
+ device_desc.flags = D3D11_CREATE_DEVICE_SINGLETHREADED;
+ if (!(device = create_device(&device_desc)))
+ {
+ skip("Failed to create single-threaded device.\n");
+ return;
+ }
+
+ hr = ID3D11Device_CreateDeferredContext(device, 0, &context);
+ todo_wine ok(hr == DXGI_ERROR_INVALID_CALL, "Failed to create deferred context, hr %#x.\n", hr);
+
+ refcount = ID3D11Device_Release(device);
+ ok(!refcount, "Device has %u references left.\n", refcount);
+
+ if (!(device = create_device(NULL)))
+ {
+ skip("Failed to create device.\n");
+ return;
+ }
+
+ expected_refcount = get_refcount(device) + 1;
+ hr = ID3D11Device_CreateDeferredContext(device, 0, &context);
+ todo_wine ok(hr == S_OK, "Failed to create deferred context, hr %#x.\n", hr);
+ if (FAILED(hr))
+ goto done;
+ refcount = get_refcount(device);
+ ok(refcount == expected_refcount, "Got refcount %u, expected %u.\n", refcount, expected_refcount);
+ refcount = get_refcount(context);
+ ok(refcount == 1, "Got unexpected refcount %u.\n", refcount);
+
+ check_interface(context, &IID_IUnknown, TRUE, FALSE);
+ check_interface(context, &IID_ID3D11DeviceChild, TRUE, FALSE);
+ check_interface(context, &IID_ID3D11DeviceContext, TRUE, FALSE);
+ check_interface(context, &IID_ID3D11Multithread, FALSE, FALSE);
+
+ refcount = ID3D11DeviceContext_Release(context);
+ ok(!refcount, "Got unexpected refcount %u.\n", refcount);
+
+done:
+ refcount = ID3D11Device_Release(device);
+ ok(!refcount, "Device has %u references left.\n", refcount);
+}
+
static void test_create_texture1d(void)
{
ULONG refcount, expected_refcount;
@@ -29205,6 +29256,7 @@ START_TEST(d3d11)
queue_test(test_create_device);
queue_for_each_feature_level(test_device_interfaces);
queue_test(test_get_immediate_context);
+ queue_test(test_create_deferred_context);
queue_test(test_create_texture1d);
queue_test(test_texture1d_interfaces);
queue_test(test_create_texture2d);
More information about the wine-cvs
mailing list