Author: cwittich
Date: Tue Dec 30 03:10:17 2008
New Revision: 38466
URL: 
http://svn.reactos.org/svn/reactos?rev=38466&view=rev
Log:
add func_iphlpapi winetest from wine 1.1.11
Added:
    trunk/rostests/winetests/iphlpapi/   (with props)
    trunk/rostests/winetests/iphlpapi/iphlpapi.c   (with props)
    trunk/rostests/winetests/iphlpapi/iphlpapi.rbuild   (with props)
    trunk/rostests/winetests/iphlpapi/testlist.c   (with props)
Modified:
    trunk/rostests/winetests/directory.rbuild
Modified: trunk/rostests/winetests/directory.rbuild
URL:
http://svn.reactos.org/svn/reactos/trunk/rostests/winetests/directory.rbuil…
==============================================================================
--- trunk/rostests/winetests/directory.rbuild [iso-8859-1] (original)
+++ trunk/rostests/winetests/directory.rbuild [iso-8859-1] Tue Dec 30 03:10:17 2008
@@ -39,6 +39,9 @@
        </directory>
        <directory name="imm32">
                <xi:include href="imm32/imm32.rbuild" />
+       </directory>
+       <directory name="iphlpapi">
+               <xi:include href="iphlpapi/iphlpapi.rbuild" />
        </directory>
        <directory name="jscript">
                <xi:include href="jscript/jscript.rbuild" />
Propchange: trunk/rostests/winetests/iphlpapi/
------------------------------------------------------------------------------
--- bugtraq:logregex (added)
+++ bugtraq:logregex Tue Dec 30 03:10:17 2008
@@ -1,0 +1,2 @@
+([Ii]ssue|[Bb]ug)s? #?(\d+)(,? ?#?(\d+))*(,? ?(and |or )?#?(\d+))?
+(\d+)
Propchange: trunk/rostests/winetests/iphlpapi/
------------------------------------------------------------------------------
    bugtraq:message = See issue #%BUGID% for more details.
Propchange: trunk/rostests/winetests/iphlpapi/
------------------------------------------------------------------------------
    bugtraq:url = 
http://www.reactos.org/bugzilla/show_bug.cgi?id=%BUGID%
Propchange: trunk/rostests/winetests/iphlpapi/
------------------------------------------------------------------------------
    tsvn:logminsize = 10
Added: trunk/rostests/winetests/iphlpapi/iphlpapi.c
URL:
http://svn.reactos.org/svn/reactos/trunk/rostests/winetests/iphlpapi/iphlpa…
==============================================================================
--- trunk/rostests/winetests/iphlpapi/iphlpapi.c (added)
+++ trunk/rostests/winetests/iphlpapi/iphlpapi.c [iso-8859-1] Tue Dec 30 03:10:17 2008
@@ -1,0 +1,670 @@
+/*
+ * iphlpapi dll test
+ *
+ * Copyright (C) 2003 Juan Lang
+ *
+ * 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
+ */
+
+/*
+ * Some observations that an automated test can't produce:
+ * An adapter index is a key for an adapter.  That is, if an index is returned
+ * from one API, that same index may be used successfully in another API, as
+ * long as the adapter remains present.
+ * If the adapter is removed and reinserted, however, the index may change (and
+ * indeed it does change on Win2K).
+ *
+ * The Name field of the IP_ADAPTER_INDEX_MAP entries returned by
+ * GetInterfaceInfo is declared as a wide string, but the bytes are actually
+ * an ASCII string on some versions of the IP helper API under Win9x.  This was
+ * apparently an MS bug, it's corrected in later versions.
+ *
+ * The DomainName field of FIXED_INFO isn't NULL-terminated on Win98.
+ */
+
+#include <stdarg.h>
+#include "windef.h"
+#include "winbase.h"
+#include "iphlpapi.h"
+#include "iprtrmib.h"
+#include "wine/test.h"
+#include <stdio.h>
+#include <stdlib.h>
+
+static HMODULE hLibrary = NULL;
+
+typedef DWORD (WINAPI *GetNumberOfInterfacesFunc)(PDWORD);
+typedef DWORD (WINAPI *GetIpAddrTableFunc)(PMIB_IPADDRTABLE,PULONG,BOOL);
+typedef DWORD (WINAPI *GetIfEntryFunc)(PMIB_IFROW);
+typedef DWORD (WINAPI *GetFriendlyIfIndexFunc)(DWORD);
+typedef DWORD (WINAPI *GetIfTableFunc)(PMIB_IFTABLE,PULONG,BOOL);
+typedef DWORD (WINAPI *GetIpForwardTableFunc)(PMIB_IPFORWARDTABLE,PULONG,BOOL);
+typedef DWORD (WINAPI *GetIpNetTableFunc)(PMIB_IPNETTABLE,PULONG,BOOL);
+typedef DWORD (WINAPI *GetInterfaceInfoFunc)(PIP_INTERFACE_INFO,PULONG);
+typedef DWORD (WINAPI *GetAdaptersInfoFunc)(PIP_ADAPTER_INFO,PULONG);
+typedef DWORD (WINAPI *GetNetworkParamsFunc)(PFIXED_INFO,PULONG);
+typedef DWORD (WINAPI *GetIcmpStatisticsFunc)(PMIB_ICMP);
+typedef DWORD (WINAPI *GetIpStatisticsFunc)(PMIB_IPSTATS);
+typedef DWORD (WINAPI *GetTcpStatisticsFunc)(PMIB_TCPSTATS);
+typedef DWORD (WINAPI *GetUdpStatisticsFunc)(PMIB_UDPSTATS);
+typedef DWORD (WINAPI *GetTcpTableFunc)(PMIB_TCPTABLE,PDWORD,BOOL);
+typedef DWORD (WINAPI *GetUdpTableFunc)(PMIB_UDPTABLE,PDWORD,BOOL);
+typedef DWORD (WINAPI *GetPerAdapterInfoFunc)(ULONG,PIP_PER_ADAPTER_INFO,PULONG);
+
+static GetNumberOfInterfacesFunc gGetNumberOfInterfaces = NULL;
+static GetIpAddrTableFunc gGetIpAddrTable = NULL;
+static GetIfEntryFunc gGetIfEntry = NULL;
+static GetFriendlyIfIndexFunc gGetFriendlyIfIndex = NULL;
+static GetIfTableFunc gGetIfTable = NULL;
+static GetIpForwardTableFunc gGetIpForwardTable = NULL;
+static GetIpNetTableFunc gGetIpNetTable = NULL;
+static GetInterfaceInfoFunc gGetInterfaceInfo = NULL;
+static GetAdaptersInfoFunc gGetAdaptersInfo = NULL;
+static GetNetworkParamsFunc gGetNetworkParams = NULL;
+static GetIcmpStatisticsFunc gGetIcmpStatistics = NULL;
+static GetIpStatisticsFunc gGetIpStatistics = NULL;
+static GetTcpStatisticsFunc gGetTcpStatistics = NULL;
+static GetUdpStatisticsFunc gGetUdpStatistics = NULL;
+static GetTcpTableFunc gGetTcpTable = NULL;
+static GetUdpTableFunc gGetUdpTable = NULL;
+static GetPerAdapterInfoFunc gGetPerAdapterInfo = NULL;
+
+static void loadIPHlpApi(void)
+{
+  hLibrary = LoadLibraryA("iphlpapi.dll");
+  if (hLibrary) {
+    gGetNumberOfInterfaces = (GetNumberOfInterfacesFunc)GetProcAddress(
+     hLibrary, "GetNumberOfInterfaces");
+    gGetIpAddrTable = (GetIpAddrTableFunc)GetProcAddress(
+     hLibrary, "GetIpAddrTable");
+    gGetIfEntry = (GetIfEntryFunc)GetProcAddress(
+     hLibrary, "GetIfEntry");
+    gGetFriendlyIfIndex = (GetFriendlyIfIndexFunc)GetProcAddress(
+     hLibrary, "GetFriendlyIfIndex");
+    gGetIfTable = (GetIfTableFunc)GetProcAddress(
+     hLibrary, "GetIfTable");
+    gGetIpForwardTable = (GetIpForwardTableFunc)GetProcAddress(
+     hLibrary, "GetIpForwardTable");
+    gGetIpNetTable = (GetIpNetTableFunc)GetProcAddress(
+     hLibrary, "GetIpNetTable");
+    gGetInterfaceInfo = (GetInterfaceInfoFunc)GetProcAddress(
+     hLibrary, "GetInterfaceInfo");
+    gGetAdaptersInfo = (GetAdaptersInfoFunc)GetProcAddress(
+     hLibrary, "GetAdaptersInfo");
+    gGetNetworkParams = (GetNetworkParamsFunc)GetProcAddress(
+     hLibrary, "GetNetworkParams");
+    gGetIcmpStatistics = (GetIcmpStatisticsFunc)GetProcAddress(
+     hLibrary, "GetIcmpStatistics");
+    gGetIpStatistics = (GetIpStatisticsFunc)GetProcAddress(
+     hLibrary, "GetIpStatistics");
+    gGetTcpStatistics = (GetTcpStatisticsFunc)GetProcAddress(
+     hLibrary, "GetTcpStatistics");
+    gGetUdpStatistics = (GetUdpStatisticsFunc)GetProcAddress(
+     hLibrary, "GetUdpStatistics");
+    gGetTcpTable = (GetTcpTableFunc)GetProcAddress(
+     hLibrary, "GetTcpTable");
+    gGetUdpTable = (GetUdpTableFunc)GetProcAddress(
+     hLibrary, "GetUdpTable");
+    gGetPerAdapterInfo = (GetPerAdapterInfoFunc)GetProcAddress(hLibrary,
"GetPerAdapterInfo");
+  }
+}
+
+static void freeIPHlpApi(void)
+{
+  if (hLibrary) {
+    gGetNumberOfInterfaces = NULL;
+    gGetIpAddrTable = NULL;
+    gGetIfEntry = NULL;
+    gGetFriendlyIfIndex = NULL;
+    gGetIfTable = NULL;
+    gGetIpForwardTable = NULL;
+    gGetIpNetTable = NULL;
+    gGetInterfaceInfo = NULL;
+    gGetAdaptersInfo = NULL;
+    gGetNetworkParams = NULL;
+    gGetIcmpStatistics = NULL;
+    gGetIpStatistics = NULL;
+    gGetTcpStatistics = NULL;
+    gGetUdpStatistics = NULL;
+    gGetTcpTable = NULL;
+    gGetUdpTable = NULL;
+    FreeLibrary(hLibrary);
+    hLibrary = NULL;
+  }
+}
+
+/*
+still-to-be-tested 98-only functions:
+GetUniDirectionalAdapterInfo
+*/
+static void testWin98OnlyFunctions(void)
+{
+}
+
+static void testGetNumberOfInterfaces(void)
+{
+  if (gGetNumberOfInterfaces) {
+    DWORD apiReturn, numInterfaces;
+
+    /* Crashes on Vista */
+    if (0) {
+      apiReturn = gGetNumberOfInterfaces(NULL), numInterfaces;
+      if (apiReturn == ERROR_NOT_SUPPORTED)
+        return;
+      ok(apiReturn == ERROR_INVALID_PARAMETER,
+       "GetNumberOfInterfaces(NULL) returned %d, expected
ERROR_INVALID_PARAMETER\n",
+       apiReturn);
+    }
+
+    apiReturn = gGetNumberOfInterfaces(&numInterfaces);
+    if (apiReturn == ERROR_NOT_SUPPORTED) {
+      skip("GetNumberOfInterfaces is not supported\n");
+      return;
+    }
+    ok(apiReturn == NO_ERROR,
+     "GetNumberOfInterfaces returned %d, expected 0\n", apiReturn);
+  }
+}
+
+static void testGetIfEntry(DWORD index)
+{
+  if (gGetIfEntry) {
+    DWORD apiReturn;
+    MIB_IFROW row;
+
+    memset(&row, 0, sizeof(row));
+    apiReturn = gGetIfEntry(NULL);
+    if (apiReturn == ERROR_NOT_SUPPORTED) {
+      skip("GetIfEntry is not supported\n");
+      return;
+    }
+    ok(apiReturn == ERROR_INVALID_PARAMETER,
+     "GetIfEntry(NULL) returned %d, expected ERROR_INVALID_PARAMETER\n",
+     apiReturn);
+    row.dwIndex = -1; /* hope that's always bogus! */
+    apiReturn = gGetIfEntry(&row);
+    ok(apiReturn == ERROR_INVALID_DATA ||
+     apiReturn == ERROR_FILE_NOT_FOUND /* Vista */,
+     "GetIfEntry(bogus row) returned %d, expected ERROR_INVALID_DATA or
ERROR_FILE_NOT_FOUND\n",
+     apiReturn);
+    row.dwIndex = index;
+    apiReturn = gGetIfEntry(&row);
+    ok(apiReturn == NO_ERROR,
+     "GetIfEntry returned %d, expected NO_ERROR\n", apiReturn);
+  }
+}
+
+static void testGetIpAddrTable(void)
+{
+  if (gGetIpAddrTable) {
+    DWORD apiReturn;
+    ULONG dwSize = 0;
+
+    apiReturn = gGetIpAddrTable(NULL, NULL, FALSE);
+    if (apiReturn == ERROR_NOT_SUPPORTED) {
+      skip("GetIpAddrTable is not supported\n");
+      return;
+    }
+    ok(apiReturn == ERROR_INVALID_PARAMETER,
+     "GetIpAddrTable(NULL, NULL, FALSE) returned %d, expected
ERROR_INVALID_PARAMETER\n",
+     apiReturn);
+    apiReturn = gGetIpAddrTable(NULL, &dwSize, FALSE);
+    ok(apiReturn == ERROR_INSUFFICIENT_BUFFER,
+     "GetIpAddrTable(NULL, &dwSize, FALSE) returned %d, expected
ERROR_INSUFFICIENT_BUFFER\n",
+     apiReturn);
+    if (apiReturn == ERROR_INSUFFICIENT_BUFFER) {
+      PMIB_IPADDRTABLE buf = HeapAlloc(GetProcessHeap(), 0, dwSize);
+
+      apiReturn = gGetIpAddrTable(buf, &dwSize, FALSE);
+      ok(apiReturn == NO_ERROR,
+       "GetIpAddrTable(buf, &dwSize, FALSE) returned %d, expected
NO_ERROR\n",
+       apiReturn);
+      if (apiReturn == NO_ERROR && buf->dwNumEntries)
+        testGetIfEntry(buf->table[0].dwIndex);
+      HeapFree(GetProcessHeap(), 0, buf);
+    }
+  }
+}
+
+static void testGetIfTable(void)
+{
+  if (gGetIfTable) {
+    DWORD apiReturn;
+    ULONG dwSize = 0;
+
+    apiReturn = gGetIfTable(NULL, NULL, FALSE);
+    if (apiReturn == ERROR_NOT_SUPPORTED) {
+      skip("GetIfTable is not supported\n");
+      return;
+    }
+    ok(apiReturn == ERROR_INVALID_PARAMETER,
+     "GetIfTable(NULL, NULL, FALSE) returned %d, expected
ERROR_INVALID_PARAMETER\n",
+     apiReturn);
+    apiReturn = gGetIfTable(NULL, &dwSize, FALSE);
+    ok(apiReturn == ERROR_INSUFFICIENT_BUFFER,
+     "GetIfTable(NULL, &dwSize, FALSE) returned %d, expected
ERROR_INSUFFICIENT_BUFFER\n",
+     apiReturn);
+    if (apiReturn == ERROR_INSUFFICIENT_BUFFER) {
+      PMIB_IFTABLE buf = HeapAlloc(GetProcessHeap(), 0, dwSize);
+
+      apiReturn = gGetIfTable(buf, &dwSize, FALSE);
+      ok(apiReturn == NO_ERROR,
+       "GetIfTable(buf, &dwSize, FALSE) returned %d, expected
NO_ERROR\n\n",
+       apiReturn);
+      HeapFree(GetProcessHeap(), 0, buf);
+    }
+  }
+}
+
+static void testGetIpForwardTable(void)
+{
+  if (gGetIpForwardTable) {
+    DWORD apiReturn;
+    ULONG dwSize = 0;
+
+    apiReturn = gGetIpForwardTable(NULL, NULL, FALSE);
+    if (apiReturn == ERROR_NOT_SUPPORTED) {
+      skip("GetIpForwardTable is not supported\n");
+      return;
+    }
+    ok(apiReturn == ERROR_INVALID_PARAMETER,
+     "GetIpForwardTable(NULL, NULL, FALSE) returned %d, expected
ERROR_INVALID_PARAMETER\n",
+     apiReturn);
+    apiReturn = gGetIpForwardTable(NULL, &dwSize, FALSE);
+    ok(apiReturn == ERROR_INSUFFICIENT_BUFFER,
+     "GetIpForwardTable(NULL, &dwSize, FALSE) returned %d, expected
ERROR_INSUFFICIENT_BUFFER\n",
+     apiReturn);
+    if (apiReturn == ERROR_INSUFFICIENT_BUFFER) {
+      PMIB_IPFORWARDTABLE buf = HeapAlloc(GetProcessHeap(), 0, dwSize);
+
+      apiReturn = gGetIpForwardTable(buf, &dwSize, FALSE);
+      ok(apiReturn == NO_ERROR,
+       "GetIpForwardTable(buf, &dwSize, FALSE) returned %d, expected
NO_ERROR\n",
+       apiReturn);
+      HeapFree(GetProcessHeap(), 0, buf);
+    }
+  }
+}
+
+static void testGetIpNetTable(void)
+{
+  if (gGetIpNetTable) {
+    DWORD apiReturn;
+    ULONG dwSize = 0;
+
+    apiReturn = gGetIpNetTable(NULL, NULL, FALSE);
+    if (apiReturn == ERROR_NOT_SUPPORTED) {
+      skip("GetIpNetTable is not supported\n");
+      return;
+    }
+    ok(apiReturn == ERROR_INVALID_PARAMETER,
+     "GetIpNetTable(NULL, NULL, FALSE) returned %d, expected
ERROR_INVALID_PARAMETER\n",
+     apiReturn);
+    apiReturn = gGetIpNetTable(NULL, &dwSize, FALSE);
+    ok(apiReturn == ERROR_NO_DATA || apiReturn == ERROR_INSUFFICIENT_BUFFER,
+     "GetIpNetTable(NULL, &dwSize, FALSE) returned %d, expected ERROR_NO_DATA or
ERROR_INSUFFICIENT_BUFFER\n",
+     apiReturn);
+    if (apiReturn == ERROR_NO_DATA)
+      ; /* empty ARP table's okay */
+    else if (apiReturn == ERROR_INSUFFICIENT_BUFFER) {
+      PMIB_IPNETTABLE buf = HeapAlloc(GetProcessHeap(), 0, dwSize);
+
+      apiReturn = gGetIpNetTable(buf, &dwSize, FALSE);
+      ok(apiReturn == NO_ERROR,
+       "GetIpNetTable(buf, &dwSize, FALSE) returned %d, expected
NO_ERROR\n",
+       apiReturn);
+      HeapFree(GetProcessHeap(), 0, buf);
+    }
+  }
+}
+
+static void testGetIcmpStatistics(void)
+{
+  if (gGetIcmpStatistics) {
+    DWORD apiReturn;
+    MIB_ICMP stats;
+
+    /* Crashes on Vista */
+    if (0) {
+      apiReturn = gGetIcmpStatistics(NULL);
+      if (apiReturn == ERROR_NOT_SUPPORTED)
+        return;
+      ok(apiReturn == ERROR_INVALID_PARAMETER,
+       "GetIcmpStatistics(NULL) returned %d, expected
ERROR_INVALID_PARAMETER\n",
+       apiReturn);
+    }
+
+    apiReturn = gGetIcmpStatistics(&stats);
+    if (apiReturn == ERROR_NOT_SUPPORTED)
+    {
+      skip("GetIcmpStatistics is not supported\n");
+      return;
+    }
+    ok(apiReturn == NO_ERROR,
+     "GetIcmpStatistics returned %d, expected NO_ERROR\n", apiReturn);
+  }
+}
+
+static void testGetIpStatistics(void)
+{
+  if (gGetIpStatistics) {
+    DWORD apiReturn;
+    MIB_IPSTATS stats;
+
+    apiReturn = gGetIpStatistics(NULL);
+    if (apiReturn == ERROR_NOT_SUPPORTED) {
+      skip("GetIpStatistics is not supported\n");
+      return;
+    }
+    ok(apiReturn == ERROR_INVALID_PARAMETER,
+     "GetIpStatistics(NULL) returned %d, expected ERROR_INVALID_PARAMETER\n",
+     apiReturn);
+    apiReturn = gGetIpStatistics(&stats);
+    ok(apiReturn == NO_ERROR,
+      "GetIpStatistics returned %d, expected NO_ERROR\n", apiReturn);
+  }
+}
+
+static void testGetTcpStatistics(void)
+{
+  if (gGetTcpStatistics) {
+    DWORD apiReturn;
+    MIB_TCPSTATS stats;
+
+    apiReturn = gGetTcpStatistics(NULL);
+    if (apiReturn == ERROR_NOT_SUPPORTED) {
+      skip("GetTcpStatistics is not supported\n");
+      return;
+    }
+    ok(apiReturn == ERROR_INVALID_PARAMETER,
+     "GetTcpStatistics(NULL) returned %d, expected ERROR_INVALID_PARAMETER\n",
+     apiReturn);
+    apiReturn = gGetTcpStatistics(&stats);
+    ok(apiReturn == NO_ERROR,
+      "GetTcpStatistics returned %d, expected NO_ERROR\n", apiReturn);
+  }
+}
+
+static void testGetUdpStatistics(void)
+{
+  if (gGetUdpStatistics) {
+    DWORD apiReturn;
+    MIB_UDPSTATS stats;
+
+    apiReturn = gGetUdpStatistics(NULL);
+    if (apiReturn == ERROR_NOT_SUPPORTED) {
+      skip("GetUdpStatistics is not supported\n");
+      return;
+    }
+    ok(apiReturn == ERROR_INVALID_PARAMETER,
+     "GetUdpStatistics(NULL) returned %d, expected ERROR_INVALID_PARAMETER\n",
+     apiReturn);
+    apiReturn = gGetUdpStatistics(&stats);
+    ok(apiReturn == NO_ERROR,
+     "GetUdpStatistics returned %d, expected NO_ERROR\n", apiReturn);
+  }
+}
+
+static void testGetTcpTable(void)
+{
+  if (gGetTcpTable) {
+    DWORD apiReturn;
+    ULONG dwSize = 0;
+
+    apiReturn = gGetTcpTable(NULL, NULL, FALSE);
+    if (apiReturn == ERROR_NOT_SUPPORTED) {
+      skip("GetTcpTable is not supported\n");
+      return;
+    }
+    ok(apiReturn == ERROR_INVALID_PARAMETER,
+     "GetTcpTable(NULL, NULL, FALSE) returned %d, expected
ERROR_INVALID_PARAMETER\n",
+     apiReturn);
+    apiReturn = gGetTcpTable(NULL, &dwSize, FALSE);
+    ok(apiReturn == ERROR_INSUFFICIENT_BUFFER ||
+       broken(apiReturn == ERROR_NO_DATA), /* win95 */
+     "GetTcpTable(NULL, &dwSize, FALSE) returned %d, expected
ERROR_INSUFFICIENT_BUFFER\n",
+     apiReturn);
+    if (apiReturn == ERROR_INSUFFICIENT_BUFFER) {
+      PMIB_TCPTABLE buf = HeapAlloc(GetProcessHeap(), 0, dwSize);
+
+      apiReturn = gGetTcpTable(buf, &dwSize, FALSE);
+      ok(apiReturn == NO_ERROR,
+       "GetTcpTable(buf, &dwSize, FALSE) returned %d, expected NO_ERROR\n",
+       apiReturn);
+      HeapFree(GetProcessHeap(), 0, buf);
+    }
+  }
+}
+
+static void testGetUdpTable(void)
+{
+  if (gGetUdpTable) {
+    DWORD apiReturn;
+    ULONG dwSize = 0;
+
+    apiReturn = gGetUdpTable(NULL, NULL, FALSE);
+    if (apiReturn == ERROR_NOT_SUPPORTED) {
+      skip("GetUdpTable is not supported\n");
+      return;
+    }
+    ok(apiReturn == ERROR_INVALID_PARAMETER,
+     "GetUdpTable(NULL, NULL, FALSE) returned %d, expected
ERROR_INVALID_PARAMETER\n",
+     apiReturn);
+    apiReturn = gGetUdpTable(NULL, &dwSize, FALSE);
+    ok(apiReturn == ERROR_INSUFFICIENT_BUFFER,
+     "GetUdpTable(NULL, &dwSize, FALSE) returned %d, expected
ERROR_INSUFFICIENT_BUFFER\n",
+     apiReturn);
+    if (apiReturn != ERROR_INSUFFICIENT_BUFFER) {
+      PMIB_UDPTABLE buf = HeapAlloc(GetProcessHeap(), 0, dwSize);
+
+      apiReturn = gGetUdpTable(buf, &dwSize, FALSE);
+      ok(apiReturn == NO_ERROR,
+       "GetUdpTable(buf, &dwSize, FALSE) returned %d, expected NO_ERROR\n",
+       apiReturn);
+      HeapFree(GetProcessHeap(), 0, buf);
+    }
+  }
+}
+
+/*
+still-to-be-tested NT4-onward functions:
+CreateIpForwardEntry
+DeleteIpForwardEntry
+CreateIpNetEntry
+DeleteIpNetEntry
+GetFriendlyIfIndex
+GetRTTAndHopCount
+SetIfEntry
+SetIpForwardEntry
+SetIpNetEntry
+SetIpStatistics
+SetIpTTL
+SetTcpEntry
+*/
+static void testWinNT4Functions(void)
+{
+  testGetNumberOfInterfaces();
+  testGetIpAddrTable();
+  testGetIfTable();
+  testGetIpForwardTable();
+  testGetIpNetTable();
+  testGetIcmpStatistics();
+  testGetIpStatistics();
+  testGetTcpStatistics();
+  testGetUdpStatistics();
+  testGetTcpTable();
+  testGetUdpTable();
+}
+
+static void testGetInterfaceInfo(void)
+{
+  if (gGetInterfaceInfo) {
+    DWORD apiReturn;
+    ULONG len = 0;
+
+    apiReturn = gGetInterfaceInfo(NULL, NULL);
+    if (apiReturn == ERROR_NOT_SUPPORTED) {
+      skip("GetInterfaceInfo is not supported\n");
+      return;
+    }
+    ok(apiReturn == ERROR_INVALID_PARAMETER,
+     "GetInterfaceInfo returned %d, expected ERROR_INVALID_PARAMETER\n",
+     apiReturn);
+    apiReturn = gGetInterfaceInfo(NULL, &len);
+    ok(apiReturn == ERROR_INSUFFICIENT_BUFFER,
+     "GetInterfaceInfo returned %d, expected ERROR_INSUFFICIENT_BUFFER\n",
+     apiReturn);
+    if (apiReturn == ERROR_INSUFFICIENT_BUFFER) {
+      PIP_INTERFACE_INFO buf = HeapAlloc(GetProcessHeap(), 0, len);
+
+      apiReturn = gGetInterfaceInfo(buf, &len);
+      ok(apiReturn == NO_ERROR,
+       "GetInterfaceInfo(buf, &dwSize) returned %d, expected NO_ERROR\n",
+       apiReturn);
+      HeapFree(GetProcessHeap(), 0, buf);
+    }
+  }
+}
+
+static void testGetAdaptersInfo(void)
+{
+  if (gGetAdaptersInfo) {
+    DWORD apiReturn;
+    ULONG len = 0;
+
+    apiReturn = gGetAdaptersInfo(NULL, NULL);
+    if (apiReturn == ERROR_NOT_SUPPORTED) {
+      skip("GetAdaptersInfo is not supported\n");
+      return;
+    }
+    ok(apiReturn == ERROR_INVALID_PARAMETER,
+     "GetAdaptersInfo returned %d, expected ERROR_INVALID_PARAMETER\n",
+     apiReturn);
+    apiReturn = gGetAdaptersInfo(NULL, &len);
+    ok(apiReturn == ERROR_NO_DATA || apiReturn == ERROR_BUFFER_OVERFLOW,
+     "GetAdaptersInfo returned %d, expected ERROR_NO_DATA or
ERROR_BUFFER_OVERFLOW\n",
+     apiReturn);
+    if (apiReturn == ERROR_NO_DATA)
+      ; /* no adapter's, that's okay */
+    else if (apiReturn == ERROR_BUFFER_OVERFLOW) {
+      PIP_ADAPTER_INFO buf = HeapAlloc(GetProcessHeap(), 0, len);
+
+      apiReturn = gGetAdaptersInfo(buf, &len);
+      ok(apiReturn == NO_ERROR,
+       "GetAdaptersInfo(buf, &dwSize) returned %d, expected NO_ERROR\n",
+       apiReturn);
+      HeapFree(GetProcessHeap(), 0, buf);
+    }
+  }
+}
+
+static void testGetNetworkParams(void)
+{
+  if (gGetNetworkParams) {
+    DWORD apiReturn;
+    ULONG len = 0;
+
+    apiReturn = gGetNetworkParams(NULL, NULL);
+    if (apiReturn == ERROR_NOT_SUPPORTED) {
+      skip("GetNetworkParams is not supported\n");
+      return;
+    }
+    ok(apiReturn == ERROR_INVALID_PARAMETER,
+     "GetNetworkParams returned %d, expected ERROR_INVALID_PARAMETER\n",
+     apiReturn);
+    apiReturn = gGetNetworkParams(NULL, &len);
+    ok(apiReturn == ERROR_BUFFER_OVERFLOW,
+     "GetNetworkParams returned %d, expected ERROR_BUFFER_OVERFLOW\n",
+     apiReturn);
+    if (apiReturn == ERROR_BUFFER_OVERFLOW) {
+      PFIXED_INFO buf = HeapAlloc(GetProcessHeap(), 0, len);
+
+      apiReturn = gGetNetworkParams(buf, &len);
+      ok(apiReturn == NO_ERROR,
+       "GetNetworkParams(buf, &dwSize) returned %d, expected NO_ERROR\n",
+       apiReturn);
+      HeapFree(GetProcessHeap(), 0, buf);
+    }
+  }
+}
+
+/*
+still-to-be-tested 98-onward functions:
+GetBestInterface
+GetBestRoute
+IpReleaseAddress
+IpRenewAddress
+*/
+static void testWin98Functions(void)
+{
+  testGetInterfaceInfo();
+  testGetAdaptersInfo();
+  testGetNetworkParams();
+}
+
+static void testGetPerAdapterInfo(void)
+{
+    DWORD ret, needed;
+    void *buffer;
+
+    if (!gGetPerAdapterInfo) return;
+    ret = gGetPerAdapterInfo(1, NULL, NULL);
+    if (ret == ERROR_NOT_SUPPORTED) {
+      skip("GetPerAdapterInfo is not supported\n");
+      return;
+    }
+    ok( ret == ERROR_INVALID_PARAMETER, "got %u instead of
ERROR_INVALID_PARAMETER\n", ret );
+    needed = 0xdeadbeef;
+    ret = gGetPerAdapterInfo(1, NULL, &needed);
+    if (ret == ERROR_NO_DATA) return;  /* no such adapter */
+    ok( ret == ERROR_BUFFER_OVERFLOW, "got %u instead of
ERROR_BUFFER_OVERFLOW\n", ret );
+    ok( needed != 0xdeadbeef, "needed not set\n" );
+    buffer = HeapAlloc( GetProcessHeap(), 0, needed );
+    ret = gGetPerAdapterInfo(1, buffer, &needed);
+    ok( ret == NO_ERROR, "got %u instead of NO_ERROR\n", ret );
+    HeapFree( GetProcessHeap(), 0, buffer );
+}
+
+/*
+still-to-be-tested 2K-onward functions:
+AddIPAddress
+CreateProxyArpEntry
+DeleteIPAddress
+DeleteProxyArpEntry
+EnableRouter
+FlushIpNetTable
+GetAdapterIndex
+NotifyAddrChange
+NotifyRouteChange
+SendARP
+UnenableRouter
+*/
+static void testWin2KFunctions(void)
+{
+    testGetPerAdapterInfo();
+}
+
+START_TEST(iphlpapi)
+{
+
+  loadIPHlpApi();
+  if (hLibrary) {
+    testWin98OnlyFunctions();
+    testWinNT4Functions();
+    testWin98Functions();
+    testWin2KFunctions();
+    freeIPHlpApi();
+  }
+}
Propchange: trunk/rostests/winetests/iphlpapi/iphlpapi.c
------------------------------------------------------------------------------
    svn:eol-style = native
Added: trunk/rostests/winetests/iphlpapi/iphlpapi.rbuild
URL:
http://svn.reactos.org/svn/reactos/trunk/rostests/winetests/iphlpapi/iphlpa…
==============================================================================
--- trunk/rostests/winetests/iphlpapi/iphlpapi.rbuild (added)
+++ trunk/rostests/winetests/iphlpapi/iphlpapi.rbuild [iso-8859-1] Tue Dec 30 03:10:17
2008
@@ -1,0 +1,13 @@
+<?xml version="1.0"?>
+<!DOCTYPE module SYSTEM "../../../tools/rbuild/project.dtd">
+<group>
+<module name="iphlpapi_winetest" type="win32cui"
installbase="bin" installname="iphlpapi_winetest.exe"
allowwarnings="true">
+       <compilerflag compiler="cc">-Wno-format</compilerflag>
+       <include base="iphlpapi_winetest">.</include>
+       <file>iphlpapi.c</file>
+       <file>testlist.c</file>
+       <library>wine</library>
+       <library>kernel32</library>
+       <library>ntdll</library>
+</module>
+</group>
Propchange: trunk/rostests/winetests/iphlpapi/iphlpapi.rbuild
------------------------------------------------------------------------------
    svn:eol-style = native
Added: trunk/rostests/winetests/iphlpapi/testlist.c
URL:
http://svn.reactos.org/svn/reactos/trunk/rostests/winetests/iphlpapi/testli…
==============================================================================
--- trunk/rostests/winetests/iphlpapi/testlist.c (added)
+++ trunk/rostests/winetests/iphlpapi/testlist.c [iso-8859-1] Tue Dec 30 03:10:17 2008
@@ -1,0 +1,15 @@
+/* Automatically generated file; DO NOT EDIT!! */
+
+#define WIN32_LEAN_AND_MEAN
+#include <windows.h>
+
+#define STANDALONE
+#include "wine/test.h"
+
+extern void func_iphlpapi(void);
+
+const struct test winetest_testlist[] =
+{
+    { "iphlpapi", func_iphlpapi },
+    { 0, 0 }
+};
Propchange: trunk/rostests/winetests/iphlpapi/testlist.c
------------------------------------------------------------------------------
    svn:eol-style = native