Commit a2e1dd29 authored by Huw Davies's avatar Huw Davies Committed by Alexandre Julliard

ole32/tests: Relax the reference counting tests a bit. We only care whether…

ole32/tests: Relax the reference counting tests a bit. We only care whether references are held or not.
parent d8a05c37
...@@ -31,8 +31,7 @@ ...@@ -31,8 +31,7 @@
#include "wine/test.h" #include "wine/test.h"
static int droptarget_addref_called; static int droptarget_refs;
static int droptarget_release_called;
/* helper macros to make tests a bit leaner */ /* helper macros to make tests a bit leaner */
#define ok_ole_success(hr, func) ok(hr == S_OK, func " failed with error 0x%08x\n", hr) #define ok_ole_success(hr, func) ok(hr == S_OK, func " failed with error 0x%08x\n", hr)
...@@ -54,14 +53,14 @@ static HRESULT WINAPI DropTarget_QueryInterface(IDropTarget* iface, REFIID riid, ...@@ -54,14 +53,14 @@ static HRESULT WINAPI DropTarget_QueryInterface(IDropTarget* iface, REFIID riid,
static ULONG WINAPI DropTarget_AddRef(IDropTarget* iface) static ULONG WINAPI DropTarget_AddRef(IDropTarget* iface)
{ {
droptarget_addref_called++; droptarget_refs++;
return 2; return droptarget_refs;
} }
static ULONG WINAPI DropTarget_Release(IDropTarget* iface) static ULONG WINAPI DropTarget_Release(IDropTarget* iface)
{ {
droptarget_release_called++; droptarget_refs--;
return 1; return droptarget_refs;
} }
static HRESULT WINAPI DropTarget_DragEnter(IDropTarget* iface, static HRESULT WINAPI DropTarget_DragEnter(IDropTarget* iface,
...@@ -314,10 +313,10 @@ static void test_Register_Revoke(void) ...@@ -314,10 +313,10 @@ static void test_Register_Revoke(void)
hr = RegisterDragDrop((HWND)0xdeadbeef, &DropTarget); hr = RegisterDragDrop((HWND)0xdeadbeef, &DropTarget);
ok(hr == DRAGDROP_E_INVALIDHWND, "RegisterDragDrop with garbage hwnd should return DRAGDROP_E_INVALIDHWND instead of 0x%08x\n", hr); ok(hr == DRAGDROP_E_INVALIDHWND, "RegisterDragDrop with garbage hwnd should return DRAGDROP_E_INVALIDHWND instead of 0x%08x\n", hr);
ok(droptarget_addref_called == 0, "DropTarget_AddRef shouldn't have been called\n"); ok(droptarget_refs == 0, "DropTarget refs should be zero not %d\n", droptarget_refs);
hr = RegisterDragDrop(hwnd, &DropTarget); hr = RegisterDragDrop(hwnd, &DropTarget);
ok_ole_success(hr, "RegisterDragDrop"); ok_ole_success(hr, "RegisterDragDrop");
ok(droptarget_addref_called == 1, "DropTarget_AddRef should have been called once, not %d times\n", droptarget_addref_called); ok(droptarget_refs >= 1, "DropTarget refs should be at least one\n");
prop = GetPropA(hwnd, "OleDropTargetInterface"); prop = GetPropA(hwnd, "OleDropTargetInterface");
ok(prop == &DropTarget, "expected IDropTarget pointer %p, got %p\n", &DropTarget, prop); ok(prop == &DropTarget, "expected IDropTarget pointer %p, got %p\n", &DropTarget, prop);
...@@ -325,15 +324,15 @@ static void test_Register_Revoke(void) ...@@ -325,15 +324,15 @@ static void test_Register_Revoke(void)
hr = RegisterDragDrop(hwnd, &DropTarget); hr = RegisterDragDrop(hwnd, &DropTarget);
ok(hr == DRAGDROP_E_ALREADYREGISTERED, "RegisterDragDrop with already registered hwnd should return DRAGDROP_E_ALREADYREGISTERED instead of 0x%08x\n", hr); ok(hr == DRAGDROP_E_ALREADYREGISTERED, "RegisterDragDrop with already registered hwnd should return DRAGDROP_E_ALREADYREGISTERED instead of 0x%08x\n", hr);
ok(droptarget_release_called == 0, "DropTarget_Release shouldn't have been called\n"); ok(droptarget_refs >= 1, "DropTarget refs should be at least one\n");
OleUninitialize(); OleUninitialize();
ok(droptarget_release_called == 0, "DropTarget_Release shouldn't have been called\n"); ok(droptarget_refs >= 1, "DropTarget refs should be at least one\n");
hr = RevokeDragDrop(hwnd); hr = RevokeDragDrop(hwnd);
ok_ole_success(hr, "RevokeDragDrop"); ok_ole_success(hr, "RevokeDragDrop");
ok(droptarget_release_called == 1 || ok(droptarget_refs == 0 ||
broken(droptarget_release_called == 0), /* NT4 */ broken(droptarget_refs == 1), /* NT4 */
"DropTarget_Release should have been called once, not %d times\n", droptarget_release_called); "DropTarget refs should be zero not %d\n", droptarget_refs);
hr = RevokeDragDrop(NULL); hr = RevokeDragDrop(NULL);
ok(hr == DRAGDROP_E_INVALIDHWND, "RevokeDragDrop with NULL hwnd should return DRAGDROP_E_INVALIDHWND instead of 0x%08x\n", hr); ok(hr == DRAGDROP_E_INVALIDHWND, "RevokeDragDrop with NULL hwnd should return DRAGDROP_E_INVALIDHWND instead of 0x%08x\n", hr);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment