mirror of
https://github.com/reactos/reactos.git
synced 2025-01-04 21:38:43 +00:00
350 lines
10 KiB
C
350 lines
10 KiB
C
/*
|
|
* PROJECT: ReactOS API Tests
|
|
* LICENSE: GPL-2.0+ (https://spdx.org/licenses/GPL-2.0+)
|
|
* PURPOSE: Tests for TCP connections enumeration functions
|
|
* COPYRIGHT: Copyright 2018 Pierre Schweitzer
|
|
*/
|
|
|
|
#include <apitest.h>
|
|
|
|
#define WIN32_NO_STATUS
|
|
#include <iphlpapi.h>
|
|
#include <winsock2.h>
|
|
|
|
static DWORD GetExtendedTcpTableWithAlloc(PVOID *TcpTable, BOOL Order, DWORD Family, TCP_TABLE_CLASS Class)
|
|
{
|
|
DWORD ret;
|
|
DWORD Size = 0;
|
|
|
|
*TcpTable = NULL;
|
|
|
|
ret = GetExtendedTcpTable(*TcpTable, &Size, Order, Family, Class, 0);
|
|
if (ret == ERROR_INSUFFICIENT_BUFFER)
|
|
{
|
|
*TcpTable = HeapAlloc(GetProcessHeap(), 0, Size);
|
|
if (*TcpTable == NULL)
|
|
{
|
|
return ERROR_OUTOFMEMORY;
|
|
}
|
|
|
|
ret = GetExtendedTcpTable(*TcpTable, &Size, Order, Family, Class, 0);
|
|
if (ret != NO_ERROR)
|
|
{
|
|
HeapFree(GetProcessHeap(), 0, *TcpTable);
|
|
*TcpTable = NULL;
|
|
}
|
|
}
|
|
|
|
return ret;
|
|
}
|
|
|
|
START_TEST(GetExtendedTcpTable)
|
|
{
|
|
WSADATA wsaData;
|
|
SOCKET sock;
|
|
SOCKADDR_IN server;
|
|
PMIB_TCPTABLE TcpTable;
|
|
PMIB_TCPTABLE_OWNER_PID TcpTableOwner;
|
|
PMIB_TCPTABLE_OWNER_MODULE TcpTableOwnerMod;
|
|
DWORD i;
|
|
BOOLEAN Found;
|
|
FILETIME Creation;
|
|
LARGE_INTEGER CreationTime;
|
|
DWORD Pid = GetCurrentProcessId();
|
|
|
|
if (WSAStartup(MAKEWORD(2, 2), &wsaData) != 0)
|
|
{
|
|
skip("Failed to init WS2\n");
|
|
return;
|
|
}
|
|
|
|
GetSystemTimeAsFileTime(&Creation);
|
|
CreationTime.LowPart = Creation.dwLowDateTime;
|
|
CreationTime.HighPart = Creation.dwHighDateTime;
|
|
|
|
sock = socket(AF_INET, SOCK_STREAM, 0);
|
|
if (sock == INVALID_SOCKET)
|
|
{
|
|
skip("Cannot create socket\n");
|
|
goto quit;
|
|
}
|
|
|
|
ZeroMemory(&server, sizeof(SOCKADDR_IN));
|
|
server.sin_family = AF_INET;
|
|
server.sin_addr.s_addr = htonl(INADDR_ANY);
|
|
server.sin_port = htons(9876);
|
|
|
|
if (bind(sock, (SOCKADDR*)&server, sizeof(SOCKADDR_IN)) == SOCKET_ERROR)
|
|
{
|
|
skip("Cannot bind socket\n");
|
|
goto quit2;
|
|
}
|
|
|
|
if (listen(sock, SOMAXCONN) == SOCKET_ERROR)
|
|
{
|
|
skip("Cannot listen on socket\n");
|
|
goto quit2;
|
|
}
|
|
|
|
if (GetExtendedTcpTableWithAlloc((PVOID *)&TcpTable, TRUE, AF_INET, TCP_TABLE_BASIC_ALL) == ERROR_SUCCESS)
|
|
{
|
|
ok(TcpTable->dwNumEntries > 0, "No TCP connections?!\n");
|
|
|
|
Found = FALSE;
|
|
for (i = 0; i < TcpTable->dwNumEntries; ++i)
|
|
{
|
|
if (TcpTable->table[i].dwState == MIB_TCP_STATE_LISTEN &&
|
|
TcpTable->table[i].dwLocalAddr == 0 &&
|
|
TcpTable->table[i].dwLocalPort == htons(9876) &&
|
|
TcpTable->table[i].dwRemoteAddr == 0)
|
|
{
|
|
Found = TRUE;
|
|
break;
|
|
}
|
|
}
|
|
ok(Found, "Our socket wasn't found!\n");
|
|
|
|
HeapFree(GetProcessHeap(), 0, TcpTable);
|
|
}
|
|
else
|
|
{
|
|
skip("GetExtendedTcpTableWithAlloc failure\n");
|
|
}
|
|
|
|
if (GetExtendedTcpTableWithAlloc((PVOID *)&TcpTable, TRUE, AF_INET, TCP_TABLE_BASIC_CONNECTIONS) == ERROR_SUCCESS)
|
|
{
|
|
Found = FALSE;
|
|
for (i = 0; i < TcpTable->dwNumEntries; ++i)
|
|
{
|
|
if (TcpTable->table[i].dwState == MIB_TCP_STATE_LISTEN &&
|
|
TcpTable->table[i].dwLocalAddr == 0 &&
|
|
TcpTable->table[i].dwLocalPort == htons(9876) &&
|
|
TcpTable->table[i].dwRemoteAddr == 0)
|
|
{
|
|
Found = TRUE;
|
|
break;
|
|
}
|
|
}
|
|
ok(Found == FALSE, "Our socket was found!\n");
|
|
|
|
HeapFree(GetProcessHeap(), 0, TcpTable);
|
|
}
|
|
else
|
|
{
|
|
skip("GetExtendedTcpTableWithAlloc failure\n");
|
|
}
|
|
|
|
if (GetExtendedTcpTableWithAlloc((PVOID *)&TcpTable, TRUE, AF_INET, TCP_TABLE_BASIC_LISTENER) == ERROR_SUCCESS)
|
|
{
|
|
ok(TcpTable->dwNumEntries > 0, "No TCP connections?!\n");
|
|
|
|
Found = FALSE;
|
|
for (i = 0; i < TcpTable->dwNumEntries; ++i)
|
|
{
|
|
if (TcpTable->table[i].dwState == MIB_TCP_STATE_LISTEN &&
|
|
TcpTable->table[i].dwLocalAddr == 0 &&
|
|
TcpTable->table[i].dwLocalPort == htons(9876) &&
|
|
TcpTable->table[i].dwRemoteAddr == 0)
|
|
{
|
|
Found = TRUE;
|
|
break;
|
|
}
|
|
}
|
|
ok(Found, "Our socket wasn't found!\n");
|
|
|
|
HeapFree(GetProcessHeap(), 0, TcpTable);
|
|
}
|
|
else
|
|
{
|
|
skip("GetExtendedTcpTableWithAlloc failure\n");
|
|
}
|
|
|
|
if (GetExtendedTcpTableWithAlloc((PVOID *)&TcpTableOwner, TRUE, AF_INET, TCP_TABLE_OWNER_PID_ALL) == ERROR_SUCCESS)
|
|
{
|
|
ok(TcpTableOwner->dwNumEntries > 0, "No TCP connections?!\n");
|
|
|
|
Found = FALSE;
|
|
for (i = 0; i < TcpTableOwner->dwNumEntries; ++i)
|
|
{
|
|
if (TcpTableOwner->table[i].dwState == MIB_TCP_STATE_LISTEN &&
|
|
TcpTableOwner->table[i].dwLocalAddr == 0 &&
|
|
TcpTableOwner->table[i].dwLocalPort == htons(9876) &&
|
|
TcpTableOwner->table[i].dwRemoteAddr == 0)
|
|
{
|
|
Found = TRUE;
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (!Found)
|
|
{
|
|
skip("Our socket wasn't found!\n");
|
|
}
|
|
else
|
|
{
|
|
ok(TcpTableOwner->table[i].dwOwningPid == Pid, "Invalid owner\n");
|
|
}
|
|
|
|
HeapFree(GetProcessHeap(), 0, TcpTableOwner);
|
|
}
|
|
else
|
|
{
|
|
skip("GetExtendedTcpTableWithAlloc failure\n");
|
|
}
|
|
|
|
if (GetExtendedTcpTableWithAlloc((PVOID *)&TcpTableOwner, TRUE, AF_INET, TCP_TABLE_OWNER_PID_CONNECTIONS) == ERROR_SUCCESS)
|
|
{
|
|
Found = FALSE;
|
|
for (i = 0; i < TcpTableOwner->dwNumEntries; ++i)
|
|
{
|
|
if (TcpTableOwner->table[i].dwState == MIB_TCP_STATE_LISTEN &&
|
|
TcpTableOwner->table[i].dwLocalAddr == 0 &&
|
|
TcpTableOwner->table[i].dwLocalPort == htons(9876) &&
|
|
TcpTableOwner->table[i].dwRemoteAddr == 0)
|
|
{
|
|
Found = TRUE;
|
|
break;
|
|
}
|
|
}
|
|
ok(Found == FALSE, "Our socket was found!\n");
|
|
|
|
HeapFree(GetProcessHeap(), 0, TcpTableOwner);
|
|
}
|
|
else
|
|
{
|
|
skip("GetExtendedTcpTableWithAlloc failure\n");
|
|
}
|
|
|
|
if (GetExtendedTcpTableWithAlloc((PVOID *)&TcpTableOwner, TRUE, AF_INET, TCP_TABLE_OWNER_PID_LISTENER) == ERROR_SUCCESS)
|
|
{
|
|
ok(TcpTableOwner->dwNumEntries > 0, "No TCP connections?!\n");
|
|
|
|
Found = FALSE;
|
|
for (i = 0; i < TcpTableOwner->dwNumEntries; ++i)
|
|
{
|
|
if (TcpTableOwner->table[i].dwState == MIB_TCP_STATE_LISTEN &&
|
|
TcpTableOwner->table[i].dwLocalAddr == 0 &&
|
|
TcpTableOwner->table[i].dwLocalPort == htons(9876) &&
|
|
TcpTableOwner->table[i].dwRemoteAddr == 0)
|
|
{
|
|
Found = TRUE;
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (!Found)
|
|
{
|
|
skip("Our socket wasn't found!\n");
|
|
}
|
|
else
|
|
{
|
|
ok(TcpTableOwner->table[i].dwOwningPid == Pid, "Invalid owner\n");
|
|
}
|
|
|
|
HeapFree(GetProcessHeap(), 0, TcpTableOwner);
|
|
}
|
|
else
|
|
{
|
|
skip("GetExtendedTcpTableWithAlloc failure\n");
|
|
}
|
|
|
|
if (GetExtendedTcpTableWithAlloc((PVOID *)&TcpTableOwnerMod, TRUE, AF_INET, TCP_TABLE_OWNER_MODULE_ALL) == ERROR_SUCCESS)
|
|
{
|
|
ok(TcpTableOwnerMod->dwNumEntries > 0, "No TCP connections?!\n");
|
|
|
|
Found = FALSE;
|
|
for (i = 0; i < TcpTableOwnerMod->dwNumEntries; ++i)
|
|
{
|
|
if (TcpTableOwnerMod->table[i].dwState == MIB_TCP_STATE_LISTEN &&
|
|
TcpTableOwnerMod->table[i].dwLocalAddr == 0 &&
|
|
TcpTableOwnerMod->table[i].dwLocalPort == htons(9876) &&
|
|
TcpTableOwnerMod->table[i].dwRemoteAddr == 0)
|
|
{
|
|
Found = TRUE;
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (!Found)
|
|
{
|
|
skip("Our socket wasn't found!\n");
|
|
}
|
|
else
|
|
{
|
|
ok(TcpTableOwnerMod->table[i].dwOwningPid == Pid, "Invalid owner\n");
|
|
|
|
ok(TcpTableOwnerMod->table[i].liCreateTimestamp.QuadPart >= CreationTime.QuadPart, "Invalid time\n");
|
|
ok(TcpTableOwnerMod->table[i].liCreateTimestamp.QuadPart <= CreationTime.QuadPart + 60000000000LL, "Invalid time\n");
|
|
}
|
|
|
|
HeapFree(GetProcessHeap(), 0, TcpTableOwnerMod);
|
|
}
|
|
else
|
|
{
|
|
skip("GetExtendedTcpTableWithAlloc failure\n");
|
|
}
|
|
|
|
if (GetExtendedTcpTableWithAlloc((PVOID *)&TcpTableOwnerMod, TRUE, AF_INET, TCP_TABLE_OWNER_MODULE_CONNECTIONS) == ERROR_SUCCESS)
|
|
{
|
|
Found = FALSE;
|
|
for (i = 0; i < TcpTableOwnerMod->dwNumEntries; ++i)
|
|
{
|
|
if (TcpTableOwnerMod->table[i].dwState == MIB_TCP_STATE_LISTEN &&
|
|
TcpTableOwnerMod->table[i].dwLocalAddr == 0 &&
|
|
TcpTableOwnerMod->table[i].dwLocalPort == htons(9876) &&
|
|
TcpTableOwnerMod->table[i].dwRemoteAddr == 0)
|
|
{
|
|
Found = TRUE;
|
|
break;
|
|
}
|
|
}
|
|
ok(Found == FALSE, "Our socket was found!\n");
|
|
|
|
HeapFree(GetProcessHeap(), 0, TcpTableOwnerMod);
|
|
}
|
|
else
|
|
{
|
|
skip("GetExtendedTcpTableWithAlloc failure\n");
|
|
}
|
|
|
|
if (GetExtendedTcpTableWithAlloc((PVOID *)&TcpTableOwnerMod, TRUE, AF_INET, TCP_TABLE_OWNER_MODULE_LISTENER) == ERROR_SUCCESS)
|
|
{
|
|
ok(TcpTableOwnerMod->dwNumEntries > 0, "No TCP connections?!\n");
|
|
|
|
Found = FALSE;
|
|
for (i = 0; i < TcpTableOwnerMod->dwNumEntries; ++i)
|
|
{
|
|
if (TcpTableOwnerMod->table[i].dwState == MIB_TCP_STATE_LISTEN &&
|
|
TcpTableOwnerMod->table[i].dwLocalAddr == 0 &&
|
|
TcpTableOwnerMod->table[i].dwLocalPort == htons(9876) &&
|
|
TcpTableOwnerMod->table[i].dwRemoteAddr == 0)
|
|
{
|
|
Found = TRUE;
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (!Found)
|
|
{
|
|
skip("Our socket wasn't found!\n");
|
|
}
|
|
else
|
|
{
|
|
ok(TcpTableOwnerMod->table[i].dwOwningPid == Pid, "Invalid owner\n");
|
|
|
|
ok(TcpTableOwnerMod->table[i].liCreateTimestamp.QuadPart >= CreationTime.QuadPart, "Invalid time\n");
|
|
ok(TcpTableOwnerMod->table[i].liCreateTimestamp.QuadPart <= CreationTime.QuadPart + 60000000000LL, "Invalid time\n");
|
|
}
|
|
|
|
HeapFree(GetProcessHeap(), 0, TcpTableOwnerMod);
|
|
}
|
|
else
|
|
{
|
|
skip("GetExtendedTcpTableWithAlloc failure\n");
|
|
}
|
|
|
|
quit2:
|
|
closesocket(sock);
|
|
quit:
|
|
WSACleanup();
|
|
}
|