[1/3] ddraw/tests: Move surface attachment tests from refcount.c to dsurface.c.
Octavian Voicu
octavian.voicu at gmail.com
Thu Nov 3 06:32:09 CDT 2011
--
This patch series supersedes the previous patch I sent.
Tests are moved without functional changes into AttachmentTest7 and
AttachmentTest.
---
dlls/ddraw/tests/dsurface.c | 131 ++++++++++++++++++++++++++++++++++++++++++-
dlls/ddraw/tests/refcount.c | 106 +---------------------------------
2 files changed, 133 insertions(+), 104 deletions(-)
diff --git a/dlls/ddraw/tests/dsurface.c b/dlls/ddraw/tests/dsurface.c
index 3aefe52..7b5ffd5 100644
--- a/dlls/ddraw/tests/dsurface.c
+++ b/dlls/ddraw/tests/dsurface.c
@@ -1239,7 +1239,9 @@ static void AttachmentTest7(void)
HRESULT hr;
IDirectDraw7 *dd7;
IDirectDrawSurface7 *surface1, *surface2, *surface3, *surface4;
+ IDirectDrawSurface *surface1v1, *surface2v1;
DDSURFACEDESC2 ddsd, ddsd2;
+ DWORD ref;
UINT num;
DDSCAPS2 caps = {DDSCAPS_TEXTURE, 0, 0, 0}, caps2 = {DDSCAPS_BACKBUFFER,0,0,0};
HWND window = CreateWindow( "static", "ddraw_test", WS_OVERLAPPEDWINDOW, 100, 100, 160, 160, NULL, NULL, NULL, NULL );
@@ -1417,6 +1419,73 @@ static void AttachmentTest7(void)
IDirectDrawSurface7_Release(surface2);
IDirectDrawSurface7_Release(surface1);
+ /* Test DeleteAttachedSurface and automatic detachment of attached surfaces on release */
+ memset(&ddsd, 0, sizeof(ddsd));
+ ddsd.dwSize = sizeof(ddsd);
+ ddsd.dwFlags = DDSD_CAPS | DDSD_WIDTH | DDSD_HEIGHT | DDSD_PIXELFORMAT;
+ ddsd.dwWidth = 64;
+ ddsd.dwHeight = 64;
+ ddsd.ddsCaps.dwCaps = DDSCAPS_OFFSCREENPLAIN | DDSCAPS_3DDEVICE;
+ U4(ddsd).ddpfPixelFormat.dwSize = sizeof(U4(ddsd).ddpfPixelFormat);
+ U4(ddsd).ddpfPixelFormat.dwFlags = DDPF_PALETTEINDEXED8 | DDPF_RGB;
+ U1(U4(ddsd).ddpfPixelFormat).dwRGBBitCount = 8;
+
+ memset(&ddsd2, 0, sizeof(ddsd2));
+ ddsd2.dwSize = sizeof(ddsd2);
+ ddsd2.dwFlags = DDSD_CAPS | DDSD_WIDTH | DDSD_HEIGHT | DDSD_PIXELFORMAT;
+ ddsd2.dwWidth = ddsd.dwWidth;
+ ddsd2.dwHeight = ddsd.dwHeight;
+ ddsd2.ddsCaps.dwCaps = DDSCAPS_3DDEVICE | DDSCAPS_ZBUFFER;
+ U4(ddsd2).ddpfPixelFormat.dwSize = sizeof(U4(ddsd2).ddpfPixelFormat);
+ U4(ddsd2).ddpfPixelFormat.dwFlags = DDPF_ZBUFFER;
+ U1(U4(ddsd2).ddpfPixelFormat).dwZBufferBitDepth = 16;
+ U3(U4(ddsd2).ddpfPixelFormat).dwZBitMask = 0x0000FFFF;
+
+ hr = IDirectDraw7_CreateSurface(dd7, &ddsd, &surface1, NULL);
+ ok(hr == DD_OK, "CreateSurface returned %08x\n", hr);
+ if (SUCCEEDED(hr))
+ {
+ hr = IDirectDraw7_CreateSurface(dd7, &ddsd2, &surface2, NULL);
+ ok(hr == DD_OK, "CreateSurface returned %08x\n", hr);
+ if (SUCCEEDED(hr))
+ {
+ /* DeleteAttachedSurface */
+ hr = IDirectDrawSurface7_AddAttachedSurface(surface1, surface2);
+ ok(hr == DD_OK, "AddAttachedSurface returned %08x\n", hr);
+ if (SUCCEEDED(hr))
+ {
+ ref = getRefcount((IUnknown *)surface2);
+ ok(ref == 2, "Got refcount %d, expected 2\n", ref);
+ hr = IDirectDrawSurface7_QueryInterface(surface1, &IID_IDirectDrawSurface, (void **)&surface1v1);
+ ok(hr == DD_OK, "IDirectDrawSurface7_QueryInterface returned %08x\n", hr);
+ hr = IDirectDrawSurface7_QueryInterface(surface2, &IID_IDirectDrawSurface, (void **)&surface2v1);
+ ok(hr == DD_OK, "IDirectDrawSurface7_QueryInterface returned %08x\n", hr);
+ hr = IDirectDrawSurface_DeleteAttachedSurface(surface1v1, 0, surface2v1);
+ ok(hr == DDERR_SURFACENOTATTACHED, "DeleteAttachedSurface returned %08x\n", hr);
+ if (surface2v1 != NULL) IDirectDrawSurface_Release(surface2v1);
+ if (surface1v1 != NULL) IDirectDrawSurface_Release(surface1v1);
+ hr = IDirectDrawSurface7_DeleteAttachedSurface(surface1, 0, surface2);
+ ok(hr == DD_OK, "DeleteAttachedSurface returned %08x\n", hr);
+ ref = getRefcount((IUnknown *)surface2);
+ ok(ref == 1, "Got refcount %d, expected 1\n", ref);
+ }
+
+ /* Automatic detachment on release */
+ hr = IDirectDrawSurface7_AddAttachedSurface(surface1, surface2);
+ ok(hr == DD_OK, "AddAttachedSurface returned %08x\n", hr);
+ ref = getRefcount((IUnknown *)surface2);
+ ok(ref == 2, "Got refcount %d, expected 2\n", ref);
+ ref = IDirectDrawSurface7_Release(surface1);
+ ok(!ref, "Got refcount %d, expected 0\n", ref);
+ ref = getRefcount((IUnknown *)surface2);
+ ok(ref == 1, "Got refcount %d, expected 1\n", ref);
+ ref = IDirectDrawSurface7_Release(surface2);
+ ok(!ref, "Got refcount %d, expected 0\n", ref);
+ }
+ else
+ IDirectDrawSurface7_Release(surface1);
+ }
+
hr =IDirectDraw7_SetCooperativeLevel(dd7, NULL, DDSCL_NORMAL);
ok(hr == DD_OK, "SetCooperativeLevel returned %08x\n", hr);
IDirectDraw7_Release(dd7);
@@ -1426,7 +1495,8 @@ static void AttachmentTest(void)
{
HRESULT hr;
IDirectDrawSurface *surface1, *surface2, *surface3, *surface4;
- DDSURFACEDESC ddsd;
+ DDSURFACEDESC ddsd, ddsd2;
+ DWORD ref;
DDSCAPS caps = {DDSCAPS_TEXTURE};
BOOL refrast = FALSE;
HWND window = CreateWindow( "static", "ddraw_test", WS_OVERLAPPEDWINDOW, 100, 100, 160, 160, NULL, NULL, NULL, NULL );
@@ -1623,6 +1693,65 @@ static void AttachmentTest(void)
IDirectDrawSurface_Release(surface2);
IDirectDrawSurface_Release(surface1);
+ /* Test DeleteAttachedSurface and automatic detachment of attached surfaces on release */
+ memset(&ddsd, 0, sizeof(ddsd));
+ ddsd.dwSize = sizeof(ddsd);
+ ddsd.dwFlags = DDSD_CAPS | DDSD_WIDTH | DDSD_HEIGHT | DDSD_PIXELFORMAT;
+ ddsd.dwWidth = 64;
+ ddsd.dwHeight = 64;
+ ddsd.ddsCaps.dwCaps = DDSCAPS_OFFSCREENPLAIN | DDSCAPS_3DDEVICE;
+ U4(ddsd).ddpfPixelFormat.dwSize = sizeof(U4(ddsd).ddpfPixelFormat);
+ U4(ddsd).ddpfPixelFormat.dwFlags = DDPF_PALETTEINDEXED8 | DDPF_RGB;
+ U1(U4(ddsd).ddpfPixelFormat).dwRGBBitCount = 8;
+
+ memset(&ddsd2, 0, sizeof(ddsd2));
+ ddsd2.dwSize = sizeof(ddsd2);
+ ddsd2.dwFlags = DDSD_CAPS | DDSD_WIDTH | DDSD_HEIGHT | DDSD_PIXELFORMAT;
+ ddsd2.dwWidth = ddsd.dwWidth;
+ ddsd2.dwHeight = ddsd.dwHeight;
+ ddsd2.ddsCaps.dwCaps = DDSCAPS_3DDEVICE | DDSCAPS_ZBUFFER;
+ U4(ddsd2).ddpfPixelFormat.dwSize = sizeof(U4(ddsd2).ddpfPixelFormat);
+ U4(ddsd2).ddpfPixelFormat.dwFlags = DDPF_ZBUFFER;
+ U1(U4(ddsd2).ddpfPixelFormat).dwZBufferBitDepth = 16;
+ U3(U4(ddsd2).ddpfPixelFormat).dwZBitMask = 0x0000FFFF;
+
+ hr = IDirectDraw_CreateSurface(lpDD, (DDSURFACEDESC *)&ddsd, &surface1, NULL);
+ ok(hr == DD_OK, "CreateSurface returned %08x\n", hr);
+ if (SUCCEEDED(hr))
+ {
+ hr = IDirectDraw_CreateSurface(lpDD, (DDSURFACEDESC *)&ddsd2, &surface2, NULL);
+ ok(hr == DD_OK, "CreateSurface returned %08x\n", hr);
+ if (SUCCEEDED(hr))
+ {
+ /* DeleteAttachedSurface */
+ hr = IDirectDrawSurface_AddAttachedSurface(surface1, surface2);
+ ok(hr == DD_OK, "AddAttachedSurface returned %08x\n", hr);
+ if (SUCCEEDED(hr))
+ {
+ ref = getRefcount((IUnknown *)surface2);
+ ok(ref == 2, "Got refcount %d, expected 2\n", ref);
+ hr = IDirectDrawSurface_DeleteAttachedSurface(surface1, 0, surface2);
+ ok(hr == DD_OK, "DeleteAttachedSurface returned %08x\n", hr);
+ ref = getRefcount((IUnknown *)surface2);
+ ok(ref == 1, "Got refcount %d, expected 1\n", ref);
+ }
+
+ /* Automatic detachment on release */
+ hr = IDirectDrawSurface_AddAttachedSurface(surface1, surface2);
+ ok(hr == DD_OK, "AddAttachedSurface returned %08x\n", hr);
+ ref = getRefcount((IUnknown *)surface2);
+ ok(ref == 2, "Got refcount %d, expected 2\n", ref);
+ ref = IDirectDrawSurface_Release(surface1);
+ ok(!ref, "Got refcount %d, expected 0\n", ref);
+ ref = getRefcount((IUnknown *)surface2);
+ ok(ref == 1, "Got refcount %d, expected 1\n", ref);
+ ref = IDirectDrawSurface_Release(surface2);
+ ok(!ref, "Got refcount %d, expected 0\n", ref);
+ }
+ else
+ IDirectDrawSurface_Release(surface1);
+ }
+
hr =IDirectDraw_SetCooperativeLevel(lpDD, NULL, DDSCL_NORMAL);
ok(hr == DD_OK, "SetCooperativeLevel returned %08x\n", hr);
diff --git a/dlls/ddraw/tests/refcount.c b/dlls/ddraw/tests/refcount.c
index cf94986..970865e 100644
--- a/dlls/ddraw/tests/refcount.c
+++ b/dlls/ddraw/tests/refcount.c
@@ -47,11 +47,11 @@ static void test_ddraw_objects(void)
IDirectDraw2 *DDraw2;
IDirectDraw *DDraw1;
IDirectDrawPalette *palette;
- IDirectDrawSurface7 *surface = NULL, *stencil;
- IDirectDrawSurface *surface1, *stencil1;
+ IDirectDrawSurface7 *surface = NULL;
+ IDirectDrawSurface *surface1;
IDirectDrawSurface4 *surface4;
PALETTEENTRY Table[256];
- DDSURFACEDESC2 ddsd, ddsd_stencil;
+ DDSURFACEDESC2 ddsd;
hr = pDirectDrawCreateEx(NULL, (void **) &DDraw7, &IID_IDirectDraw7, NULL);
ok(hr == DD_OK || hr==DDERR_NODIRECTDRAWSUPPORT, "DirectDrawCreateEx returned: %x\n", hr);
@@ -92,17 +92,6 @@ static void test_ddraw_objects(void)
U4(ddsd).ddpfPixelFormat.dwFlags = DDPF_PALETTEINDEXED8 | DDPF_RGB;
U1(U4(ddsd).ddpfPixelFormat).dwRGBBitCount = 8;
- memset(&ddsd_stencil, 0, sizeof(ddsd_stencil));
- ddsd_stencil.dwSize = sizeof(ddsd_stencil);
- ddsd_stencil.dwFlags = DDSD_CAPS | DDSD_WIDTH | DDSD_HEIGHT | DDSD_PIXELFORMAT;
- ddsd_stencil.dwWidth = ddsd.dwWidth;
- ddsd_stencil.dwHeight = ddsd.dwHeight;
- ddsd_stencil.ddsCaps.dwCaps = DDSCAPS_3DDEVICE | DDSCAPS_ZBUFFER;
- U4(ddsd_stencil).ddpfPixelFormat.dwSize = sizeof(U4(ddsd_stencil).ddpfPixelFormat);
- U4(ddsd_stencil).ddpfPixelFormat.dwFlags = DDPF_ZBUFFER;
- U1(U4(ddsd_stencil).ddpfPixelFormat).dwZBufferBitDepth = 16;
- U3(U4(ddsd_stencil).ddpfPixelFormat).dwZBitMask = 0x0000FFFF;
-
hr = IDirectDraw7_CreateSurface(DDraw7, &ddsd, &surface, NULL);
if (!surface)
{
@@ -197,95 +186,6 @@ static void test_ddraw_objects(void)
ok(ref == 1, "Got refcount %d, expected 1\n", ref);
IDirectDrawSurface_Release(surface1);
- /* AddAttachedSurface with IDirectDrawSurface7 */
- ddsd.dwSize = sizeof(DDSURFACEDESC2);
- ddsd.ddsCaps.dwCaps |= DDSCAPS_3DDEVICE;
- hr = IDirectDraw7_CreateSurface(DDraw7, &ddsd, &surface, NULL);
- ok(hr == DD_OK, "CreateSurface returned %08x\n", hr);
- if (SUCCEEDED(hr))
- {
- ddsd_stencil.dwSize = sizeof(DDSURFACEDESC2);
- hr = IDirectDraw7_CreateSurface(DDraw7, &ddsd_stencil, &stencil, NULL);
- ok(hr == DD_OK, "CreateSurface returned %08x\n", hr);
- if (SUCCEEDED(hr))
- {
- /* AddAttachedSurface with DeleteAttachedSurface */
- hr = IDirectDrawSurface7_AddAttachedSurface(surface, stencil);
- ok(hr == DD_OK, "AddAttachedSurface returned %08x\n", hr);
- if (SUCCEEDED(hr))
- {
- ref = getRefcount( (IUnknown *) stencil);
- ok(ref == 2, "Got refcount %d, expected 2\n", ref);
- hr = IDirectDrawSurface7_QueryInterface(surface, &IID_IDirectDrawSurface, (void **) &surface1);
- ok(hr == DD_OK, "IDirectDrawSurface7_QueryInterface returned %08x\n", hr);
- hr = IDirectDrawSurface7_QueryInterface(stencil, &IID_IDirectDrawSurface, (void **) &stencil1);
- ok(hr == DD_OK, "IDirectDrawSurface7_QueryInterface returned %08x\n", hr);
- hr = IDirectDrawSurface_DeleteAttachedSurface(surface1, 0, stencil1);
- ok(hr == DDERR_SURFACENOTATTACHED, "DeleteAttachedSurface returned %08x\n", hr);
- if (stencil1 != NULL) IDirectDrawSurface_Release(stencil1);
- if (surface1 != NULL) IDirectDrawSurface_Release(surface1);
- hr = IDirectDrawSurface7_DeleteAttachedSurface(surface, 0, stencil);
- ok(hr == DD_OK, "DeleteAttachedSurface returned %08x\n", hr);
- ref = getRefcount( (IUnknown *) stencil);
- ok(ref == 1, "Got refcount %d, expected 1\n", ref);
- }
-
- /* Releasing a surface should detach any attached surfaces */
- hr = IDirectDrawSurface7_AddAttachedSurface(surface, stencil);
- ok(hr == DD_OK, "AddAttachedSurface returned %08x\n", hr);
- ref = getRefcount( (IUnknown *) stencil);
- ok(ref == 2, "Got refcount %d, expected 2\n", ref);
- ref = IDirectDrawSurface7_Release(surface);
- ok(!ref, "Got refcount %d, expected 0\n", ref);
- ref = getRefcount( (IUnknown *) stencil);
- ok(ref == 1, "Got refcount %d, expected 1\n", ref);
- ref = IDirectDrawSurface7_Release(stencil);
- ok(!ref, "Got refcount %d, expected 0\n", ref);
- }
- else
- IDirectDrawSurface7_Release(surface);
- }
-
- /* AddAttachedSurface with IDirectDrawSurface */
- ddsd.dwSize = sizeof(DDSURFACEDESC);
- hr = IDirectDraw_CreateSurface(DDraw1, (DDSURFACEDESC *) &ddsd, &surface1, NULL);
- ok(hr == DD_OK, "CreateSurface returned %08x\n", hr);
- if (SUCCEEDED(hr))
- {
- ddsd_stencil.dwSize = sizeof(DDSURFACEDESC);
- hr = IDirectDraw_CreateSurface(DDraw1, (DDSURFACEDESC *) &ddsd_stencil, &stencil1, NULL);
- ok(hr == DD_OK, "CreateSurface returned %08x\n", hr);
- if (SUCCEEDED(hr))
- {
- /* AddAttachedSurface with DeleteAttachedSurface */
- hr = IDirectDrawSurface_AddAttachedSurface(surface1, stencil1);
- ok(hr == DD_OK, "AddAttachedSurface returned %08x\n", hr);
- if (SUCCEEDED(hr))
- {
- ref = getRefcount( (IUnknown *) stencil1);
- ok(ref == 2, "Got refcount %d, expected 2\n", ref);
- hr = IDirectDrawSurface_DeleteAttachedSurface(surface1, 0, stencil1);
- ok(hr == DD_OK, "DeleteAttachedSurface returned %08x\n", hr);
- ref = getRefcount( (IUnknown *) stencil1);
- ok(ref == 1, "Got refcount %d, expected 1\n", ref);
- }
-
- /* Releasing a surface should detach any attached surfaces */
- hr = IDirectDrawSurface_AddAttachedSurface(surface1, stencil1);
- ok(hr == DD_OK, "AddAttachedSurface returned %08x\n", hr);
- ref = getRefcount( (IUnknown *) stencil1);
- ok(ref == 2, "Got refcount %d, expected 2\n", ref);
- ref = IDirectDrawSurface_Release(surface1);
- ok(!ref, "Got refcount %d, expected 0\n", ref);
- ref = getRefcount( (IUnknown *) stencil1);
- ok(ref == 1, "Got refcount %d, expected 1\n", ref);
- ref = IDirectDrawSurface_Release(stencil1);
- ok(!ref, "Got refcount %d, expected 0\n", ref);
- }
- else
- IDirectDrawSurface_Release(surface1);
- }
-
IDirectDraw7_Release(DDraw7);
IDirectDraw4_Release(DDraw4);
IDirectDraw2_Release(DDraw2);
--
1.7.4.1
More information about the wine-patches
mailing list