/* * PROJECT: ReactOS API Tests * LICENSE: GPL-2.0+ (https://spdx.org/licenses/GPL-2.0+) * PURPOSE: Tests for UDP connections owner functions * COPYRIGHT: Copyright 2018 Pierre Schweitzer */ #include #define WIN32_NO_STATUS #include #include static DWORD GetExtendedUdpTableWithAlloc(PVOID *UdpTable, BOOL Order, DWORD Family, UDP_TABLE_CLASS Class) { DWORD ret; DWORD Size = 0; *UdpTable = NULL; ret = GetExtendedUdpTable(*UdpTable, &Size, Order, Family, Class, 0); if (ret == ERROR_INSUFFICIENT_BUFFER) { *UdpTable = HeapAlloc(GetProcessHeap(), 0, Size); if (*UdpTable == NULL) { return ERROR_OUTOFMEMORY; } ret = GetExtendedUdpTable(*UdpTable, &Size, Order, Family, Class, 0); if (ret != NO_ERROR) { HeapFree(GetProcessHeap(), 0, *UdpTable); *UdpTable = NULL; } } return ret; } START_TEST(GetOwnerModuleFromUdpEntry) { WSADATA wsaData; SOCKET sock; SOCKADDR_IN server; PMIB_UDPTABLE_OWNER_MODULE UdpTableOwnerMod; 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_DGRAM, IPPROTO_UDP); 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 (GetExtendedUdpTableWithAlloc((PVOID *)&UdpTableOwnerMod, TRUE, AF_INET, UDP_TABLE_OWNER_MODULE) == ERROR_SUCCESS) { ok(UdpTableOwnerMod->dwNumEntries > 0, "No UDP connections?!\n"); Found = FALSE; for (i = 0; i < UdpTableOwnerMod->dwNumEntries; ++i) { if (UdpTableOwnerMod->table[i].dwLocalAddr == 0 && UdpTableOwnerMod->table[i].dwLocalPort == htons(9876)) { Found = TRUE; break; } } if (!Found) { skip("Our socket wasn't found!\n"); } else { DWORD Size = 0; PTCPIP_OWNER_MODULE_BASIC_INFO BasicInfo = NULL; ok(UdpTableOwnerMod->table[i].dwOwningPid == Pid, "Invalid owner\n"); ok(UdpTableOwnerMod->table[i].liCreateTimestamp.QuadPart >= CreationTime.QuadPart, "Invalid time\n"); ok(UdpTableOwnerMod->table[i].liCreateTimestamp.QuadPart <= CreationTime.QuadPart + 60000000000LL, "Invalid time\n"); if (GetOwnerModuleFromUdpEntry(&UdpTableOwnerMod->table[i], TCPIP_OWNER_MODULE_INFO_BASIC, BasicInfo, &Size) == ERROR_INSUFFICIENT_BUFFER) { BasicInfo = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, Size); ok(BasicInfo != NULL, "HeapAlloc failed\n"); if (GetOwnerModuleFromUdpEntry(&UdpTableOwnerMod->table[i], TCPIP_OWNER_MODULE_INFO_BASIC, BasicInfo, &Size) == ERROR_SUCCESS) { WCHAR CurrentModule[MAX_PATH]; PWSTR FileName; if (GetModuleFileNameW(NULL, CurrentModule, MAX_PATH) != 0) { FileName = wcsrchr(CurrentModule, L'\\'); ++FileName; ok(_wcsicmp(CurrentModule, BasicInfo->pModulePath) == 0, "Mismatching names (%S, %S)\n", CurrentModule, BasicInfo->pModulePath); ok(_wcsicmp(FileName, BasicInfo->pModuleName) == 0, "Mismatching names (%S, %S)\n", FileName, BasicInfo->pModuleName); } else { skip("GetModuleFileNameW failed\n"); } } else { skip("GetOwnerModuleFromTcpEntry failed\n"); } } else { skip("GetOwnerModuleFromTcpEntry failed\n"); } } HeapFree(GetProcessHeap(), 0, UdpTableOwnerMod); } else { skip("GetExtendedUdpTableWithAlloc failure\n"); } quit2: closesocket(sock); quit: WSACleanup(); }