[PATCH 1/5] ws2_32/tests: Add more tests for sockets that cannot be accepted into.
Zebediah Figura
z.figura12 at gmail.com
Thu Jun 3 21:41:52 CDT 2021
Signed-off-by: Zebediah Figura <z.figura12 at gmail.com>
---
dlls/ws2_32/tests/sock.c | 56 ++++++++++++++++++++++++++++++++++++++++
1 file changed, 56 insertions(+)
diff --git a/dlls/ws2_32/tests/sock.c b/dlls/ws2_32/tests/sock.c
index f165742fe45..592baa806c3 100644
--- a/dlls/ws2_32/tests/sock.c
+++ b/dlls/ws2_32/tests/sock.c
@@ -6402,6 +6402,7 @@ static void test_ConnectEx(void)
static void test_AcceptEx(void)
{
+ const struct sockaddr_in bind_addr = {.sin_family = AF_INET, .sin_addr.s_addr = htonl(INADDR_LOOPBACK)};
SOCKET listener, acceptor, acceptor2, connector, connector2;
struct sockaddr_in bindAddress, peerAddress, *readBindAddress, *readRemoteAddress;
int socklen, optlen;
@@ -6525,6 +6526,61 @@ todo_wine
closesocket(connector);
closesocket(acceptor);
+ /* A UDP socket cannot be accepted into. */
+
+ acceptor = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP);
+
+ overlapped.Internal = 0xdeadbeef;
+ bret = pAcceptEx(listener, acceptor, buffer, 0, 0, sizeof(struct sockaddr_in) + 16, &bytesReturned, &overlapped);
+ ok(!bret, "expected failure\n");
+ todo_wine ok(WSAGetLastError() == WSAEINVAL, "got error %u\n", WSAGetLastError());
+ ok(overlapped.Internal == STATUS_PENDING, "got status %#x\n", (NTSTATUS)overlapped.Internal);
+ if (WSAGetLastError() == ERROR_IO_PENDING)
+ CancelIo((HANDLE)listener);
+
+ closesocket(acceptor);
+
+ /* A bound socket cannot be accepted into. */
+
+ acceptor = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
+ iret = bind(acceptor, (const struct sockaddr *)&bind_addr, sizeof(bind_addr));
+ ok(!iret, "got error %u\n", WSAGetLastError());
+
+ overlapped.Internal = 0xdeadbeef;
+ bret = pAcceptEx(listener, acceptor, buffer, 0, 0, sizeof(struct sockaddr_in) + 16, &bytesReturned, &overlapped);
+ ok(!bret, "expected failure\n");
+ todo_wine ok(WSAGetLastError() == WSAEINVAL, "got error %u\n", WSAGetLastError());
+ ok(overlapped.Internal == STATUS_PENDING, "got status %#x\n", (NTSTATUS)overlapped.Internal);
+ if (WSAGetLastError() == ERROR_IO_PENDING)
+ CancelIo((HANDLE)listener);
+
+ closesocket(acceptor);
+
+ /* A connected socket cannot be accepted into. */
+
+ tcp_socketpair(&acceptor, &acceptor2);
+
+ overlapped.Internal = 0xdeadbeef;
+ bret = pAcceptEx(listener, acceptor, buffer, 0, 0, sizeof(struct sockaddr_in) + 16, &bytesReturned, &overlapped);
+ ok(!bret, "expected failure\n");
+ todo_wine ok(WSAGetLastError() == WSAEINVAL, "got error %u\n", WSAGetLastError());
+ ok(overlapped.Internal == STATUS_PENDING, "got status %#x\n", (NTSTATUS)overlapped.Internal);
+ if (WSAGetLastError() == ERROR_IO_PENDING)
+ CancelIo((HANDLE)listener);
+
+ overlapped.Internal = 0xdeadbeef;
+ bret = pAcceptEx(listener, acceptor2, buffer, 0, 0, sizeof(struct sockaddr_in) + 16, &bytesReturned, &overlapped);
+ ok(!bret, "expected failure\n");
+ todo_wine ok(WSAGetLastError() == WSAEINVAL, "got error %u\n", WSAGetLastError());
+ ok(overlapped.Internal == STATUS_PENDING, "got status %#x\n", (NTSTATUS)overlapped.Internal);
+ if (WSAGetLastError() == ERROR_IO_PENDING)
+ CancelIo((HANDLE)listener);
+
+ closesocket(acceptor);
+ closesocket(acceptor2);
+
+ /* Pass an insufficient local address size. */
+
acceptor = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
ok(acceptor != -1, "failed to create socket, error %u\n", WSAGetLastError());
--
2.30.2
More information about the wine-devel
mailing list