[PATCH 1/2] ws2_32/tests: Test whether WSAEventSelect() modifies the event state.
Zebediah Figura
zfigura at codeweavers.com
Wed Jan 5 19:03:03 CST 2022
Signed-off-by: Zebediah Figura <zfigura at codeweavers.com>
---
dlls/ws2_32/tests/sock.c | 36 ++++++++++++++++++++++++++++++++++++
1 file changed, 36 insertions(+)
diff --git a/dlls/ws2_32/tests/sock.c b/dlls/ws2_32/tests/sock.c
index 50f79e6adb8..db6819e77cf 100644
--- a/dlls/ws2_32/tests/sock.c
+++ b/dlls/ws2_32/tests/sock.c
@@ -5186,6 +5186,42 @@ static void test_accept_events(struct event_test_ctx *ctx)
closesocket(server);
closesocket(client);
+ /* As above, but select on a subset containing FD_ACCEPT first. */
+
+ if (!ctx->is_message)
+ {
+ select_events(ctx, listener, FD_CONNECT | FD_READ | FD_OOB | FD_ACCEPT);
+
+ client = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
+ ok(client != -1, "failed to create socket, error %u\n", WSAGetLastError());
+ ret = connect(client, (struct sockaddr *)&destaddr, sizeof(destaddr));
+ ok(!ret, "failed to connect, error %u\n", WSAGetLastError());
+
+ ret = WaitForSingleObject(ctx->event, 200);
+ ok(!ret, "wait timed out\n");
+
+ select_events(ctx, listener, FD_CONNECT | FD_READ | FD_OOB);
+ ret = WaitForSingleObject(ctx->event, 0);
+ ok(!ret, "wait timed out\n");
+
+ ResetEvent(ctx->event);
+
+ select_events(ctx, listener, FD_CONNECT | FD_READ | FD_OOB);
+ ret = WaitForSingleObject(ctx->event, 0);
+ ok(ret == WAIT_TIMEOUT, "expected timeout\n");
+
+ select_events(ctx, listener, FD_CONNECT | FD_READ | FD_OOB | FD_ACCEPT);
+ ret = WaitForSingleObject(ctx->event, 0);
+ todo_wine ok(!ret, "wait timed out\n");
+ if (!ret)
+ check_events(ctx, FD_ACCEPT, 0, 0);
+
+ server = accept(listener, NULL, NULL);
+ ok(server != -1, "failed to accept, error %u\n", WSAGetLastError());
+ closesocket(server);
+ closesocket(client);
+ }
+
/* As above, but select on a subset not containing FD_ACCEPT first. */
select_events(ctx, listener, FD_CONNECT | FD_READ | FD_OOB);
--
2.34.1
More information about the wine-devel
mailing list