mirror of
https://github.com/reactos/reactos.git
synced 2025-02-22 16:36:33 +00:00
[DXDIAGN_WINETEST]
* Import from Wine 1.7.1. CORE-7469 svn path=/trunk/; revision=60501
This commit is contained in:
parent
0ef60d3d48
commit
2a0449a453
5 changed files with 1215 additions and 0 deletions
|
@ -22,6 +22,7 @@ add_subdirectory(dinput)
|
|||
add_subdirectory(dnsapi)
|
||||
add_subdirectory(dplayx)
|
||||
add_subdirectory(dsound)
|
||||
add_subdirectory(dxdiagn)
|
||||
add_subdirectory(faultrep)
|
||||
add_subdirectory(fusion)
|
||||
add_subdirectory(gdi32)
|
||||
|
|
10
rostests/winetests/dxdiagn/CMakeLists.txt
Normal file
10
rostests/winetests/dxdiagn/CMakeLists.txt
Normal file
|
@ -0,0 +1,10 @@
|
|||
|
||||
list(APPEND SOURCE
|
||||
container.c
|
||||
provider
|
||||
testlist.c)
|
||||
|
||||
add_executable(dxdiagn_winetest ${SOURCE})
|
||||
set_module_type(dxdiagn_winetest win32cui)
|
||||
add_importlibs(dxdiagn_winetest oleaut32 ole32 msvcrt kernel32)
|
||||
add_cd_file(TARGET dxdiagn_winetest DESTINATION reactos/bin FOR all)
|
1030
rostests/winetests/dxdiagn/container.c
Normal file
1030
rostests/winetests/dxdiagn/container.c
Normal file
File diff suppressed because it is too large
Load diff
160
rostests/winetests/dxdiagn/provider.c
Normal file
160
rostests/winetests/dxdiagn/provider.c
Normal file
|
@ -0,0 +1,160 @@
|
|||
/*
|
||||
* Unit tests for IDxDiagProvider
|
||||
*
|
||||
* Copyright (C) 2009 Andrew Nguyen
|
||||
*
|
||||
* 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 <initguid.h>
|
||||
#include <wine/dxdiag.h>
|
||||
#include <wine/test.h>
|
||||
|
||||
static void test_Initialize(void)
|
||||
{
|
||||
HRESULT hr;
|
||||
IDxDiagProvider *pddp;
|
||||
DXDIAG_INIT_PARAMS params;
|
||||
|
||||
hr = CoCreateInstance(&CLSID_DxDiagProvider, NULL, CLSCTX_INPROC_SERVER,
|
||||
&IID_IDxDiagProvider, (LPVOID*)&pddp);
|
||||
ok(hr == S_OK ||
|
||||
broken(hr == REGDB_E_CLASSNOTREG), /* Clean W2K3 */
|
||||
"Creating a IDxDiagProvider instance failed with %x\n", hr);
|
||||
if (FAILED(hr))
|
||||
{
|
||||
skip("Failed to create a IDxDiagProvider instance\n");
|
||||
return;
|
||||
}
|
||||
|
||||
/* Test passing a NULL DXDIAG_INIT_PARAMS pointer. */
|
||||
hr = IDxDiagProvider_Initialize(pddp, NULL);
|
||||
ok(hr == E_POINTER,
|
||||
"Expected IDxDiagProvider::Initialize to return E_POINTER, got %x\n", hr);
|
||||
|
||||
/* Test passing invalid dwSize values. */
|
||||
params.dwSize = 0;
|
||||
hr = IDxDiagProvider_Initialize(pddp, ¶ms);
|
||||
ok(hr == E_INVALIDARG,
|
||||
"Expected IDxDiagProvider::Initialize to return E_INVALIDARG, got %x\n", hr);
|
||||
|
||||
params.dwSize = sizeof(params) + 1;
|
||||
hr = IDxDiagProvider_Initialize(pddp, ¶ms);
|
||||
ok(hr == E_INVALIDARG,
|
||||
"Expected IDxDiagProvider::Initialize to return E_INVALIDARG, got %x\n", hr);
|
||||
|
||||
/* Test passing an unexpected dwDxDiagHeaderVersion value. */
|
||||
params.dwSize = sizeof(params);
|
||||
params.dwDxDiagHeaderVersion = 0;
|
||||
params.bAllowWHQLChecks = FALSE;
|
||||
params.pReserved = NULL;
|
||||
hr = IDxDiagProvider_Initialize(pddp, ¶ms);
|
||||
ok(hr == E_INVALIDARG,
|
||||
"Expected IDxDiagProvider::Initialize to return E_INVALIDARG, got %x\n", hr);
|
||||
|
||||
/* Setting pReserved to a non-NULL value causes a crash on Windows. */
|
||||
if (0)
|
||||
{
|
||||
params.dwDxDiagHeaderVersion = DXDIAG_DX9_SDK_VERSION;
|
||||
params.bAllowWHQLChecks = FALSE;
|
||||
params.pReserved = (VOID*)0xdeadbeef;
|
||||
hr = IDxDiagProvider_Initialize(pddp, ¶ms);
|
||||
trace("IDxDiagProvider::Initialize returned %x\n", hr);
|
||||
}
|
||||
|
||||
/* Test passing an appropriately initialized DXDIAG_INIT_PARAMS. */
|
||||
params.dwDxDiagHeaderVersion = DXDIAG_DX9_SDK_VERSION;
|
||||
params.bAllowWHQLChecks = FALSE;
|
||||
params.pReserved = NULL;
|
||||
hr = IDxDiagProvider_Initialize(pddp, ¶ms);
|
||||
ok(hr == S_OK, "Expected IDxDiagProvider::Initialize to return S_OK, got %x\n", hr);
|
||||
|
||||
/* Test initializing multiple times. */
|
||||
hr = IDxDiagProvider_Initialize(pddp, ¶ms);
|
||||
ok(hr == S_OK, "Expected IDxDiagProvider::Initialize to return S_OK, got %x\n", hr);
|
||||
|
||||
IDxDiagProvider_Release(pddp);
|
||||
}
|
||||
|
||||
static void test_GetRootContainer(void)
|
||||
{
|
||||
HRESULT hr;
|
||||
IDxDiagProvider *pddp;
|
||||
IDxDiagContainer *pddc, *pddc2;
|
||||
DXDIAG_INIT_PARAMS params;
|
||||
|
||||
hr = CoCreateInstance(&CLSID_DxDiagProvider, NULL, CLSCTX_INPROC_SERVER,
|
||||
&IID_IDxDiagProvider, (LPVOID*)&pddp);
|
||||
ok(hr == S_OK ||
|
||||
broken(hr == REGDB_E_CLASSNOTREG), /* Clean W2K3 */
|
||||
"Creating a IDxDiagProvider instance failed with %x\n", hr);
|
||||
if (FAILED(hr))
|
||||
{
|
||||
skip("Failed to create a IDxDiagProvider instance\n");
|
||||
return;
|
||||
}
|
||||
|
||||
/* Test calling IDxDiagProvider::GetRootContainer before initialization. */
|
||||
hr = IDxDiagProvider_GetRootContainer(pddp, NULL);
|
||||
ok(hr == CO_E_NOTINITIALIZED,
|
||||
"Expected IDxDiagProvider::GetRootContainer to return CO_E_NOTINITIALIZED, got %x\n", hr);
|
||||
|
||||
hr = IDxDiagProvider_GetRootContainer(pddp, &pddc);
|
||||
ok(hr == CO_E_NOTINITIALIZED,
|
||||
"Expected IDxDiagProvider::GetRootContainer to return CO_E_NOTINITIALIZED, got %x\n", hr);
|
||||
|
||||
params.dwSize = sizeof(params);
|
||||
params.dwDxDiagHeaderVersion = DXDIAG_DX9_SDK_VERSION;
|
||||
params.bAllowWHQLChecks = FALSE;
|
||||
params.pReserved = NULL;
|
||||
hr = IDxDiagProvider_Initialize(pddp, ¶ms);
|
||||
ok(hr == S_OK, "Expected IDxDiagProvider::Initialize to return S_OK, got %x\n", hr);
|
||||
if (FAILED(hr))
|
||||
{
|
||||
skip("IDxDiagProvider::Initialize failed\n");
|
||||
IDxDiagProvider_Release(pddp);
|
||||
return;
|
||||
}
|
||||
|
||||
/* Passing NULL causes a crash on Windows. */
|
||||
if (0)
|
||||
{
|
||||
hr = IDxDiagProvider_GetRootContainer(pddp, NULL);
|
||||
trace("IDxDiagProvider::GetRootContainer returned %x\n", hr);
|
||||
}
|
||||
|
||||
hr = IDxDiagProvider_GetRootContainer(pddp, &pddc);
|
||||
ok(hr == S_OK, "Expected IDxDiagProvider::GetRootContainer to return S_OK, got %x\n", hr);
|
||||
|
||||
/* IDxDiagProvider::GetRootContainer creates new instances of the root
|
||||
* container rather than maintain a static root container. */
|
||||
hr = IDxDiagProvider_GetRootContainer(pddp, &pddc2);
|
||||
ok(hr == S_OK, "Expected IDxDiagProvider::GetRootContainer to return S_OK, got %x\n", hr);
|
||||
ok(pddc != pddc2, "Expected the two pointers (%p vs. %p) to be unequal\n", pddc, pddc2);
|
||||
|
||||
IDxDiagContainer_Release(pddc2);
|
||||
IDxDiagContainer_Release(pddc);
|
||||
IDxDiagProvider_Release(pddp);
|
||||
}
|
||||
|
||||
START_TEST(provider)
|
||||
{
|
||||
CoInitialize(NULL);
|
||||
test_Initialize();
|
||||
test_GetRootContainer();
|
||||
CoUninitialize();
|
||||
}
|
14
rostests/winetests/dxdiagn/testlist.c
Normal file
14
rostests/winetests/dxdiagn/testlist.c
Normal file
|
@ -0,0 +1,14 @@
|
|||
/* Automatically generated file; DO NOT EDIT!! */
|
||||
|
||||
#define STANDALONE
|
||||
#include <wine/test.h>
|
||||
|
||||
extern void func_container(void);
|
||||
extern void func_provider(void);
|
||||
|
||||
const struct test winetest_testlist[] =
|
||||
{
|
||||
{ "container", func_container },
|
||||
{ "provider", func_provider },
|
||||
{ 0, 0 }
|
||||
};
|
Loading…
Reference in a new issue