Module: wine Branch: master Commit: 1b3c8aaf069fdaacb3961de1faf3638cf2b42657 URL: http://source.winehq.org/git/wine.git/?a=commit;h=1b3c8aaf069fdaacb3961de1fa...
Author: André Hentschel nerv@dawncrow.de Date: Fri Jan 13 00:21:05 2012 +0100
d3drm/tests: Add refcount testing.
---
dlls/d3drm/tests/d3drm.c | 27 ++++++++++++++++++++++++++- 1 files changed, 26 insertions(+), 1 deletions(-)
diff --git a/dlls/d3drm/tests/d3drm.c b/dlls/d3drm/tests/d3drm.c index 8f3c01c..d4bb77d 100644 --- a/dlls/d3drm/tests/d3drm.c +++ b/dlls/d3drm/tests/d3drm.c @@ -16,7 +16,9 @@ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA */
-#include "d3drm.h" +#define COBJMACROS +#include <d3drm.h> +#include <initguid.h>
#include "wine/test.h"
@@ -24,6 +26,13 @@ static HMODULE d3drm_handle = 0;
static HRESULT (WINAPI * pDirect3DRMCreate)(LPDIRECT3DRM* ppDirect3DRM);
+#define CHECK_REFCOUNT(obj,rc) \ + { \ + int rc_new = rc; \ + int count = get_refcount( (IUnknown *)obj ); \ + ok(count == rc_new, "Invalid refcount. Expected %d got %d\n", rc_new, count); \ + } + #define D3DRM_GET_PROC(func) \ p ## func = (void*)GetProcAddress(d3drm_handle, #func); \ if(!p ## func) { \ @@ -47,6 +56,12 @@ static BOOL InitFunctionPtrs(void) return TRUE; }
+static int get_refcount(IUnknown *object) +{ + IUnknown_AddRef( object ); + return IUnknown_Release( object ); +} + static char data_bad_version[] = "xof 0302txt 0064\n" "Header Object\n" @@ -236,11 +251,13 @@ static void test_Frame(void)
hr = IDirect3DRM_CreateFrame(pD3DRM, NULL, &pFrameC); ok(hr == D3DRM_OK, "Cannot get IDirect3DRMFrame interface (hr = %x)\n", hr); + CHECK_REFCOUNT(pFrameC, 1);
pFrameTmp = (void*)0xdeadbeef; hr = IDirect3DRMFrame_GetParent(pFrameC, &pFrameTmp); todo_wine ok(hr == D3DRM_OK, "Cannot get parent frame (hr = %x)\n", hr); todo_wine ok(pFrameTmp == NULL, "pFrameTmp = %p\n", pFrameTmp); + CHECK_REFCOUNT(pFrameC, 1);
pArray = NULL; hr = IDirect3DRMFrame_GetChildren(pFrameC, &pArray); @@ -264,6 +281,8 @@ static void test_Frame(void)
hr = IDirect3DRMFrame_AddChild(pFrameP1, pFrameC); todo_wine ok(hr == D3DRM_OK, "Cannot add child frame (hr = %x)\n", hr); + CHECK_REFCOUNT(pFrameP1, 1); + todo_wine CHECK_REFCOUNT(pFrameC, 2);
pArray = NULL; hr = IDirect3DRMFrame_GetChildren(pFrameP1, &pArray); @@ -279,6 +298,7 @@ static void test_Frame(void) hr = IDirect3DRMFrame_GetParent(pFrameC, &pFrameTmp); todo_wine ok(hr == D3DRM_OK, "Cannot get parent frame (hr = %x)\n", hr); todo_wine ok(pFrameTmp == pFrameP1, "pFrameTmp = %p\n", pFrameTmp); + todo_wine CHECK_REFCOUNT(pFrameP1, 2);
/* Add child to second parent */ hr = IDirect3DRM_CreateFrame(pD3DRM, NULL, &pFrameP2); @@ -286,6 +306,7 @@ static void test_Frame(void)
hr = IDirect3DRMFrame_AddChild(pFrameP2, pFrameC); todo_wine ok(hr == D3DRM_OK, "Cannot add child frame (hr = %x)\n", hr); + todo_wine CHECK_REFCOUNT(pFrameC, 2);
pArray = NULL; hr = IDirect3DRMFrame_GetChildren(pFrameP2, &pArray); @@ -311,10 +332,13 @@ static void test_Frame(void) hr = IDirect3DRMFrame_GetParent(pFrameC, &pFrameTmp); todo_wine ok(hr == D3DRM_OK, "Cannot get parent frame (hr = %x)\n", hr); todo_wine ok(pFrameTmp == pFrameP2, "pFrameTmp = %p\n", pFrameTmp); + todo_wine CHECK_REFCOUNT(pFrameP2, 2); + todo_wine CHECK_REFCOUNT(pFrameC, 2);
/* Add child again */ hr = IDirect3DRMFrame_AddChild(pFrameP2, pFrameC); todo_wine ok(hr == D3DRM_OK, "Cannot add child frame (hr = %x)\n", hr); + todo_wine CHECK_REFCOUNT(pFrameC, 2);
pArray = NULL; hr = IDirect3DRMFrame_GetChildren(pFrameP2, &pArray); @@ -329,6 +353,7 @@ static void test_Frame(void) /* Delete child */ hr = IDirect3DRMFrame_DeleteChild(pFrameP2, pFrameC); todo_wine ok(hr == D3DRM_OK, "Cannot delete child frame (hr = %x)\n", hr); + CHECK_REFCOUNT(pFrameC, 1);
pArray = NULL; hr = IDirect3DRMFrame_GetChildren(pFrameP2, &pArray);