[PATCH 2/2] d3drm/tests: Add tests for IDirect3DRMObject::Add/DeleteDestroyCallback (v2).
Aaryaman Vasishta
jem456.vasishta at gmail.com
Sun Apr 3 14:42:50 CDT 2016
v2: Fixed commit message.
Signed-off-by: Aaryaman Vasishta <jem456.vasishta at gmail.com>
---
dlls/d3drm/tests/d3drm.c | 203 ++++++++++++++++++-----------------------------
1 file changed, 79 insertions(+), 124 deletions(-)
diff --git a/dlls/d3drm/tests/d3drm.c b/dlls/d3drm/tests/d3drm.c
index 1abfed3..1f197b8 100644
--- a/dlls/d3drm/tests/d3drm.c
+++ b/dlls/d3drm/tests/d3drm.c
@@ -1219,6 +1219,7 @@ static void test_Frame(void)
struct destroy_context
{
IDirect3DRMObject *obj;
+ unsigned int test_idx;
int called;
};
@@ -1238,6 +1239,81 @@ static void CDECL destroy_callback1(IDirect3DRMObject *obj, void *arg)
ctxt->called++;
}
+static void test_destroy_callback(unsigned int test_idx, REFCLSID clsid, REFIID iid)
+{
+ struct destroy_context context;
+ IDirect3DRMObject *obj;
+ IUnknown *unknown;
+ IDirect3DRM *d3drm;
+ HRESULT hr;
+
+ hr = Direct3DRMCreate(&d3drm);
+ ok(SUCCEEDED(hr), "Test %u: Cannot get IDirect3DRM interface (hr = %x).\n", test_idx, hr);
+
+ hr = IDirect3DRM_CreateObject(d3drm, clsid, NULL, iid, (void **)&unknown);
+ ok(hr == D3DRM_OK, "Test %u: Cannot get IDirect3DRMObject interface (hr = %x).\n", test_idx, hr);
+ hr = IUnknown_QueryInterface(unknown, &IID_IDirect3DRMObject, (void**)&obj);
+ ok(hr == D3DRM_OK, "Test %u: expected D3DRM_OK (hr = %x).\n", test_idx, hr);
+ IUnknown_Release(unknown);
+
+ context.called = 0;
+ context.test_idx = test_idx;
+ context.obj = obj;
+
+ hr = IDirect3DRMObject_AddDestroyCallback(obj, NULL, &context);
+ ok(hr == D3DRMERR_BADVALUE, "Test %u: expected D3DRMERR_BADVALUE (hr = %x).\n", test_idx, hr);
+
+ hr = IDirect3DRMObject_AddDestroyCallback(obj, destroy_callback, &context);
+ ok(hr == D3DRM_OK, "Test %u: expected D3DRM_OK (hr = %x).\n", test_idx, hr);
+
+ /* same callback added twice */
+ hr = IDirect3DRMObject_AddDestroyCallback(obj, destroy_callback, &context);
+ ok(hr == D3DRM_OK, "Test %u: expected D3DRM_OK (hr = %x).\n", test_idx, hr);
+
+ hr = IDirect3DRMObject_DeleteDestroyCallback(obj, destroy_callback1, NULL);
+ ok(hr == D3DRM_OK, "Test %u: expected D3DRM_OK (hr = %x).\n", test_idx, hr);
+
+ hr = IDirect3DRMObject_DeleteDestroyCallback(obj, destroy_callback1, &context);
+ ok(hr == D3DRM_OK, "Test %u: expected D3DRM_OK (hr = %x).\n", test_idx, hr);
+
+ /* add one more */
+ hr = IDirect3DRMObject_AddDestroyCallback(obj, destroy_callback1, &context);
+ ok(hr == D3DRM_OK, "Test %u: expected D3DRM_OK (hr = %x).\n", test_idx, hr);
+
+ hr = IDirect3DRMObject_DeleteDestroyCallback(obj, NULL, NULL);
+ ok(hr == D3DRMERR_BADVALUE, "Test %u: expected D3DRM_BADVALUE (hr = %x).\n", test_idx, hr);
+
+ context.called = 0;
+ IDirect3DRMObject_Release(obj);
+ ok(context.called == 3, "Test %u: got %d, expected 3.\n", test_idx, context.called);
+
+ /* test this pattern - add cb1, add cb2, add cb1, delete cb1 */
+ hr = IDirect3DRM_CreateObject(d3drm, clsid, NULL, iid, (void **)&unknown);
+ ok(hr == D3DRM_OK, "Test %u: Cannot get IDirect3DRMObject interface (hr = %x).\n", test_idx, hr);
+ hr = IUnknown_QueryInterface(unknown, &IID_IDirect3DRMObject, (void**)&obj);
+ ok(hr == D3DRM_OK, "Test %u: expected D3DRM_OK (hr = %x).\n", test_idx, hr);
+ IUnknown_Release(unknown);
+
+ hr = IDirect3DRMObject_AddDestroyCallback(obj, destroy_callback, &context);
+ ok(hr == D3DRM_OK, "Test %u: expected D3DRM_OK (hr = %x).\n", test_idx, hr);
+
+ hr = IDirect3DRMObject_AddDestroyCallback(obj, destroy_callback1, &context);
+ ok(hr == D3DRM_OK, "Test %u: expected D3DRM_OK (hr = %x).\n", test_idx, hr);
+
+ hr = IDirect3DRMObject_AddDestroyCallback(obj, destroy_callback, &context);
+ ok(hr == D3DRM_OK, "Test %u: expected D3DRM_OK (hr = %x).\n", test_idx, hr);
+
+ hr = IDirect3DRMObject_DeleteDestroyCallback(obj, destroy_callback, &context);
+ ok(hr == D3DRM_OK, "Test %u: expected D3DRM_OK (hr = %x).\n", test_idx, hr);
+
+ context.called = 0;
+ hr = IDirect3DRMObject_QueryInterface(obj, &IID_IDirect3DRMObject, (void**)&context.obj);
+ ok(hr == D3DRM_OK, "Test %u: expected D3DRM_OK (hr = %x).\n", test_idx, hr);
+ IDirect3DRMObject_Release(context.obj);
+ IUnknown_Release(unknown);
+ ok(context.called == 2, "Test %u: got %d, expected 2.\n", test_idx, context.called);
+}
+
static void test_object(void)
{
static const struct
@@ -1292,6 +1368,9 @@ static void test_object(void)
ref2 = get_refcount((IUnknown *)d3drm1);
ok(ref2 == ref1, "Test %u: expected ref2 == ref1, got ref1 = %u, ref2 = %u.\n", i, ref1, ref2);
+ /* test Add/Destroy callbacks */
+ test_destroy_callback(i, tests[i].clsid, tests[i].iid);
+
hr = IDirect3DRM2_CreateObject(d3drm2, tests[i].clsid, NULL, tests[i].iid, (void **)&unknown);
ok(SUCCEEDED(hr), "Test %u: expected hr == D3DRM_OK, got %#x.\n", i, hr);
ref2 = get_refcount((IUnknown *)d3drm1);
@@ -1325,7 +1404,6 @@ static void test_object(void)
static void test_Viewport(void)
{
- struct destroy_context context;
IDirectDrawClipper *pClipper;
HRESULT hr;
IDirect3DRM *d3drm;
@@ -1411,129 +1489,6 @@ static void test_Viewport(void)
ok(data == 1, "got %x\n", data);
IDirect3DRMViewport2_Release(viewport2);
- /* destroy callback */
- context.called = 0;
- hr = IDirect3DRMViewport_QueryInterface(viewport, &IID_IDirect3DRMObject, (void**)&context.obj);
- ok(hr == D3DRM_OK, "expected D3DRM_OK (hr = %x)\n", hr);
- IDirect3DRMObject_Release(context.obj);
-
- hr = IDirect3DRMViewport_AddDestroyCallback(viewport, NULL, &context);
- ok(hr == D3DRMERR_BADVALUE, "expected D3DRMERR_BADVALUE (hr = %x)\n", hr);
-
- hr = IDirect3DRMViewport_AddDestroyCallback(viewport, destroy_callback, &context);
- ok(hr == D3DRM_OK, "expected D3DRM_OK (hr = %x)\n", hr);
-
- /* same callback added twice */
- hr = IDirect3DRMViewport_AddDestroyCallback(viewport, destroy_callback, &context);
- ok(hr == D3DRM_OK, "expected D3DRM_OK (hr = %x)\n", hr);
-
- hr = IDirect3DRMViewport_DeleteDestroyCallback(viewport, destroy_callback1, NULL);
- ok(hr == D3DRM_OK, "expected D3DRM_OK (hr = %x)\n", hr);
-
- hr = IDirect3DRMViewport_DeleteDestroyCallback(viewport, destroy_callback1, &context);
- ok(hr == D3DRM_OK, "expected D3DRM_OK (hr = %x)\n", hr);
-
- /* add one more */
- hr = IDirect3DRMViewport_AddDestroyCallback(viewport, destroy_callback1, &context);
- ok(hr == D3DRM_OK, "expected D3DRM_OK (hr = %x)\n", hr);
-
- hr = IDirect3DRMViewport_DeleteDestroyCallback(viewport, NULL, NULL);
- ok(hr == D3DRMERR_BADVALUE, "expected D3DRM_BADVALUE (hr = %x)\n", hr);
-
- context.called = 0;
- IDirect3DRMViewport_Release(viewport);
- ok(context.called == 3, "got %d, expected 3\n", context.called);
-
- /* test this pattern - add cb1, add cb2, add cb1, delete cb1 */
- hr = IDirect3DRM_CreateViewport(d3drm, device, frame, rc.left, rc.top, rc.right, rc.bottom, &viewport);
- ok(hr == D3DRM_OK, "Cannot get IDirect3DRMViewport interface (hr = %x)\n", hr);
-
- hr = IDirect3DRMViewport_AddDestroyCallback(viewport, destroy_callback, &context);
- ok(hr == D3DRM_OK, "expected D3DRM_OK (hr = %x)\n", hr);
-
- hr = IDirect3DRMViewport_AddDestroyCallback(viewport, destroy_callback1, &context);
- ok(hr == D3DRM_OK, "expected D3DRM_OK (hr = %x)\n", hr);
-
- hr = IDirect3DRMViewport_AddDestroyCallback(viewport, destroy_callback, &context);
- ok(hr == D3DRM_OK, "expected D3DRM_OK (hr = %x)\n", hr);
-
- hr = IDirect3DRMViewport_DeleteDestroyCallback(viewport, destroy_callback, &context);
- ok(hr == D3DRM_OK, "expected D3DRM_OK (hr = %x)\n", hr);
-
- context.called = 0;
- hr = IDirect3DRMViewport_QueryInterface(viewport, &IID_IDirect3DRMObject, (void**)&context.obj);
- ok(hr == D3DRM_OK, "expected D3DRM_OK (hr = %x)\n", hr);
- IDirect3DRMObject_Release(context.obj);
- IDirect3DRMViewport_Release(viewport);
- ok(context.called == 2, "got %d, expected 2\n", context.called);
-
- /* destroy from Viewport2 */
- hr = IDirect3DRM_CreateViewport(d3drm, device, frame, rc.left, rc.top, rc.right, rc.bottom, &viewport);
- ok(hr == D3DRM_OK, "Cannot get IDirect3DRMViewport interface (hr = %x)\n", hr);
-
- hr = IDirect3DRMViewport_QueryInterface(viewport, &IID_IDirect3DRMViewport2, (void**)&viewport2);
- ok(hr == D3DRM_OK, "expected D3DRM_OK (hr = %x)\n", hr);
- IDirect3DRMViewport_Release(viewport);
-
- context.called = 0;
- hr = IDirect3DRMViewport2_QueryInterface(viewport2, &IID_IDirect3DRMObject, (void**)&context.obj);
- ok(hr == D3DRM_OK, "expected D3DRM_OK (hr = %x)\n", hr);
- IDirect3DRMObject_Release(context.obj);
-
- hr = IDirect3DRMViewport2_AddDestroyCallback(viewport2, NULL, &context);
- ok(hr == D3DRMERR_BADVALUE, "expected D3DRMERR_BADVALUE (hr = %x)\n", hr);
-
- hr = IDirect3DRMViewport2_AddDestroyCallback(viewport2, destroy_callback, &context);
- ok(hr == D3DRM_OK, "expected D3DRM_OK (hr = %x)\n", hr);
-
- /* same callback added twice */
- hr = IDirect3DRMViewport2_AddDestroyCallback(viewport2, destroy_callback, &context);
- ok(hr == D3DRM_OK, "expected D3DRM_OK (hr = %x)\n", hr);
-
- hr = IDirect3DRMViewport2_DeleteDestroyCallback(viewport2, destroy_callback1, NULL);
- ok(hr == D3DRM_OK, "expected D3DRM_OK (hr = %x)\n", hr);
-
- hr = IDirect3DRMViewport2_DeleteDestroyCallback(viewport2, destroy_callback1, &context);
- ok(hr == D3DRM_OK, "expected D3DRM_OK (hr = %x)\n", hr);
-
- /* add one more */
- hr = IDirect3DRMViewport2_AddDestroyCallback(viewport2, destroy_callback1, &context);
- ok(hr == D3DRM_OK, "expected D3DRM_OK (hr = %x)\n", hr);
-
- hr = IDirect3DRMViewport2_DeleteDestroyCallback(viewport2, NULL, NULL);
- ok(hr == D3DRMERR_BADVALUE, "expected D3DRM_BADVALUE (hr = %x)\n", hr);
-
- context.called = 0;
- IDirect3DRMViewport2_Release(viewport2);
- ok(context.called == 3, "got %d, expected 3\n", context.called);
-
- /* test this pattern - add cb1, add cb2, add cb1, delete cb1 */
- hr = IDirect3DRM_CreateViewport(d3drm, device, frame, rc.left, rc.top, rc.right, rc.bottom, &viewport);
- ok(hr == D3DRM_OK, "Cannot get IDirect3DRMViewport interface (hr = %x)\n", hr);
-
- hr = IDirect3DRMViewport_QueryInterface(viewport, &IID_IDirect3DRMViewport2, (void**)&viewport2);
- ok(hr == D3DRM_OK, "expected D3DRM_OK (hr = %x)\n", hr);
- IDirect3DRMViewport_Release(viewport);
-
- hr = IDirect3DRMViewport2_AddDestroyCallback(viewport2, destroy_callback, &context);
- ok(hr == D3DRM_OK, "expected D3DRM_OK (hr = %x)\n", hr);
-
- hr = IDirect3DRMViewport2_AddDestroyCallback(viewport2, destroy_callback1, &context);
- ok(hr == D3DRM_OK, "expected D3DRM_OK (hr = %x)\n", hr);
-
- hr = IDirect3DRMViewport2_AddDestroyCallback(viewport2, destroy_callback, &context);
- ok(hr == D3DRM_OK, "expected D3DRM_OK (hr = %x)\n", hr);
-
- hr = IDirect3DRMViewport2_DeleteDestroyCallback(viewport2, destroy_callback, &context);
- ok(hr == D3DRM_OK, "expected D3DRM_OK (hr = %x)\n", hr);
-
- context.called = 0;
- hr = IDirect3DRMViewport2_QueryInterface(viewport2, &IID_IDirect3DRMObject, (void**)&context.obj);
- ok(hr == D3DRM_OK, "expected D3DRM_OK (hr = %x)\n", hr);
- IDirect3DRMObject_Release(context.obj);
- IDirect3DRMViewport2_Release(viewport2);
- ok(context.called == 2, "got %d, expected 2\n", context.called);
-
IDirect3DRMFrame_Release(frame);
IDirect3DRMDevice_Release(device);
IDirectDrawClipper_Release(pClipper);
--
2.3.2 (Apple Git-55)
More information about the wine-patches
mailing list