diff --git a/dlls/d3d9/tests/Makefile.in b/dlls/d3d9/tests/Makefile.in index 941c980aef..60b9a637ec 100644 --- a/dlls/d3d9/tests/Makefile.in +++ b/dlls/d3d9/tests/Makefile.in @@ -4,7 +4,6 @@ IMPORTS = user32 C_SRCS = \ d3d9ex.c \ device.c \ - query.c \ shader.c \ stateblock.c \ surface.c \ diff --git a/dlls/d3d9/tests/device.c b/dlls/d3d9/tests/device.c index 0514c7b8f6..6b977ecc5e 100644 --- a/dlls/d3d9/tests/device.c +++ b/dlls/d3d9/tests/device.c @@ -3968,6 +3968,177 @@ static void test_vertex_buffer_alignment(void) DestroyWindow(window); } +static void test_query_support(void) +{ + static const D3DQUERYTYPE queries[] = + { + D3DQUERYTYPE_VCACHE, + D3DQUERYTYPE_RESOURCEMANAGER, + D3DQUERYTYPE_VERTEXSTATS, + D3DQUERYTYPE_EVENT, + D3DQUERYTYPE_OCCLUSION, + D3DQUERYTYPE_TIMESTAMP, + D3DQUERYTYPE_TIMESTAMPDISJOINT, + D3DQUERYTYPE_TIMESTAMPFREQ, + D3DQUERYTYPE_PIPELINETIMINGS, + D3DQUERYTYPE_INTERFACETIMINGS, + D3DQUERYTYPE_VERTEXTIMINGS, + D3DQUERYTYPE_PIXELTIMINGS, + D3DQUERYTYPE_BANDWIDTHTIMINGS, + D3DQUERYTYPE_CACHEUTILIZATION, + }; + IDirect3DQuery9 *query = NULL; + IDirect3DDevice9 *device; + IDirect3D9 *d3d9; + unsigned int i; + ULONG refcount; + BOOL supported; + HWND window; + HRESULT hr; + + if (!(d3d9 = pDirect3DCreate9(D3D_SDK_VERSION))) + { + skip("Failed to create d3d9 object, skipping tests.\n"); + return; + } + + window = CreateWindowA("d3d9_test_wc", "d3d9_test", WS_OVERLAPPEDWINDOW, + 0, 0, 640, 480, 0, 0, 0, 0); + if (!(device = create_device(d3d9, window, window, TRUE))) + { + skip("Failed to create a D3D device, skipping tests.\n"); + IDirect3D9_Release(d3d9); + DestroyWindow(window); + return; + } + + for (i = 0; i < sizeof(queries) / sizeof(*queries); ++i) + { + hr = IDirect3DDevice9_CreateQuery(device, queries[i], NULL); + ok(hr == D3D_OK || hr == D3DERR_NOTAVAILABLE, "Got unexpected hr %#x for query %#x.\n", hr, queries[i]); + + supported = hr == D3D_OK; + + hr = IDirect3DDevice9_CreateQuery(device, queries[i], &query); + ok(hr == D3D_OK || hr == D3DERR_NOTAVAILABLE, "Got unexpected hr %#x for query %#x.\n", hr, queries[i]); + + ok(!supported || query, "Query %#x was claimed to be supported, but can't be created.\n", queries[i]); + ok(supported || !query, "Query %#x was claimed not to be supported, but can be created.\n", queries[i]); + + if (query) + { + IDirect3DQuery9_Release(query); + query = NULL; + } + } + + refcount = IDirect3DDevice9_Release(device); + ok(!refcount, "Device has %u references left.\n", refcount); + IDirect3D9_Release(d3d9); + DestroyWindow(window); +} + +static void test_occlusion_query_states(void) +{ + static const float point[3] = {0.0, 0.0, 0.0}; + IDirect3DQuery9 *query = NULL; + unsigned int data_size, i; + IDirect3DDevice9 *device; + IDirect3D9 *d3d9; + ULONG refcount; + HWND window; + HRESULT hr; + BYTE *data; + + if (!(d3d9 = pDirect3DCreate9(D3D_SDK_VERSION))) + { + skip("Failed to create d3d9 object, skipping tests.\n"); + return; + } + + window = CreateWindowA("d3d9_test_wc", "d3d9_test", WS_OVERLAPPEDWINDOW, + 0, 0, 640, 480, 0, 0, 0, 0); + if (!(device = create_device(d3d9, window, window, TRUE))) + { + skip("Failed to create a D3D device, skipping tests.\n"); + IDirect3D9_Release(d3d9); + DestroyWindow(window); + return; + } + + hr = IDirect3DDevice9_CreateQuery(device, D3DQUERYTYPE_OCCLUSION, &query); + ok(hr == D3D_OK || hr == D3DERR_NOTAVAILABLE, "Got unexpected hr %#x.\n", hr); + if (!query) + { + skip("Occlusion queries are not supported, skipping tests.\n"); + IDirect3DDevice9_Release(device); + IDirect3D9_Release(d3d9); + DestroyWindow(window); + return; + } + + data_size = IDirect3DQuery9_GetDataSize(query); + data = HeapAlloc(GetProcessHeap(), 0, data_size); + + hr = IDirect3DQuery9_GetData(query, NULL, 0, D3DGETDATA_FLUSH); + ok(hr == S_OK, "Got unexpected hr %#x.\n", hr); + hr = IDirect3DQuery9_GetData(query, data, data_size, D3DGETDATA_FLUSH); + ok(hr == S_OK, "Got unexpected hr %#x.\n", hr); + + hr = IDirect3DQuery9_Issue(query, D3DISSUE_END); + ok(hr == D3D_OK, "Got unexpected hr %#x.\n", hr); + hr = IDirect3DQuery9_Issue(query, D3DISSUE_BEGIN); + ok(hr == D3D_OK, "Got unexpected hr %#x.\n", hr); + hr = IDirect3DQuery9_Issue(query, D3DISSUE_BEGIN); + ok(hr == D3D_OK, "Got unexpected hr %#x.\n", hr); + + *((DWORD *)data) = 0x12345678; + hr = IDirect3DQuery9_GetData(query, NULL, 0, D3DGETDATA_FLUSH); + ok(hr == S_FALSE || hr == D3D_OK, "Got unexpected hr %#x.\n", hr); + hr = IDirect3DQuery9_GetData(query, data, data_size, D3DGETDATA_FLUSH); + ok(hr == S_FALSE || hr == D3D_OK, "Got unexpected hr %#x.\n", hr); + if (hr == D3D_OK) + ok(!*(DWORD *)data, "Got unexpected query result %u.\n", *(DWORD *)data); + + hr = IDirect3DDevice9_SetFVF(device, D3DFVF_XYZ); + ok(SUCCEEDED(hr), "Failed to set FVF, hr %#x.\n", hr); + hr = IDirect3DDevice9_BeginScene(device); + ok(SUCCEEDED(hr), "Failed to begin scene, hr %#x.\n", hr); + hr = IDirect3DDevice9_DrawPrimitiveUP(device, D3DPT_POINTLIST, 1, point, 3 * sizeof(float)); + ok(SUCCEEDED(hr), "Failed to draw, hr %#x.\n", hr); + hr = IDirect3DDevice9_EndScene(device); + ok(SUCCEEDED(hr), "Failed to end scene, hr %#x.\n", hr); + + hr = IDirect3DQuery9_Issue(query, D3DISSUE_END); + ok(hr == D3D_OK, "Got unexpected hr %#x.\n", hr); + for (i = 0; i < 500; ++i) + { + if ((hr = IDirect3DQuery9_GetData(query, NULL, 0, D3DGETDATA_FLUSH)) != S_FALSE) + break; + Sleep(10); + } + ok(hr == S_OK, "Got unexpected hr %#x.\n", hr); + + hr = IDirect3DQuery9_GetData(query, data, data_size, D3DGETDATA_FLUSH); + ok(hr == S_OK, "Got unexpected hr %#x.\n", hr); + hr = IDirect3DQuery9_GetData(query, data, data_size, D3DGETDATA_FLUSH); + ok(hr == S_OK, "Got unexpected hr %#x.\n", hr); + + hr = IDirect3DQuery9_Issue(query, D3DISSUE_BEGIN); + ok(hr == D3D_OK, "Got unexpected hr %#x.\n", hr); + hr = IDirect3DQuery9_Issue(query, D3DISSUE_END); + ok(hr == D3D_OK, "Got unexpected hr %#x.\n", hr); + hr = IDirect3DQuery9_Issue(query, D3DISSUE_END); + ok(hr == D3D_OK, "Got unexpected hr %#x.\n", hr); + + HeapFree(GetProcessHeap(), 0, data); + IDirect3DQuery9_Release(query); + refcount = IDirect3DDevice9_Release(device); + ok(!refcount, "Device has %u references left.\n", refcount); + IDirect3D9_Release(d3d9); + DestroyWindow(window); +} + START_TEST(device) { HMODULE d3d9_handle = LoadLibraryA( "d3d9.dll" ); @@ -4030,6 +4201,8 @@ START_TEST(device) test_volume_resource(); test_vb_lock_flags(); test_vertex_buffer_alignment(); + test_query_support(); + test_occlusion_query_states(); } out: diff --git a/dlls/d3d9/tests/query.c b/dlls/d3d9/tests/query.c deleted file mode 100644 index 834f5b3f50..0000000000 --- a/dlls/d3d9/tests/query.c +++ /dev/null @@ -1,291 +0,0 @@ -/* - * Copyright (C) 2006-2007 Stefan Dösinger(For CodeWeavers) - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2.1 of the License, or (at your option) any later version. - * - * This library is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with this library; if not, write to the Free Software - * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA - */ - -#define COBJMACROS -#include -#include "wine/test.h" - -static IDirect3D9 *(WINAPI *pDirect3DCreate9)(UINT); - -struct queryInfo -{ - D3DQUERYTYPE type; /* Query to test */ - BOOL foundSupported; /* If at least one windows driver has been found supporting this query */ - BOOL foundUnsupported; /* If at least one windows driver has been found which does not support this query */ -}; - -/* When running running this test on windows reveals any differences regarding known supported / unsupported queries, - * change this table. - * - * When marking a query known supported or known unsupported please write one card which supports / does not support - * the query. - */ -static struct queryInfo queries[] = -{ - {D3DQUERYTYPE_VCACHE, TRUE /* geforce 6600 */, TRUE /* geforce 2 mx */ }, - {D3DQUERYTYPE_RESOURCEMANAGER, FALSE, TRUE /* geforce 2 mx */ }, - {D3DQUERYTYPE_VERTEXSTATS, FALSE, TRUE /* geforce 2 mx */ }, - {D3DQUERYTYPE_EVENT, TRUE /* geforce 2 mx */, TRUE /* ati mach64 */ }, - {D3DQUERYTYPE_OCCLUSION, TRUE /* radeon M9 */, TRUE /* geforce 2 mx */ }, - {D3DQUERYTYPE_TIMESTAMP, TRUE /* geforce 6600 */, TRUE /* geforce 2 mx */ }, - {D3DQUERYTYPE_TIMESTAMPDISJOINT, TRUE /* geforce 6600 */, TRUE /* geforce 2 mx */ }, - {D3DQUERYTYPE_TIMESTAMPFREQ, TRUE /* geforce 6600 */, TRUE /* geforce 2 mx */ }, - {D3DQUERYTYPE_PIPELINETIMINGS, FALSE, TRUE /* geforce 2 mx */ }, - {D3DQUERYTYPE_INTERFACETIMINGS, FALSE, TRUE /* geforce 2 mx */ }, - {D3DQUERYTYPE_VERTEXTIMINGS, FALSE, TRUE /* geforce 2 mx */ }, - {D3DQUERYTYPE_PIXELTIMINGS, FALSE, TRUE /* geforce 2 mx */ }, - {D3DQUERYTYPE_BANDWIDTHTIMINGS, FALSE, TRUE /* geforce 2 mx */ }, - {D3DQUERYTYPE_CACHEUTILIZATION, FALSE, TRUE /* geforce 2 mx */ }, -}; - -static const char *queryName(D3DQUERYTYPE type) -{ - switch(type) - { - case D3DQUERYTYPE_VCACHE: return "D3DQUERYTYPE_VCACHE"; - case D3DQUERYTYPE_RESOURCEMANAGER: return "D3DQUERYTYPE_RESOURCEMANAGER"; - case D3DQUERYTYPE_VERTEXSTATS: return "D3DQUERYTYPE_VERTEXSTATS"; - case D3DQUERYTYPE_EVENT: return "D3DQUERYTYPE_EVENT"; - case D3DQUERYTYPE_OCCLUSION: return "D3DQUERYTYPE_OCCLUSION"; - case D3DQUERYTYPE_TIMESTAMP: return "D3DQUERYTYPE_TIMESTAMP"; - case D3DQUERYTYPE_TIMESTAMPDISJOINT: return "D3DQUERYTYPE_TIMESTAMPDISJOINT"; - case D3DQUERYTYPE_TIMESTAMPFREQ: return "D3DQUERYTYPE_TIMESTAMPFREQ"; - case D3DQUERYTYPE_PIPELINETIMINGS: return "D3DQUERYTYPE_PIPELINETIMINGS"; - case D3DQUERYTYPE_INTERFACETIMINGS: return "D3DQUERYTYPE_INTERFACETIMINGS"; - case D3DQUERYTYPE_VERTEXTIMINGS: return "D3DQUERYTYPE_VERTEXTIMINGS"; - case D3DQUERYTYPE_PIXELTIMINGS: return "D3DQUERYTYPE_PIXELTIMINGS"; - case D3DQUERYTYPE_BANDWIDTHTIMINGS: return "D3DQUERYTYPE_BANDWIDTHTIMINGS"; - case D3DQUERYTYPE_CACHEUTILIZATION: return "D3DQUERYTYPE_CACHEUTILIZATION"; - default: return "Unexpected query type"; - } -} - -static void test_query_support(IDirect3D9 *pD3d, HWND hwnd) -{ - - HRESULT hr; - - IDirect3DDevice9 *pDevice = NULL; - D3DPRESENT_PARAMETERS d3dpp; - D3DDISPLAYMODE d3ddm; - unsigned int i; - IDirect3DQuery9 *pQuery = NULL; - BOOL supported; - - IDirect3D9_GetAdapterDisplayMode( pD3d, D3DADAPTER_DEFAULT, &d3ddm ); - ZeroMemory( &d3dpp, sizeof(d3dpp) ); - d3dpp.Windowed = TRUE; - d3dpp.SwapEffect = D3DSWAPEFFECT_DISCARD; - d3dpp.BackBufferFormat = d3ddm.Format; - - hr = IDirect3D9_CreateDevice( pD3d, D3DADAPTER_DEFAULT, D3DDEVTYPE_HAL, hwnd, - D3DCREATE_SOFTWARE_VERTEXPROCESSING, &d3dpp, &pDevice ); - ok(SUCCEEDED(hr) || hr == D3DERR_NOTAVAILABLE, "Failed to create IDirect3D9Device (%08x)\n", hr); - if (FAILED(hr)) - { - skip("Failed to create a d3d device\n"); - goto cleanup; - } - - for(i = 0; i < sizeof(queries) / sizeof(queries[0]); i++) - { - hr = IDirect3DDevice9_CreateQuery(pDevice, queries[i].type, NULL); - ok(hr == D3D_OK || hr == D3DERR_NOTAVAILABLE, - "IDirect3DDevice9_CreateQuery returned unexpected return value %08x for query %s\n", hr, queryName(queries[i].type)); - - supported = hr == D3D_OK; - trace("query %s is %s\n", queryName(queries[i].type), supported ? "supported" : "not supported"); - - ok(!supported || queries[i].foundSupported, - "Query %s is supported on this system, but was not found supported before\n", - queryName(queries[i].type)); - ok(supported || queries[i].foundUnsupported, - "Query %s is not supported on this system, but was found to be supported on all other systems tested before\n", - queryName(queries[i].type)); - - hr = IDirect3DDevice9_CreateQuery(pDevice, queries[i].type, &pQuery); - ok(hr == D3D_OK || hr == D3DERR_NOTAVAILABLE, - "IDirect3DDevice9_CreateQuery returned unexpected return value %08x for query %s\n", hr, queryName(queries[i].type)); - ok(!supported || pQuery, "Query %s was claimed to be supported, but can't be created\n", queryName(queries[i].type)); - ok(supported || !pQuery, "Query %s was claimed not to be supported, but can be created\n", queryName(queries[i].type)); - if(pQuery) - { - IDirect3DQuery9_Release(pQuery); - pQuery = NULL; - } - } - -cleanup: - if (pDevice) - { - UINT refcount = IDirect3DDevice9_Release(pDevice); - ok(!refcount, "Device has %u references left.\n", refcount); - } -} - -static void test_occlusion_query_states(IDirect3D9 *pD3d, HWND hwnd) -{ - - HRESULT hr; - - IDirect3DDevice9 *pDevice = NULL; - D3DPRESENT_PARAMETERS d3dpp; - D3DDISPLAYMODE d3ddm; - IDirect3DQuery9 *pQuery = NULL; - BYTE *data = NULL; - float point[3] = {0.0, 0.0, 0.0}; - unsigned int count = 0; - - IDirect3D9_GetAdapterDisplayMode( pD3d, D3DADAPTER_DEFAULT, &d3ddm ); - ZeroMemory( &d3dpp, sizeof(d3dpp) ); - d3dpp.Windowed = TRUE; - d3dpp.SwapEffect = D3DSWAPEFFECT_DISCARD; - d3dpp.BackBufferFormat = d3ddm.Format; - - hr = IDirect3D9_CreateDevice( pD3d, D3DADAPTER_DEFAULT, D3DDEVTYPE_HAL, hwnd, - D3DCREATE_SOFTWARE_VERTEXPROCESSING, &d3dpp, &pDevice ); - ok(SUCCEEDED(hr) || hr == D3DERR_NOTAVAILABLE, "Failed to create IDirect3D9Device (%08x)\n", hr); - if (FAILED(hr)) - { - skip("Failed to create a d3d device\n"); - goto cleanup; - } - - hr = IDirect3DDevice9_CreateQuery(pDevice, D3DQUERYTYPE_OCCLUSION, &pQuery); - ok(hr == D3D_OK || hr == D3DERR_NOTAVAILABLE, - "IDirect3DDevice9_CreateQuery returned unexpected return value %08x\n", hr); - if(!pQuery) { - skip("Occlusion queries not supported\n"); - goto cleanup; - } - - data = HeapAlloc(GetProcessHeap(), 0, IDirect3DQuery9_GetDataSize(pQuery)); - - hr = IDirect3DQuery9_GetData(pQuery, NULL, 0, D3DGETDATA_FLUSH); - ok(hr == S_OK, "IDirect3DQuery9_GetData(NULL) on a new query returned %08x\n", hr); - hr = IDirect3DQuery9_GetData(pQuery, data, IDirect3DQuery9_GetDataSize(pQuery), D3DGETDATA_FLUSH); - ok(hr == S_OK, "IDirect3DQuery9_GetData on a new query returned %08x\n", hr); - - hr = IDirect3DQuery9_Issue(pQuery, D3DISSUE_END); - ok(hr == D3D_OK, "IDirect3DQuery9_Issue(D3DISSUE_END) on a new not yet started query returned %08x\n", hr); - - hr = IDirect3DQuery9_Issue(pQuery, D3DISSUE_BEGIN); - ok(hr == D3D_OK, "IDirect3DQuery9_Issue(D3DISSUE_BEGIN) on a new not yet started query returned %08x\n", hr); - - hr = IDirect3DQuery9_Issue(pQuery, D3DISSUE_BEGIN); - ok(hr == D3D_OK, "IDirect3DQuery9_Issue(D3DQUERY_BEGIN) on a started query returned %08x\n", hr); - - *((DWORD *)data) = 0x12345678; - hr = IDirect3DQuery9_GetData(pQuery, NULL, 0, D3DGETDATA_FLUSH); - ok(hr == S_FALSE || hr == D3D_OK, "IDirect3DQuery9_GetData(NULL) on a started query returned %08x\n", hr); - hr = IDirect3DQuery9_GetData(pQuery, data, IDirect3DQuery9_GetDataSize(pQuery), D3DGETDATA_FLUSH); - ok(hr == S_FALSE || hr == D3D_OK, "IDirect3DQuery9_GetData on a started query returned %08x\n", hr); - if (hr == D3D_OK) - { - DWORD value = *((DWORD *)data); - ok(value == 0, "The unfinished query returned %u, expected 0\n", value); - } - - hr = IDirect3DDevice9_SetFVF(pDevice, D3DFVF_XYZ); - ok(hr == D3D_OK, "IDirect3DDevice9_SetFVF returned %08x\n", hr); - hr = IDirect3DDevice9_BeginScene(pDevice); - ok(hr == D3D_OK, "IDirect3DDevice9_BeginScene returned %08x\n", hr); - if(SUCCEEDED(hr)) { - hr = IDirect3DDevice9_DrawPrimitiveUP(pDevice, D3DPT_POINTLIST, 1, point, 3 * sizeof(float)); - ok(hr == D3D_OK, "IDirect3DDevice9_DrawPrimitiveUP returned %08x\n", hr); - hr = IDirect3DDevice9_EndScene(pDevice); - ok(hr == D3D_OK, "IDirect3DDevice9_EndScene returned %08x\n", hr); - } - - hr = IDirect3DQuery9_Issue(pQuery, D3DISSUE_END); - ok(hr == D3D_OK, "IDirect3DQuery9_Issue(D3DISSUE_END) on a started query returned %08x\n", hr); - - hr = S_FALSE; - while(hr == S_FALSE && count < 500) { - hr = IDirect3DQuery9_GetData(pQuery, NULL, 0, D3DGETDATA_FLUSH); - ok(hr == S_OK || hr == S_FALSE, "IDirect3DQuery9_GetData on a ended query returned %08x\n", hr); - count++; - if(hr == S_FALSE) Sleep(10); - } - ok(hr == S_OK, "Occlusion query did not finish\n"); - - hr = IDirect3DQuery9_GetData(pQuery, data, IDirect3DQuery9_GetDataSize(pQuery), D3DGETDATA_FLUSH); - ok(hr == S_OK, "IDirect3DQuery9_GetData on a ended query returned %08x\n", hr); - hr = IDirect3DQuery9_GetData(pQuery, data, IDirect3DQuery9_GetDataSize(pQuery), D3DGETDATA_FLUSH); - ok(hr == S_OK, "IDirect3DQuery9_GetData a 2nd time on a ended query returned %08x\n", hr); - - hr = IDirect3DQuery9_Issue(pQuery, D3DISSUE_BEGIN); - ok(hr == D3D_OK, "IDirect3DQuery9_Issue(D3DISSUE_BEGIN) on a new not yet started query returned %08x\n", hr); - hr = IDirect3DQuery9_Issue(pQuery, D3DISSUE_END); - ok(hr == D3D_OK, "IDirect3DQuery9_Issue(D3DISSUE_END) on a started query returned %08x\n", hr); - hr = IDirect3DQuery9_Issue(pQuery, D3DISSUE_END); - ok(hr == D3D_OK, "IDirect3DQuery9_Issue(D3DISSUE_END) on a ended query returned %08x\n", hr); - -cleanup: - HeapFree(GetProcessHeap(), 0, data); - if (pQuery) IDirect3DQuery9_Release(pQuery); - if (pDevice) - { - UINT refcount = IDirect3DDevice9_Release(pDevice); - ok(!refcount, "Device has %u references left.\n", refcount); - } -} - -START_TEST(query) -{ - HMODULE d3d9_handle = LoadLibraryA( "d3d9.dll" ); - if (!d3d9_handle) - { - skip("Could not load d3d9.dll\n"); - return; - } - - pDirect3DCreate9 = (void *)GetProcAddress( d3d9_handle, "Direct3DCreate9" ); - ok(pDirect3DCreate9 != NULL, "Failed to get address of Direct3DCreate9\n"); - if (pDirect3DCreate9) - { - IDirect3D9 *pD3d = NULL; - HWND hwnd = NULL; - WNDCLASS wc = {0}; - wc.lpfnWndProc = DefWindowProc; - wc.lpszClassName = "d3d9_test_wc"; - RegisterClass(&wc); - - pD3d = pDirect3DCreate9( D3D_SDK_VERSION ); - if(!pD3d) - { - skip("Failed to create Direct3D9 object, not running tests\n"); - goto out; - } - hwnd = CreateWindow( wc.lpszClassName, "d3d9_test", - WS_SYSMENU | WS_POPUP, 100, 100, 160, 160, NULL, NULL, NULL, NULL ); - if(!hwnd) - { - skip("Failed to create window\n"); - goto out; - } - - test_query_support(pD3d, hwnd); - test_occlusion_query_states(pD3d, hwnd); - - out: - if(pD3d) IDirect3D9_Release(pD3d); - if(hwnd) DestroyWindow(hwnd); - UnregisterClassA(wc.lpszClassName, GetModuleHandleA(NULL)); - } -}