[1/4] dpnet/tests: Merge peer.c into client.c.

Hans Leidekker hans at codeweavers.com
Fri Dec 9 11:03:03 CST 2016


Signed-off-by: Hans Leidekker <hans at codeweavers.com>
---
 dlls/dpnet/tests/Makefile.in |   1 -
 dlls/dpnet/tests/client.c    | 269 ++++++++++++++++++++++++++++++++++++-
 dlls/dpnet/tests/peer.c      | 312 -------------------------------------------
 3 files changed, 268 insertions(+), 314 deletions(-)
 delete mode 100644 dlls/dpnet/tests/peer.c

diff --git a/dlls/dpnet/tests/Makefile.in b/dlls/dpnet/tests/Makefile.in
index f6e45ea..13eae44 100644
--- a/dlls/dpnet/tests/Makefile.in
+++ b/dlls/dpnet/tests/Makefile.in
@@ -4,5 +4,4 @@ IMPORTS   = dxguid uuid dpnet ole32
 C_SRCS = \
 	address.c \
 	client.c \
-	peer.c \
 	server.c
diff --git a/dlls/dpnet/tests/client.c b/dlls/dpnet/tests/client.c
index 4753d74..68b3832 100644
--- a/dlls/dpnet/tests/client.c
+++ b/dlls/dpnet/tests/client.c
@@ -24,7 +24,7 @@
 #include <dplobby8.h>
 #include "wine/test.h"
 
-
+static IDirectPlay8Peer* peer = NULL;
 static IDirectPlay8Client* client = NULL;
 static IDirectPlay8LobbiedApplication* lobbied = NULL;
 static const GUID appguid = { 0xcd0c3d4b, 0xe15e, 0x4cf2, { 0x9e, 0xa8, 0x6e, 0x1d, 0x65, 0x48, 0xc5, 0xa5 } };
@@ -346,6 +346,266 @@ static void test_close(void)
     IDirectPlay8Client_Release(client2);
 }
 
+static void test_init_dp_peer(void)
+{
+    HRESULT hr;
+    DPN_SP_CAPS caps;
+    DPNHANDLE lobbyConnection;
+
+    hr = CoInitialize(0);
+    ok(hr == S_OK, "CoInitialize failed with %x\n", hr);
+
+    hr = CoCreateInstance(&CLSID_DirectPlay8Peer, NULL, CLSCTX_INPROC_SERVER, &IID_IDirectPlay8Peer, (void **)&peer);
+    ok(hr == S_OK, "CoCreateInstance failed with 0x%x\n", hr);
+
+    memset(&caps, 0, sizeof(DPN_SP_CAPS));
+    caps.dwSize = sizeof(DPN_SP_CAPS);
+
+    hr = IDirectPlay8Peer_GetSPCaps(peer, &CLSID_DP8SP_TCPIP, &caps, 0);
+    ok(hr == DPNERR_UNINITIALIZED, "GetSPCaps failed with %x\n", hr);
+
+    hr = IDirectPlay8Peer_Initialize(peer, NULL, NULL, 0);
+    ok(hr == DPNERR_INVALIDPARAM, "got %x\n", hr);
+
+    hr = IDirectPlay8Peer_Initialize(peer, NULL, DirectPlayMessageHandler, 0);
+    ok(hr == S_OK, "IDirectPlay8Peer_Initialize failed with %x\n", hr);
+
+    hr = CoCreateInstance(&CLSID_DirectPlay8LobbiedApplication, NULL, CLSCTX_INPROC_SERVER,
+                          &IID_IDirectPlay8LobbiedApplication, (void **)&lobbied);
+    ok(hr == S_OK, "CoCreateInstance failed with 0x%x\n", hr);
+
+    hr = IDirectPlay8LobbiedApplication_Initialize(lobbied, NULL, NULL,
+                                                &lobbyConnection, 0);
+    ok(hr == DPNERR_INVALIDPOINTER, "Failed with %x\n", hr);
+
+    hr = IDirectPlay8LobbiedApplication_Initialize(lobbied, NULL, DirectPlayLobbyMessageHandler,
+                                                &lobbyConnection, 0);
+    ok(hr == S_OK, "IDirectPlay8LobbiedApplication_Initialize failed with %x\n", hr);
+}
+
+static void test_enum_service_providers_peer(void)
+{
+    DPN_SERVICE_PROVIDER_INFO *serv_prov_info;
+    DWORD items, size;
+    DWORD i;
+    HRESULT hr;
+
+    size = 0;
+    items = 0;
+
+    hr = IDirectPlay8Peer_EnumServiceProviders(peer, NULL, NULL, NULL, &size, NULL, 0);
+    ok(hr == E_POINTER, "IDirectPlay8Peer_EnumServiceProviders failed with %x\n", hr);
+
+    hr = IDirectPlay8Peer_EnumServiceProviders(peer, NULL, NULL, NULL, NULL, &items, 0);
+    ok(hr == E_POINTER, "IDirectPlay8Peer_EnumServiceProviders failed with %x\n", hr);
+
+    hr = IDirectPlay8Peer_EnumServiceProviders(peer, NULL, NULL, NULL, &size, &items, 0);
+    ok(hr == DPNERR_BUFFERTOOSMALL, "IDirectPlay8Peer_EnumServiceProviders failed with %x\n", hr);
+    ok(size != 0, "size is unexpectedly 0\n");
+
+    serv_prov_info = HeapAlloc(GetProcessHeap(), 0, size);
+
+    hr = IDirectPlay8Peer_EnumServiceProviders(peer, NULL, NULL, serv_prov_info, &size, &items, 0);
+    ok(hr == S_OK, "IDirectPlay8Peer_EnumServiceProviders failed with %x\n", hr);
+    ok(items != 0, "Found unexpectedly no service providers\n");
+
+    trace("number of items found: %d\n", items);
+
+    for (i=0;i<items;i++)
+    {
+        trace("Found Service Provider: %s\n", wine_dbgstr_w(serv_prov_info->pwszName));
+        trace("Found guid: %s\n", wine_dbgstr_guid(&serv_prov_info->guid));
+
+        serv_prov_info++;
+    }
+
+    serv_prov_info -= items; /* set pointer back */
+    ok(HeapFree(GetProcessHeap(), 0, serv_prov_info), "Failed freeing server provider info\n");
+
+    size = 0;
+    items = 0;
+
+    hr = IDirectPlay8Peer_EnumServiceProviders(peer, &CLSID_DP8SP_TCPIP, NULL, NULL, &size, &items, 0);
+    ok(hr == DPNERR_BUFFERTOOSMALL, "IDirectPlay8Peer_EnumServiceProviders failed with %x\n", hr);
+    ok(size != 0, "size is unexpectedly 0\n");
+
+    serv_prov_info = HeapAlloc(GetProcessHeap(), 0, size);
+
+    hr = IDirectPlay8Peer_EnumServiceProviders(peer, &CLSID_DP8SP_TCPIP, NULL, serv_prov_info, &size, &items, 0);
+    ok(hr == S_OK, "IDirectPlay8Peer_EnumServiceProviders failed with %x\n", hr);
+    ok(items != 0, "Found unexpectedly no adapter\n");
+
+
+    for (i=0;i<items;i++)
+    {
+        trace("Found adapter: %s\n", wine_dbgstr_w(serv_prov_info->pwszName));
+        trace("Found adapter guid: %s\n", wine_dbgstr_guid(&serv_prov_info->guid));
+
+        serv_prov_info++;
+    }
+
+    serv_prov_info -= items; /* set pointer back */
+    ok(HeapFree(GetProcessHeap(), 0, serv_prov_info), "Failed freeing server provider info\n");
+}
+
+static void test_enum_hosts_peer(void)
+{
+    HRESULT hr;
+    IDirectPlay8Address *host = NULL;
+    IDirectPlay8Address *local = NULL;
+    DPN_APPLICATION_DESC appdesc;
+    DPNHANDLE async = 0;
+    static const WCHAR localhost[] = {'1','2','7','.','0','.','0','.','1',0};
+
+    memset( &appdesc, 0, sizeof(DPN_APPLICATION_DESC) );
+    appdesc.dwSize  = sizeof( DPN_APPLICATION_DESC );
+    appdesc.guidApplication  = appguid;
+
+    hr = CoCreateInstance( &CLSID_DirectPlay8Address, NULL, CLSCTX_ALL, &IID_IDirectPlay8Address, (LPVOID*)&local);
+    ok(hr == S_OK, "IDirectPlay8Address failed with 0x%08x\n", hr);
+
+    hr = IDirectPlay8Address_SetSP(local, &CLSID_DP8SP_TCPIP);
+    ok(hr == S_OK, "IDirectPlay8Address_SetSP failed with 0x%08x\n", hr);
+
+    hr = CoCreateInstance( &CLSID_DirectPlay8Address, NULL, CLSCTX_ALL, &IID_IDirectPlay8Address, (LPVOID*)&host);
+    ok(hr == S_OK, "IDirectPlay8Address failed with 0x%08x\n", hr);
+
+    hr = IDirectPlay8Address_SetSP(host, &CLSID_DP8SP_TCPIP);
+    ok(hr == S_OK, "IDirectPlay8Address_SetSP failed with 0x%08x\n", hr);
+
+    hr = IDirectPlay8Address_AddComponent(host, DPNA_KEY_HOSTNAME, localhost, sizeof(localhost),
+                                                         DPNA_DATATYPE_STRING);
+    ok(hr == S_OK, "IDirectPlay8Address failed with 0x%08x\n", hr);
+
+    hr = IDirectPlay8Peer_EnumHosts(peer, &appdesc, host, local, NULL, 0, INFINITE, 0, INFINITE, NULL,  &async, 0);
+    todo_wine ok(hr == DPNSUCCESS_PENDING, "IDirectPlay8Peer_EnumServiceProviders failed with 0x%08x\n", hr);
+    todo_wine ok(async, "No Handle returned\n");
+
+    hr = IDirectPlay8Peer_CancelAsyncOperation(peer, async, 0);
+    todo_wine ok(hr == S_OK, "IDirectPlay8Peer_CancelAsyncOperation failed with 0x%08x\n", hr);
+
+    IDirectPlay8Address_Release(local);
+    IDirectPlay8Address_Release(host);
+}
+
+static void test_get_sp_caps_peer(void)
+{
+    DPN_SP_CAPS caps;
+    HRESULT hr;
+
+    memset(&caps, 0, sizeof(DPN_SP_CAPS));
+
+    hr = IDirectPlay8Peer_GetSPCaps(peer, &CLSID_DP8SP_TCPIP, &caps, 0);
+    ok(hr == DPNERR_INVALIDPARAM, "GetSPCaps unexpectedly returned %x\n", hr);
+
+    caps.dwSize = sizeof(DPN_SP_CAPS);
+
+    hr = IDirectPlay8Peer_GetSPCaps(peer, &CLSID_DP8SP_TCPIP, &caps, 0);
+    ok(hr == DPN_OK, "GetSPCaps failed with %x\n", hr);
+
+    ok(caps.dwSize == sizeof(DPN_SP_CAPS), "got %d\n", caps.dwSize);
+    ok((caps.dwFlags &
+        (DPNSPCAPS_SUPPORTSDPNSRV | DPNSPCAPS_SUPPORTSBROADCAST | DPNSPCAPS_SUPPORTSALLADAPTERS)) ==
+       (DPNSPCAPS_SUPPORTSDPNSRV | DPNSPCAPS_SUPPORTSBROADCAST | DPNSPCAPS_SUPPORTSALLADAPTERS),
+       "unexpected flags %x\n", caps.dwFlags);
+    ok(caps.dwNumThreads >= 3, "got %d\n", caps.dwNumThreads);
+    ok(caps.dwDefaultEnumCount == 5, "expected 5, got %d\n", caps.dwDefaultEnumCount);
+    ok(caps.dwDefaultEnumRetryInterval == 1500, "expected 1500, got %d\n", caps.dwDefaultEnumRetryInterval);
+    ok(caps.dwDefaultEnumTimeout == 1500, "expected 1500, got %d\n", caps.dwDefaultEnumTimeout);
+    ok(caps.dwMaxEnumPayloadSize == 983, "expected 983, got %d\n", caps.dwMaxEnumPayloadSize);
+    ok(caps.dwBuffersPerThread == 1, "expected 1, got %d\n", caps.dwBuffersPerThread);
+    ok(caps.dwSystemBufferSize == 0x10000 || broken(caps.dwSystemBufferSize == 0x2000 /* before Win8 */),
+       "expected 0x10000, got 0x%x\n", caps.dwSystemBufferSize);
+}
+
+static void test_player_info_peer(void)
+{
+    HRESULT hr;
+    DPN_PLAYER_INFO info;
+    WCHAR name[] = {'w','i','n','e',0};
+    WCHAR name2[] = {'w','i','n','e','2',0};
+    WCHAR data[] = {'X','X','X','X',0};
+
+    ZeroMemory( &info, sizeof(DPN_PLAYER_INFO) );
+    info.dwSize = sizeof(DPN_PLAYER_INFO);
+    info.dwInfoFlags = DPNINFO_NAME;
+
+    hr = IDirectPlay8Peer_SetPeerInfo(peer, NULL, NULL, NULL, DPNSETPEERINFO_SYNC);
+    ok(hr == E_POINTER, "got %x\n", hr);
+
+    info.pwszName = NULL;
+    hr = IDirectPlay8Peer_SetPeerInfo(peer, &info, NULL, NULL, DPNSETPEERINFO_SYNC);
+    ok(hr == S_OK, "got %x\n", hr);
+
+    info.pwszName = name;
+    hr = IDirectPlay8Peer_SetPeerInfo(peer, &info, NULL, NULL, DPNSETPEERINFO_SYNC);
+    ok(hr == S_OK, "got %x\n", hr);
+
+    info.dwInfoFlags = DPNINFO_NAME;
+    info.pwszName = name2;
+    hr = IDirectPlay8Peer_SetPeerInfo(peer, &info, NULL, NULL, DPNSETPEERINFO_SYNC);
+    ok(hr == S_OK, "got %x\n", hr);
+
+if(0) /* Crashes on windows */
+{
+    info.dwInfoFlags = DPNINFO_DATA;
+    info.pwszName = NULL;
+    info.pvData = NULL;
+    info.dwDataSize = sizeof(data);
+    hr = IDirectPlay8Peer_SetPeerInfo(peer, &info, NULL, NULL, DPNSETPEERINFO_SYNC);
+    ok(hr == S_OK, "got %x\n", hr);
+}
+
+    info.dwInfoFlags = DPNINFO_DATA;
+    info.pwszName = NULL;
+    info.pvData = data;
+    info.dwDataSize = 0;
+    hr = IDirectPlay8Peer_SetPeerInfo(peer, &info, NULL, NULL, DPNSETPEERINFO_SYNC);
+    ok(hr == S_OK, "got %x\n", hr);
+
+    info.dwInfoFlags = DPNINFO_DATA;
+    info.pwszName = NULL;
+    info.pvData = data;
+    info.dwDataSize = sizeof(data);
+    hr = IDirectPlay8Peer_SetPeerInfo(peer, &info, NULL, NULL, DPNSETPEERINFO_SYNC);
+    ok(hr == S_OK, "got %x\n", hr);
+
+    info.dwInfoFlags = DPNINFO_DATA | DPNINFO_NAME;
+    info.pwszName = name;
+    info.pvData = data;
+    info.dwDataSize = sizeof(data);
+    hr = IDirectPlay8Peer_SetPeerInfo(peer, &info, NULL, NULL, DPNSETPEERINFO_SYNC);
+    ok(hr == S_OK, "got %x\n", hr);
+
+    /* Leave PeerInfo with only the name set. */
+    info.dwInfoFlags = DPNINFO_DATA | DPNINFO_NAME;
+    info.pwszName = name;
+    info.pvData = NULL;
+    info.dwDataSize = 0;
+    hr = IDirectPlay8Peer_SetPeerInfo(peer, &info, NULL, NULL, DPNSETPEERINFO_SYNC);
+    ok(hr == S_OK, "got %x\n", hr);
+}
+
+static void test_cleanup_dp_peer(void)
+{
+    HRESULT hr;
+
+    hr = IDirectPlay8Peer_Close(peer, 0);
+    ok(hr == S_OK, "IDirectPlay8Peer_Close failed with %x\n", hr);
+
+    if(lobbied)
+    {
+        hr = IDirectPlay8LobbiedApplication_Close(lobbied, 0);
+        ok(hr == S_OK, "IDirectPlay8LobbiedApplication_Close failed with %x\n", hr);
+
+        IDirectPlay8LobbiedApplication_Release(lobbied);
+    }
+
+    IDirectPlay8Peer_Release(peer);
+
+    CoUninitialize();
+}
+
 START_TEST(client)
 {
     if(!test_init_dp())
@@ -358,4 +618,11 @@ START_TEST(client)
     test_lobbyclient();
     test_close();
     test_cleanup_dp();
+
+    test_init_dp_peer();
+    test_enum_service_providers_peer();
+    test_enum_hosts_peer();
+    test_get_sp_caps_peer();
+    test_player_info_peer();
+    test_cleanup_dp_peer();
 }
diff --git a/dlls/dpnet/tests/peer.c b/dlls/dpnet/tests/peer.c
deleted file mode 100644
index 9d06c80..0000000
--- a/dlls/dpnet/tests/peer.c
+++ /dev/null
@@ -1,312 +0,0 @@
-/*
- * Copyright 2011 Louis Lenders
- *
- * 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 WIN32_LEAN_AND_MEAN
-#include <stdio.h>
-
-#include <dplay8.h>
-#include <dplobby8.h>
-#include "wine/test.h"
-
-
-static IDirectPlay8Peer* peer = NULL;
-static IDirectPlay8LobbiedApplication* lobbied = NULL;
-
-static HRESULT WINAPI DirectPlayMessageHandler(PVOID context, DWORD message_id, PVOID buffer)
-{
-    trace("DirectPlayMessageHandler: 0x%08x\n", message_id);
-    return S_OK;
-}
-
-static HRESULT WINAPI DirectPlayLobbyMessageHandler(PVOID context, DWORD message_id, PVOID buffer)
-{
-    trace("DirectPlayLobbyMessageHandler: 0x%08x\n", message_id);
-    return S_OK;
-}
-
-static void test_init_dp(void)
-{
-    HRESULT hr;
-    DPN_SP_CAPS caps;
-    DPNHANDLE lobbyConnection;
-
-    hr = CoInitialize(0);
-    ok(hr == S_OK, "CoInitialize failed with %x\n", hr);
-
-    hr = CoCreateInstance(&CLSID_DirectPlay8Peer, NULL, CLSCTX_INPROC_SERVER, &IID_IDirectPlay8Peer, (void **)&peer);
-    ok(hr == S_OK, "CoCreateInstance failed with 0x%x\n", hr);
-
-    memset(&caps, 0, sizeof(DPN_SP_CAPS));
-    caps.dwSize = sizeof(DPN_SP_CAPS);
-
-    hr = IDirectPlay8Peer_GetSPCaps(peer, &CLSID_DP8SP_TCPIP, &caps, 0);
-    ok(hr == DPNERR_UNINITIALIZED, "GetSPCaps failed with %x\n", hr);
-
-    hr = IDirectPlay8Peer_Initialize(peer, NULL, NULL, 0);
-    ok(hr == DPNERR_INVALIDPARAM, "got %x\n", hr);
-
-    hr = IDirectPlay8Peer_Initialize(peer, NULL, DirectPlayMessageHandler, 0);
-    ok(hr == S_OK, "IDirectPlay8Peer_Initialize failed with %x\n", hr);
-
-    hr = CoCreateInstance(&CLSID_DirectPlay8LobbiedApplication, NULL, CLSCTX_INPROC_SERVER,
-                          &IID_IDirectPlay8LobbiedApplication, (void **)&lobbied);
-    ok(hr == S_OK, "CoCreateInstance failed with 0x%x\n", hr);
-
-    hr = IDirectPlay8LobbiedApplication_Initialize(lobbied, NULL, NULL,
-                                                &lobbyConnection, 0);
-    ok(hr == DPNERR_INVALIDPOINTER, "Failed with %x\n", hr);
-
-    hr = IDirectPlay8LobbiedApplication_Initialize(lobbied, NULL, DirectPlayLobbyMessageHandler,
-                                                &lobbyConnection, 0);
-    ok(hr == S_OK, "IDirectPlay8LobbiedApplication_Initialize failed with %x\n", hr);
-}
-
-static void test_enum_service_providers(void)
-{
-    DPN_SERVICE_PROVIDER_INFO *serv_prov_info;
-    DWORD items, size;
-    DWORD i;
-    HRESULT hr;
-
-    size = 0;
-    items = 0;
-
-    hr = IDirectPlay8Peer_EnumServiceProviders(peer, NULL, NULL, NULL, &size, NULL, 0);
-    ok(hr == E_POINTER, "IDirectPlay8Peer_EnumServiceProviders failed with %x\n", hr);
-
-    hr = IDirectPlay8Peer_EnumServiceProviders(peer, NULL, NULL, NULL, NULL, &items, 0);
-    ok(hr == E_POINTER, "IDirectPlay8Peer_EnumServiceProviders failed with %x\n", hr);
-
-    hr = IDirectPlay8Peer_EnumServiceProviders(peer, NULL, NULL, NULL, &size, &items, 0);
-    ok(hr == DPNERR_BUFFERTOOSMALL, "IDirectPlay8Peer_EnumServiceProviders failed with %x\n", hr);
-    ok(size != 0, "size is unexpectedly 0\n");
-
-    serv_prov_info = HeapAlloc(GetProcessHeap(), 0, size);
-
-    hr = IDirectPlay8Peer_EnumServiceProviders(peer, NULL, NULL, serv_prov_info, &size, &items, 0);
-    ok(hr == S_OK, "IDirectPlay8Peer_EnumServiceProviders failed with %x\n", hr);
-    ok(items != 0, "Found unexpectedly no service providers\n");
-
-    trace("number of items found: %d\n", items);
-
-    for (i=0;i<items;i++)
-    {
-        trace("Found Service Provider: %s\n", wine_dbgstr_w(serv_prov_info->pwszName));
-        trace("Found guid: %s\n", wine_dbgstr_guid(&serv_prov_info->guid));
-
-        serv_prov_info++;
-    }
-
-    serv_prov_info -= items; /* set pointer back */
-    ok(HeapFree(GetProcessHeap(), 0, serv_prov_info), "Failed freeing server provider info\n");
-
-    size = 0;
-    items = 0;
-
-    hr = IDirectPlay8Peer_EnumServiceProviders(peer, &CLSID_DP8SP_TCPIP, NULL, NULL, &size, &items, 0);
-    ok(hr == DPNERR_BUFFERTOOSMALL, "IDirectPlay8Peer_EnumServiceProviders failed with %x\n", hr);
-    ok(size != 0, "size is unexpectedly 0\n");
-
-    serv_prov_info = HeapAlloc(GetProcessHeap(), 0, size);
-
-    hr = IDirectPlay8Peer_EnumServiceProviders(peer, &CLSID_DP8SP_TCPIP, NULL, serv_prov_info, &size, &items, 0);
-    ok(hr == S_OK, "IDirectPlay8Peer_EnumServiceProviders failed with %x\n", hr);
-    ok(items != 0, "Found unexpectedly no adapter\n");
-
-
-    for (i=0;i<items;i++)
-    {
-        trace("Found adapter: %s\n", wine_dbgstr_w(serv_prov_info->pwszName));
-        trace("Found adapter guid: %s\n", wine_dbgstr_guid(&serv_prov_info->guid));
-
-        serv_prov_info++;
-    }
-
-    serv_prov_info -= items; /* set pointer back */
-    ok(HeapFree(GetProcessHeap(), 0, serv_prov_info), "Failed freeing server provider info\n");
-}
-
-static const GUID appguid = { 0xcd0c3d4b, 0xe15e, 0x4cf2, { 0x9e, 0xa8, 0x6e, 0x1d, 0x65, 0x48, 0xc5, 0xa5 } };
-
-static void test_enum_hosts(void)
-{
-    HRESULT hr;
-    IDirectPlay8Address *host = NULL;
-    IDirectPlay8Address *local = NULL;
-    DPN_APPLICATION_DESC appdesc;
-    DPNHANDLE async = 0;
-    static const WCHAR localhost[] = {'1','2','7','.','0','.','0','.','1',0};
-
-    memset( &appdesc, 0, sizeof(DPN_APPLICATION_DESC) );
-    appdesc.dwSize  = sizeof( DPN_APPLICATION_DESC );
-    appdesc.guidApplication  = appguid;
-
-    hr = CoCreateInstance( &CLSID_DirectPlay8Address, NULL, CLSCTX_ALL, &IID_IDirectPlay8Address, (LPVOID*)&local);
-    ok(hr == S_OK, "IDirectPlay8Address failed with 0x%08x\n", hr);
-
-    hr = IDirectPlay8Address_SetSP(local, &CLSID_DP8SP_TCPIP);
-    ok(hr == S_OK, "IDirectPlay8Address_SetSP failed with 0x%08x\n", hr);
-
-    hr = CoCreateInstance( &CLSID_DirectPlay8Address, NULL, CLSCTX_ALL, &IID_IDirectPlay8Address, (LPVOID*)&host);
-    ok(hr == S_OK, "IDirectPlay8Address failed with 0x%08x\n", hr);
-
-    hr = IDirectPlay8Address_SetSP(host, &CLSID_DP8SP_TCPIP);
-    ok(hr == S_OK, "IDirectPlay8Address_SetSP failed with 0x%08x\n", hr);
-
-    hr = IDirectPlay8Address_AddComponent(host, DPNA_KEY_HOSTNAME, localhost, sizeof(localhost),
-                                                         DPNA_DATATYPE_STRING);
-    ok(hr == S_OK, "IDirectPlay8Address failed with 0x%08x\n", hr);
-
-    hr = IDirectPlay8Peer_EnumHosts(peer, &appdesc, host, local, NULL, 0, INFINITE, 0, INFINITE, NULL,  &async, 0);
-    todo_wine ok(hr == DPNSUCCESS_PENDING, "IDirectPlay8Peer_EnumServiceProviders failed with 0x%08x\n", hr);
-    todo_wine ok(async, "No Handle returned\n");
-
-    hr = IDirectPlay8Peer_CancelAsyncOperation(peer, async, 0);
-    todo_wine ok(hr == S_OK, "IDirectPlay8Peer_CancelAsyncOperation failed with 0x%08x\n", hr);
-
-    IDirectPlay8Address_Release(local);
-    IDirectPlay8Address_Release(host);
-}
-
-static void test_get_sp_caps(void)
-{
-    DPN_SP_CAPS caps;
-    HRESULT hr;
-
-    memset(&caps, 0, sizeof(DPN_SP_CAPS));
-
-    hr = IDirectPlay8Peer_GetSPCaps(peer, &CLSID_DP8SP_TCPIP, &caps, 0);
-    ok(hr == DPNERR_INVALIDPARAM, "GetSPCaps unexpectedly returned %x\n", hr);
-
-    caps.dwSize = sizeof(DPN_SP_CAPS);
-
-    hr = IDirectPlay8Peer_GetSPCaps(peer, &CLSID_DP8SP_TCPIP, &caps, 0);
-    ok(hr == DPN_OK, "GetSPCaps failed with %x\n", hr);
-
-    ok(caps.dwSize == sizeof(DPN_SP_CAPS), "got %d\n", caps.dwSize);
-    ok((caps.dwFlags &
-        (DPNSPCAPS_SUPPORTSDPNSRV | DPNSPCAPS_SUPPORTSBROADCAST | DPNSPCAPS_SUPPORTSALLADAPTERS)) ==
-       (DPNSPCAPS_SUPPORTSDPNSRV | DPNSPCAPS_SUPPORTSBROADCAST | DPNSPCAPS_SUPPORTSALLADAPTERS),
-       "unexpected flags %x\n", caps.dwFlags);
-    ok(caps.dwNumThreads >= 3, "got %d\n", caps.dwNumThreads);
-    ok(caps.dwDefaultEnumCount == 5, "expected 5, got %d\n", caps.dwDefaultEnumCount);
-    ok(caps.dwDefaultEnumRetryInterval == 1500, "expected 1500, got %d\n", caps.dwDefaultEnumRetryInterval);
-    ok(caps.dwDefaultEnumTimeout == 1500, "expected 1500, got %d\n", caps.dwDefaultEnumTimeout);
-    ok(caps.dwMaxEnumPayloadSize == 983, "expected 983, got %d\n", caps.dwMaxEnumPayloadSize);
-    ok(caps.dwBuffersPerThread == 1, "expected 1, got %d\n", caps.dwBuffersPerThread);
-    ok(caps.dwSystemBufferSize == 0x10000 || broken(caps.dwSystemBufferSize == 0x2000 /* before Win8 */),
-       "expected 0x10000, got 0x%x\n", caps.dwSystemBufferSize);
-}
-
-static void test_player_info(void)
-{
-    HRESULT hr;
-    DPN_PLAYER_INFO info;
-    WCHAR name[] = {'w','i','n','e',0};
-    WCHAR name2[] = {'w','i','n','e','2',0};
-    WCHAR data[] = {'X','X','X','X',0};
-
-    ZeroMemory( &info, sizeof(DPN_PLAYER_INFO) );
-    info.dwSize = sizeof(DPN_PLAYER_INFO);
-    info.dwInfoFlags = DPNINFO_NAME;
-
-    hr = IDirectPlay8Peer_SetPeerInfo(peer, NULL, NULL, NULL, DPNSETPEERINFO_SYNC);
-    ok(hr == E_POINTER, "got %x\n", hr);
-
-    info.pwszName = NULL;
-    hr = IDirectPlay8Peer_SetPeerInfo(peer, &info, NULL, NULL, DPNSETPEERINFO_SYNC);
-    ok(hr == S_OK, "got %x\n", hr);
-
-    info.pwszName = name;
-    hr = IDirectPlay8Peer_SetPeerInfo(peer, &info, NULL, NULL, DPNSETPEERINFO_SYNC);
-    ok(hr == S_OK, "got %x\n", hr);
-
-    info.dwInfoFlags = DPNINFO_NAME;
-    info.pwszName = name2;
-    hr = IDirectPlay8Peer_SetPeerInfo(peer, &info, NULL, NULL, DPNSETPEERINFO_SYNC);
-    ok(hr == S_OK, "got %x\n", hr);
-
-if(0) /* Crashes on windows */
-{
-    info.dwInfoFlags = DPNINFO_DATA;
-    info.pwszName = NULL;
-    info.pvData = NULL;
-    info.dwDataSize = sizeof(data);
-    hr = IDirectPlay8Peer_SetPeerInfo(peer, &info, NULL, NULL, DPNSETPEERINFO_SYNC);
-    ok(hr == S_OK, "got %x\n", hr);
-}
-
-    info.dwInfoFlags = DPNINFO_DATA;
-    info.pwszName = NULL;
-    info.pvData = data;
-    info.dwDataSize = 0;
-    hr = IDirectPlay8Peer_SetPeerInfo(peer, &info, NULL, NULL, DPNSETPEERINFO_SYNC);
-    ok(hr == S_OK, "got %x\n", hr);
-
-    info.dwInfoFlags = DPNINFO_DATA;
-    info.pwszName = NULL;
-    info.pvData = data;
-    info.dwDataSize = sizeof(data);
-    hr = IDirectPlay8Peer_SetPeerInfo(peer, &info, NULL, NULL, DPNSETPEERINFO_SYNC);
-    ok(hr == S_OK, "got %x\n", hr);
-
-    info.dwInfoFlags = DPNINFO_DATA | DPNINFO_NAME;
-    info.pwszName = name;
-    info.pvData = data;
-    info.dwDataSize = sizeof(data);
-    hr = IDirectPlay8Peer_SetPeerInfo(peer, &info, NULL, NULL, DPNSETPEERINFO_SYNC);
-    ok(hr == S_OK, "got %x\n", hr);
-
-    /* Leave PeerInfo with only the name set. */
-    info.dwInfoFlags = DPNINFO_DATA | DPNINFO_NAME;
-    info.pwszName = name;
-    info.pvData = NULL;
-    info.dwDataSize = 0;
-    hr = IDirectPlay8Peer_SetPeerInfo(peer, &info, NULL, NULL, DPNSETPEERINFO_SYNC);
-    ok(hr == S_OK, "got %x\n", hr);
-}
-
-static void test_cleanup_dp(void)
-{
-    HRESULT hr;
-
-    hr = IDirectPlay8Peer_Close(peer, 0);
-    ok(hr == S_OK, "IDirectPlay8Peer_Close failed with %x\n", hr);
-
-    if(lobbied)
-    {
-        hr = IDirectPlay8LobbiedApplication_Close(lobbied, 0);
-        ok(hr == S_OK, "IDirectPlay8LobbiedApplication_Close failed with %x\n", hr);
-
-        IDirectPlay8LobbiedApplication_Release(lobbied);
-    }
-
-    IDirectPlay8Peer_Release(peer);
-
-    CoUninitialize();
-}
-
-START_TEST(peer)
-{
-    test_init_dp();
-    test_enum_service_providers();
-    test_enum_hosts();
-    test_get_sp_caps();
-    test_player_info();
-    test_cleanup_dp();
-}
-- 
2.1.4




More information about the wine-patches mailing list