=?UTF-8?Q?Stefan=20D=C3=B6singer=20?=: d3d8/tests: Show that a failing SetPrivateData call does not clear the old contents.
Alexandre Julliard
julliard at winehq.org
Tue Mar 11 14:45:41 CDT 2014
Module: wine
Branch: master
Commit: b71c4f000b4d7356c0118b981492b5ba241ba013
URL: http://source.winehq.org/git/wine.git/?a=commit;h=b71c4f000b4d7356c0118b981492b5ba241ba013
Author: Stefan Dösinger <stefan at codeweavers.com>
Date: Mon Mar 10 23:43:10 2014 +0100
d3d8/tests: Show that a failing SetPrivateData call does not clear the old contents.
---
dlls/d3d8/tests/device.c | 14 ++++++++++++++
1 file changed, 14 insertions(+)
diff --git a/dlls/d3d8/tests/device.c b/dlls/d3d8/tests/device.c
index fa370b0..2bac6fd 100644
--- a/dlls/d3d8/tests/device.c
+++ b/dlls/d3d8/tests/device.c
@@ -3915,6 +3915,20 @@ static void test_private_data(void)
device, sizeof(IUnknown *) * 2, D3DSPD_IUNKNOWN);
ok(hr == D3DERR_INVALIDCALL, "Got unexpected hr %#x.\n", hr);
+ /* A failing SetPrivateData call does not clear the old data with the same tag. */
+ hr = IDirect3DSurface8_SetPrivateData(surface, &IID_IDirect3DVertexBuffer8, device,
+ sizeof(device), D3DSPD_IUNKNOWN);
+ ok(SUCCEEDED(hr), "Failed to set private data, hr %#x.\n", hr);
+ hr = IDirect3DSurface8_SetPrivateData(surface, &IID_IDirect3DVertexBuffer8, device,
+ sizeof(device) * 2, D3DSPD_IUNKNOWN);
+ ok(hr == D3DERR_INVALIDCALL, "Got unexpected hr %#x.\n", hr);
+ size = sizeof(ptr);
+ hr = IDirect3DSurface8_GetPrivateData(surface, &IID_IDirect3DVertexBuffer8, &ptr, &size);
+ ok(SUCCEEDED(hr), "Failed to get private data, hr %#x.\n", hr);
+ IUnknown_Release(ptr);
+ hr = IDirect3DSurface8_FreePrivateData(surface, &IID_IDirect3DVertexBuffer8);
+ ok(SUCCEEDED(hr), "Failed to free private data, hr %#x.\n", hr);
+
refcount = get_refcount((IUnknown *)device);
hr = IDirect3DSurface8_SetPrivateData(surface, &IID_IDirect3DSurface8 /* Abuse this tag */,
device, sizeof(IUnknown *), D3DSPD_IUNKNOWN);
More information about the wine-cvs
mailing list