Erich Hoover : ws2_32/tests: Test for AcceptEx IOCP behavior for cancelled sockets.
Alexandre Julliard
julliard at winehq.org
Tue May 1 13:12:14 CDT 2012
Module: wine
Branch: master
Commit: 23a785af7e5a3e876b0c49c790fe30298cf0cdfa
URL: http://source.winehq.org/git/wine.git/?a=commit;h=23a785af7e5a3e876b0c49c790fe30298cf0cdfa
Author: Erich Hoover <ehoover at mines.edu>
Date: Mon Apr 30 21:13:37 2012 -0600
ws2_32/tests: Test for AcceptEx IOCP behavior for cancelled sockets.
---
dlls/ws2_32/tests/sock.c | 43 +++++++++++++++++++++++++++++++++++++++++++
1 files changed, 43 insertions(+), 0 deletions(-)
diff --git a/dlls/ws2_32/tests/sock.c b/dlls/ws2_32/tests/sock.c
index ac5cef5..54fa086 100644
--- a/dlls/ws2_32/tests/sock.c
+++ b/dlls/ws2_32/tests/sock.c
@@ -5510,6 +5510,49 @@ static void test_completion_port(void)
ok(num_bytes == 0xdeadbeef, "Number of bytes transferred is %u\n", num_bytes);
ok(!olp, "Overlapped structure is at %p\n", olp);
+ /* Test IOCP response on socket close (IOCP created before AcceptEx) */
+
+ if ((src = setup_iocp_src(&bindAddress)) == INVALID_SOCKET)
+ goto end;
+
+ SetLastError(0xdeadbeef);
+
+ io_port = CreateIoCompletionPort((HANDLE)src, previous_port, 125, 0);
+ ok(io_port != NULL, "failed to create completion port %u\n", GetLastError());
+
+ bret = pAcceptEx(src, dest, buf, sizeof(buf) - 2*(sizeof(struct sockaddr_in) + 16),
+ sizeof(struct sockaddr_in) + 16, sizeof(struct sockaddr_in) + 16,
+ &num_bytes, &ov);
+ ok(bret == FALSE, "AcceptEx returned %d\n", bret);
+ ok(GetLastError() == ERROR_IO_PENDING, "Last error was %d\n", GetLastError());
+
+ closesocket(src);
+ src = INVALID_SOCKET;
+
+ SetLastError(0xdeadbeef);
+ key = 0xdeadbeef;
+ num_bytes = 0xdeadbeef;
+ olp = (WSAOVERLAPPED *)0xdeadbeef;
+
+ bret = GetQueuedCompletionStatus(io_port, &num_bytes, &key, &olp, 100);
+ ok(bret == FALSE, "failed to get completion status %u\n", bret);
+ todo_wine ok(GetLastError() == ERROR_OPERATION_ABORTED, "Last error was %d\n", GetLastError());
+ todo_wine ok(key == 125, "Key is %lu\n", key);
+ todo_wine ok(num_bytes == 0, "Number of bytes transferred is %u\n", num_bytes);
+ todo_wine ok(olp == &ov, "Overlapped structure is at %p\n", olp);
+ todo_wine ok(olp && (olp->Internal == (ULONG)STATUS_CANCELLED), "Internal status is %lx\n", olp ? olp->Internal : 0);
+
+ SetLastError(0xdeadbeef);
+ key = 0xdeadbeef;
+ num_bytes = 0xdeadbeef;
+ olp = (WSAOVERLAPPED *)0xdeadbeef;
+ bret = GetQueuedCompletionStatus( io_port, &num_bytes, &key, &olp, 200 );
+ ok(bret == FALSE, "failed to get completion status %u\n", bret);
+ ok(GetLastError() == WAIT_TIMEOUT, "Last error was %d\n", GetLastError());
+ ok(key == 0xdeadbeef, "Key is %lu\n", key);
+ ok(num_bytes == 0xdeadbeef, "Number of bytes transferred is %u\n", num_bytes);
+ ok(!olp, "Overlapped structure is at %p\n", olp);
+
/* */
if ((src = setup_iocp_src(&bindAddress)) == INVALID_SOCKET)
More information about the wine-cvs
mailing list