d3d9/tests: Use a separate device for clear_test().

This commit is contained in:
Henri Verbeet 2014-04-11 07:53:18 +02:00 committed by Alexandre Julliard
parent e3383d1739
commit 32919f40d0
1 changed files with 22 additions and 2 deletions

View File

@ -470,7 +470,7 @@ static void lighting_test(IDirect3DDevice9 *device)
ok(hr == D3D_OK, "IDirect3DDevice9_SetMaterial returned %08x\n", hr); ok(hr == D3D_OK, "IDirect3DDevice9_SetMaterial returned %08x\n", hr);
} }
static void clear_test(IDirect3DDevice9 *device) static void clear_test(void)
{ {
/* Tests the correctness of clearing parameters */ /* Tests the correctness of clearing parameters */
HRESULT hr; HRESULT hr;
@ -481,6 +481,20 @@ static void clear_test(IDirect3DDevice9 *device)
RECT scissor; RECT scissor;
DWORD oldColorWrite; DWORD oldColorWrite;
BOOL invalid_clear_failed = FALSE; BOOL invalid_clear_failed = FALSE;
IDirect3DDevice9 *device;
IDirect3D9 *d3d;
ULONG refcount;
HWND window;
window = CreateWindowA("static", "d3d9_test", WS_OVERLAPPEDWINDOW | WS_VISIBLE,
0, 0, 640, 480, NULL, NULL, NULL, NULL);
d3d = Direct3DCreate9(D3D_SDK_VERSION);
ok(!!d3d, "Failed to create a D3D object.\n");
if (!(device = create_device(d3d, window, window, TRUE)))
{
skip("Failed to create a D3D device, skipping tests.\n");
goto done;
}
hr = IDirect3DDevice9_Clear(device, 0, NULL, D3DCLEAR_TARGET, 0xffffffff, 0.0, 0); hr = IDirect3DDevice9_Clear(device, 0, NULL, D3DCLEAR_TARGET, 0xffffffff, 0.0, 0);
ok(hr == D3D_OK, "IDirect3DDevice9_Clear failed with %08x\n", hr); ok(hr == D3D_OK, "IDirect3DDevice9_Clear failed with %08x\n", hr);
@ -717,6 +731,12 @@ static void clear_test(IDirect3DDevice9 *device)
"Clear with count = 1, rect = NULL has color %08x\n", color); "Clear with count = 1, rect = NULL has color %08x\n", color);
IDirect3DDevice9_Present(device, NULL, NULL, NULL, NULL); IDirect3DDevice9_Present(device, NULL, NULL, NULL, NULL);
refcount = IDirect3DDevice9_Release(device);
ok(!refcount, "Device has %u references left.\n", refcount);
done:
IDirect3D9_Release(d3d);
DestroyWindow(window);
} }
static void color_fill_test(void) static void color_fill_test(void)
@ -16747,11 +16767,11 @@ START_TEST(visual)
depth_clamp_test(device_ptr); depth_clamp_test(device_ptr);
stretchrect_test(device_ptr); stretchrect_test(device_ptr);
lighting_test(device_ptr); lighting_test(device_ptr);
clear_test(device_ptr);
cleanup_device(device_ptr); cleanup_device(device_ptr);
device_ptr = NULL; device_ptr = NULL;
clear_test();
color_fill_test(); color_fill_test();
fog_test(); fog_test();
test_cube_wrap(); test_cube_wrap();