dplay: Directplay should initialize session Guid, with conformance tests.
This commit is contained in:
parent
5c9edfd4be
commit
d1331e62ca
|
@ -213,6 +213,9 @@ dlls/dnsapi/tests/testlist.c
|
||||||
dlls/dplay/libdplay.def
|
dlls/dplay/libdplay.def
|
||||||
dlls/dplay/version.res
|
dlls/dplay/version.res
|
||||||
dlls/dplayx/libdplayx.def
|
dlls/dplayx/libdplayx.def
|
||||||
|
dlls/dplayx/tests/*.ok
|
||||||
|
dlls/dplayx/tests/dplayx_crosstest.exe
|
||||||
|
dlls/dplayx/tests/testlist.c
|
||||||
dlls/dplayx/version.res
|
dlls/dplayx/version.res
|
||||||
dlls/dpnet/libdpnet.def
|
dlls/dpnet/libdpnet.def
|
||||||
dlls/dpnet/version.res
|
dlls/dpnet/version.res
|
||||||
|
@ -803,6 +806,7 @@ programs/winetest/d3d9_test.exe
|
||||||
programs/winetest/ddraw_test.exe
|
programs/winetest/ddraw_test.exe
|
||||||
programs/winetest/dinput_test.exe
|
programs/winetest/dinput_test.exe
|
||||||
programs/winetest/dnsapi_test.exe
|
programs/winetest/dnsapi_test.exe
|
||||||
|
programs/winetest/dplayx_test.exe
|
||||||
programs/winetest/dsound_test.exe
|
programs/winetest/dsound_test.exe
|
||||||
programs/winetest/gdi32_test.exe
|
programs/winetest/gdi32_test.exe
|
||||||
programs/winetest/hlink_test.exe
|
programs/winetest/hlink_test.exe
|
||||||
|
|
|
@ -216,6 +216,7 @@ ALL_MAKEFILES = \
|
||||||
dlls/dnsapi/tests/Makefile \
|
dlls/dnsapi/tests/Makefile \
|
||||||
dlls/dplay/Makefile \
|
dlls/dplay/Makefile \
|
||||||
dlls/dplayx/Makefile \
|
dlls/dplayx/Makefile \
|
||||||
|
dlls/dplayx/tests/Makefile \
|
||||||
dlls/dpnet/Makefile \
|
dlls/dpnet/Makefile \
|
||||||
dlls/dpnhpast/Makefile \
|
dlls/dpnhpast/Makefile \
|
||||||
dlls/dsound/Makefile \
|
dlls/dsound/Makefile \
|
||||||
|
@ -549,6 +550,7 @@ dlls/dnsapi/Makefile: dlls/dnsapi/Makefile.in dlls/Makedll.rules
|
||||||
dlls/dnsapi/tests/Makefile: dlls/dnsapi/tests/Makefile.in dlls/Maketest.rules
|
dlls/dnsapi/tests/Makefile: dlls/dnsapi/tests/Makefile.in dlls/Maketest.rules
|
||||||
dlls/dplay/Makefile: dlls/dplay/Makefile.in dlls/Makedll.rules
|
dlls/dplay/Makefile: dlls/dplay/Makefile.in dlls/Makedll.rules
|
||||||
dlls/dplayx/Makefile: dlls/dplayx/Makefile.in dlls/Makedll.rules
|
dlls/dplayx/Makefile: dlls/dplayx/Makefile.in dlls/Makedll.rules
|
||||||
|
dlls/dplayx/tests/Makefile: dlls/dplayx/tests/Makefile.in dlls/Maketest.rules
|
||||||
dlls/dpnet/Makefile: dlls/dpnet/Makefile.in dlls/Makedll.rules
|
dlls/dpnet/Makefile: dlls/dpnet/Makefile.in dlls/Makedll.rules
|
||||||
dlls/dpnhpast/Makefile: dlls/dpnhpast/Makefile.in dlls/Makedll.rules
|
dlls/dpnhpast/Makefile: dlls/dpnhpast/Makefile.in dlls/Makedll.rules
|
||||||
dlls/dsound/Makefile: dlls/dsound/Makefile.in dlls/Makedll.rules
|
dlls/dsound/Makefile: dlls/dsound/Makefile.in dlls/Makedll.rules
|
||||||
|
|
|
@ -20563,6 +20563,8 @@ ac_config_files="$ac_config_files dlls/dplay/Makefile"
|
||||||
|
|
||||||
ac_config_files="$ac_config_files dlls/dplayx/Makefile"
|
ac_config_files="$ac_config_files dlls/dplayx/Makefile"
|
||||||
|
|
||||||
|
ac_config_files="$ac_config_files dlls/dplayx/tests/Makefile"
|
||||||
|
|
||||||
ac_config_files="$ac_config_files dlls/dpnet/Makefile"
|
ac_config_files="$ac_config_files dlls/dpnet/Makefile"
|
||||||
|
|
||||||
ac_config_files="$ac_config_files dlls/dpnhpast/Makefile"
|
ac_config_files="$ac_config_files dlls/dpnhpast/Makefile"
|
||||||
|
@ -21709,6 +21711,7 @@ do
|
||||||
"dlls/dnsapi/tests/Makefile") CONFIG_FILES="$CONFIG_FILES dlls/dnsapi/tests/Makefile" ;;
|
"dlls/dnsapi/tests/Makefile") CONFIG_FILES="$CONFIG_FILES dlls/dnsapi/tests/Makefile" ;;
|
||||||
"dlls/dplay/Makefile") CONFIG_FILES="$CONFIG_FILES dlls/dplay/Makefile" ;;
|
"dlls/dplay/Makefile") CONFIG_FILES="$CONFIG_FILES dlls/dplay/Makefile" ;;
|
||||||
"dlls/dplayx/Makefile") CONFIG_FILES="$CONFIG_FILES dlls/dplayx/Makefile" ;;
|
"dlls/dplayx/Makefile") CONFIG_FILES="$CONFIG_FILES dlls/dplayx/Makefile" ;;
|
||||||
|
"dlls/dplayx/tests/Makefile") CONFIG_FILES="$CONFIG_FILES dlls/dplayx/tests/Makefile" ;;
|
||||||
"dlls/dpnet/Makefile") CONFIG_FILES="$CONFIG_FILES dlls/dpnet/Makefile" ;;
|
"dlls/dpnet/Makefile") CONFIG_FILES="$CONFIG_FILES dlls/dpnet/Makefile" ;;
|
||||||
"dlls/dpnhpast/Makefile") CONFIG_FILES="$CONFIG_FILES dlls/dpnhpast/Makefile" ;;
|
"dlls/dpnhpast/Makefile") CONFIG_FILES="$CONFIG_FILES dlls/dpnhpast/Makefile" ;;
|
||||||
"dlls/dsound/Makefile") CONFIG_FILES="$CONFIG_FILES dlls/dsound/Makefile" ;;
|
"dlls/dsound/Makefile") CONFIG_FILES="$CONFIG_FILES dlls/dsound/Makefile" ;;
|
||||||
|
|
|
@ -1586,6 +1586,7 @@ AC_CONFIG_FILES([dlls/dnsapi/Makefile])
|
||||||
AC_CONFIG_FILES([dlls/dnsapi/tests/Makefile])
|
AC_CONFIG_FILES([dlls/dnsapi/tests/Makefile])
|
||||||
AC_CONFIG_FILES([dlls/dplay/Makefile])
|
AC_CONFIG_FILES([dlls/dplay/Makefile])
|
||||||
AC_CONFIG_FILES([dlls/dplayx/Makefile])
|
AC_CONFIG_FILES([dlls/dplayx/Makefile])
|
||||||
|
AC_CONFIG_FILES([dlls/dplayx/tests/Makefile])
|
||||||
AC_CONFIG_FILES([dlls/dpnet/Makefile])
|
AC_CONFIG_FILES([dlls/dpnet/Makefile])
|
||||||
AC_CONFIG_FILES([dlls/dpnhpast/Makefile])
|
AC_CONFIG_FILES([dlls/dpnhpast/Makefile])
|
||||||
AC_CONFIG_FILES([dlls/dsound/Makefile])
|
AC_CONFIG_FILES([dlls/dsound/Makefile])
|
||||||
|
|
|
@ -233,6 +233,7 @@ TESTSUBDIRS = \
|
||||||
ddraw/tests \
|
ddraw/tests \
|
||||||
dinput/tests \
|
dinput/tests \
|
||||||
dnsapi/tests \
|
dnsapi/tests \
|
||||||
|
dplayx/tests \
|
||||||
dsound/tests \
|
dsound/tests \
|
||||||
gdi32/tests \
|
gdi32/tests \
|
||||||
hlink/tests \
|
hlink/tests \
|
||||||
|
|
|
@ -3244,7 +3244,11 @@ static HRESULT WINAPI DP_SetSessionDesc
|
||||||
HeapFree( GetProcessHeap(), 0, This->dp2->lpSessionDesc );
|
HeapFree( GetProcessHeap(), 0, This->dp2->lpSessionDesc );
|
||||||
|
|
||||||
This->dp2->lpSessionDesc = lpTempSessDesc;
|
This->dp2->lpSessionDesc = lpTempSessDesc;
|
||||||
|
if( bInitial )
|
||||||
|
{
|
||||||
|
/*Initializing session GUID*/
|
||||||
|
CoCreateGuid( &(This->dp2->lpSessionDesc->guidInstance) );
|
||||||
|
}
|
||||||
/* Set the new */
|
/* Set the new */
|
||||||
DP_CopySessionDesc( This->dp2->lpSessionDesc, lpSessDesc, bAnsi );
|
DP_CopySessionDesc( This->dp2->lpSessionDesc, lpSessDesc, bAnsi );
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,14 @@
|
||||||
|
TOPSRCDIR = @top_srcdir@
|
||||||
|
TOPOBJDIR = ../../..
|
||||||
|
SRCDIR = @srcdir@
|
||||||
|
VPATH = @srcdir@
|
||||||
|
TESTDLL = dplayx.dll
|
||||||
|
IMPORTS = ole32 kernel32
|
||||||
|
EXTRALIBS = -ldxguid
|
||||||
|
|
||||||
|
CTESTS = \
|
||||||
|
dplayx.c
|
||||||
|
|
||||||
|
@MAKE_TEST_RULES@
|
||||||
|
|
||||||
|
@DEPENDENCIES@ # everything below this line is overwritten by make depend
|
|
@ -0,0 +1,89 @@
|
||||||
|
/* DirectPlay Conformance Tests
|
||||||
|
*
|
||||||
|
* Copyright 2007 - Alessandro Pignotti
|
||||||
|
*
|
||||||
|
* 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
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "wine/test.h"
|
||||||
|
#include <dplay.h>
|
||||||
|
|
||||||
|
static BOOL validSP = FALSE; /*This global variable is needed until wine has a working service provider
|
||||||
|
implementation*/
|
||||||
|
|
||||||
|
static BOOL CALLBACK EnumConnectionsCallback(LPCGUID lpguidSP, LPVOID lpConnection,
|
||||||
|
DWORD dwConnectionSize, LPCDPNAME lpName, DWORD dwFlags, LPVOID lpContext)
|
||||||
|
{
|
||||||
|
HRESULT hr;
|
||||||
|
|
||||||
|
if(IsEqualGUID(lpguidSP,&DPSPGUID_TCPIP))
|
||||||
|
{
|
||||||
|
/*I'm forcing TCP/IP Sevice provider*/
|
||||||
|
hr = IDirectPlayX_InitializeConnection((LPDIRECTPLAY4) lpContext, lpConnection, 0);
|
||||||
|
todo_wine ok( SUCCEEDED( hr ), "It's not possible to initialize TCP/IP service provider\n");
|
||||||
|
if( SUCCEEDED( hr ))
|
||||||
|
validSP = TRUE;
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void test_session_guid(LPDIRECTPLAY4 pDP)
|
||||||
|
{
|
||||||
|
GUID appGuid;
|
||||||
|
GUID zeroGuid;
|
||||||
|
DPSESSIONDESC2 sessionDesc;
|
||||||
|
LPDPSESSIONDESC2 newSession;
|
||||||
|
DWORD sessionSize;
|
||||||
|
static char name[] = "DPlay conformance test";
|
||||||
|
|
||||||
|
CoCreateGuid( &appGuid );
|
||||||
|
IDirectPlayX_EnumConnections(pDP, &appGuid, EnumConnectionsCallback, pDP, 0);
|
||||||
|
if( validSP )
|
||||||
|
{
|
||||||
|
memset(&sessionDesc, 0, sizeof( DPSESSIONDESC2 ));
|
||||||
|
memset(&zeroGuid, 0, 16);
|
||||||
|
|
||||||
|
sessionDesc.dwSize = sizeof( DPSESSIONDESC2 );
|
||||||
|
memcpy(&sessionDesc.guidApplication, &appGuid, 16);
|
||||||
|
sessionDesc.dwFlags = DPSESSION_CLIENTSERVER;
|
||||||
|
sessionDesc.lpszSessionNameA = name;
|
||||||
|
sessionDesc.dwMaxPlayers = 10;
|
||||||
|
sessionDesc.dwCurrentPlayers = 0;
|
||||||
|
IDirectPlayX_Open(pDP, &sessionDesc, DPOPEN_CREATE);
|
||||||
|
/* I read the sessiondesc from directplay in a fresh memory location,
|
||||||
|
because directplay does not touch the original struct, but saves
|
||||||
|
internally a version with the session guid set*/
|
||||||
|
IDirectPlayX_GetSessionDesc(pDP, NULL, &sessionSize);
|
||||||
|
newSession=HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, sessionSize);
|
||||||
|
IDirectPlayX_GetSessionDesc(pDP, newSession, &sessionSize);
|
||||||
|
todo_wine ok( !IsEqualGUID(&newSession->guidInstance, &zeroGuid), "Session guid not initialized");
|
||||||
|
HeapFree(GetProcessHeap(), 0, newSession);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
START_TEST(dplayx)
|
||||||
|
{
|
||||||
|
LPDIRECTPLAY4 pDP;
|
||||||
|
|
||||||
|
CoInitialize( NULL );
|
||||||
|
CoCreateInstance(&CLSID_DirectPlay, NULL, CLSCTX_ALL, &IID_IDirectPlay4A, (VOID**)&pDP);
|
||||||
|
|
||||||
|
test_session_guid( pDP );
|
||||||
|
|
||||||
|
IDirectPlayX_Release( pDP );
|
||||||
|
CoUninitialize();
|
||||||
|
}
|
|
@ -36,6 +36,7 @@ TESTBINS = \
|
||||||
ddraw_test.exe \
|
ddraw_test.exe \
|
||||||
dinput_test.exe \
|
dinput_test.exe \
|
||||||
dnsapi_test.exe \
|
dnsapi_test.exe \
|
||||||
|
dplayx_test.exe \
|
||||||
dsound_test.exe \
|
dsound_test.exe \
|
||||||
gdi32_test.exe \
|
gdi32_test.exe \
|
||||||
hlink_test.exe \
|
hlink_test.exe \
|
||||||
|
@ -109,6 +110,8 @@ dinput_test.exe: $(DLLDIR)/dinput/tests/dinput_test.exe$(DLLEXT)
|
||||||
cp $(DLLDIR)/dinput/tests/dinput_test.exe$(DLLEXT) $@ && $(STRIP) $@
|
cp $(DLLDIR)/dinput/tests/dinput_test.exe$(DLLEXT) $@ && $(STRIP) $@
|
||||||
dnsapi_test.exe: $(DLLDIR)/dnsapi/tests/dnsapi_test.exe$(DLLEXT)
|
dnsapi_test.exe: $(DLLDIR)/dnsapi/tests/dnsapi_test.exe$(DLLEXT)
|
||||||
cp $(DLLDIR)/dnsapi/tests/dnsapi_test.exe$(DLLEXT) $@ && $(STRIP) $@
|
cp $(DLLDIR)/dnsapi/tests/dnsapi_test.exe$(DLLEXT) $@ && $(STRIP) $@
|
||||||
|
dplayx_test.exe: $(DLLDIR)/dplayx/tests/dplayx_test.exe$(DLLEXT)
|
||||||
|
cp $(DLLDIR)/dplayx/tests/dplayx_test.exe$(DLLEXT) $@ && $(STRIP) $@
|
||||||
dsound_test.exe: $(DLLDIR)/dsound/tests/dsound_test.exe$(DLLEXT)
|
dsound_test.exe: $(DLLDIR)/dsound/tests/dsound_test.exe$(DLLEXT)
|
||||||
cp $(DLLDIR)/dsound/tests/dsound_test.exe$(DLLEXT) $@ && $(STRIP) $@
|
cp $(DLLDIR)/dsound/tests/dsound_test.exe$(DLLEXT) $@ && $(STRIP) $@
|
||||||
gdi32_test.exe: $(DLLDIR)/gdi32/tests/gdi32_test.exe$(DLLEXT)
|
gdi32_test.exe: $(DLLDIR)/gdi32/tests/gdi32_test.exe$(DLLEXT)
|
||||||
|
|
|
@ -159,6 +159,7 @@ d3d9_test.exe TESTRES "d3d9_test.exe"
|
||||||
ddraw_test.exe TESTRES "ddraw_test.exe"
|
ddraw_test.exe TESTRES "ddraw_test.exe"
|
||||||
dinput_test.exe TESTRES "dinput_test.exe"
|
dinput_test.exe TESTRES "dinput_test.exe"
|
||||||
dnsapi_test.exe TESTRES "dnsapi_test.exe"
|
dnsapi_test.exe TESTRES "dnsapi_test.exe"
|
||||||
|
dplayx_test.exe TESTRES "dplayx_test.exe"
|
||||||
dsound_test.exe TESTRES "dsound_test.exe"
|
dsound_test.exe TESTRES "dsound_test.exe"
|
||||||
gdi32_test.exe TESTRES "gdi32_test.exe"
|
gdi32_test.exe TESTRES "gdi32_test.exe"
|
||||||
hlink_test.exe TESTRES "hlink_test.exe"
|
hlink_test.exe TESTRES "hlink_test.exe"
|
||||||
|
|
Loading…
Reference in New Issue