Commit 2aebe0b6 authored by Zebediah Figura's avatar Zebediah Figura Committed by Alexandre Julliard

ws2_32/tests: Fix a test failure on w10pro64.

parent ff8b5a51
...@@ -6268,7 +6268,7 @@ static BOOL poll_isset(WSAPOLLFD *fds, int max, SOCKET s, int rev) ...@@ -6268,7 +6268,7 @@ static BOOL poll_isset(WSAPOLLFD *fds, int max, SOCKET s, int rev)
static void test_WSAPoll(void) static void test_WSAPoll(void)
{ {
int ix, ret, err, poll_timeout; int ix, ret, err;
SOCKET fdListen, fdRead, fdWrite; SOCKET fdListen, fdRead, fdWrite;
struct sockaddr_in address; struct sockaddr_in address;
socklen_t len; socklen_t len;
...@@ -6315,19 +6315,18 @@ static void test_WSAPoll(void) ...@@ -6315,19 +6315,18 @@ static void test_WSAPoll(void)
address.sin_family = AF_INET; address.sin_family = AF_INET;
len = sizeof(address); len = sizeof(address);
fdListen = setup_server_socket(&address, &len); fdListen = setup_server_socket(&address, &len);
poll_timeout = 100;
/* When no events are pending poll returns 0 with no error */ /* When no events are pending poll returns 0 with no error */
POLL_CLEAR(); POLL_CLEAR();
POLL_SET(fdListen, POLLIN); POLL_SET(fdListen, POLLIN);
ret = pWSAPoll(fds, ix, poll_timeout); ret = pWSAPoll(fds, ix, 100);
ok(ret == 0, "expected 0, got %d\n", ret); ok(ret == 0, "expected 0, got %d\n", ret);
/* Test listening socket connection attempt notifications */ /* Test listening socket connection attempt notifications */
fdWrite = setup_connector_socket(&address, len, TRUE); fdWrite = setup_connector_socket(&address, len, TRUE);
POLL_CLEAR(); POLL_CLEAR();
POLL_SET(fdListen, POLLIN | POLLOUT); POLL_SET(fdListen, POLLIN | POLLOUT);
ret = pWSAPoll(fds, ix, poll_timeout); ret = pWSAPoll(fds, ix, 100);
ok(ret == 1, "expected 1, got %d\n", ret); ok(ret == 1, "expected 1, got %d\n", ret);
ok(POLL_ISSET(fdListen, POLLRDNORM), "fdListen socket events incorrect\n"); ok(POLL_ISSET(fdListen, POLLRDNORM), "fdListen socket events incorrect\n");
len = sizeof(address); len = sizeof(address);
...@@ -6339,7 +6338,7 @@ static void test_WSAPoll(void) ...@@ -6339,7 +6338,7 @@ static void test_WSAPoll(void)
POLL_SET(fdListen, POLLIN | POLLOUT); POLL_SET(fdListen, POLLIN | POLLOUT);
POLL_SET(fdRead, POLLIN | POLLOUT); POLL_SET(fdRead, POLLIN | POLLOUT);
POLL_SET(fdWrite, POLLIN | POLLOUT); POLL_SET(fdWrite, POLLIN | POLLOUT);
ret = pWSAPoll(fds, ix, poll_timeout); ret = pWSAPoll(fds, ix, 100);
ok(ret == 2, "expected 2, got %d\n", ret); ok(ret == 2, "expected 2, got %d\n", ret);
ok(POLL_ISSET(fdWrite, POLLWRNORM), "fdWrite socket events incorrect\n"); ok(POLL_ISSET(fdWrite, POLLWRNORM), "fdWrite socket events incorrect\n");
ok(POLL_ISSET(fdRead, POLLWRNORM), "fdRead socket events incorrect\n"); ok(POLL_ISSET(fdRead, POLLWRNORM), "fdRead socket events incorrect\n");
...@@ -6355,7 +6354,7 @@ static void test_WSAPoll(void) ...@@ -6355,7 +6354,7 @@ static void test_WSAPoll(void)
POLL_CLEAR(); POLL_CLEAR();
POLL_SET(fdListen, POLLIN | POLLOUT); POLL_SET(fdListen, POLLIN | POLLOUT);
POLL_SET(fdRead, POLLIN); POLL_SET(fdRead, POLLIN);
ret = pWSAPoll(fds, ix, poll_timeout); ret = pWSAPoll(fds, ix, 100);
ok(ret == 1, "expected 1, got %d\n", ret); ok(ret == 1, "expected 1, got %d\n", ret);
ok(POLL_ISSET(fdRead, POLLRDNORM), "fdRead socket events incorrect\n"); ok(POLL_ISSET(fdRead, POLLRDNORM), "fdRead socket events incorrect\n");
ret = recv(fdRead, tmp_buf, sizeof(tmp_buf), 0); ret = recv(fdRead, tmp_buf, sizeof(tmp_buf), 0);
...@@ -6368,7 +6367,7 @@ static void test_WSAPoll(void) ...@@ -6368,7 +6367,7 @@ static void test_WSAPoll(void)
POLL_CLEAR(); POLL_CLEAR();
POLL_SET(fdListen, POLLIN | POLLOUT); POLL_SET(fdListen, POLLIN | POLLOUT);
POLL_SET(fdRead, POLLIN); POLL_SET(fdRead, POLLIN);
ret = pWSAPoll(fds, ix, poll_timeout); ret = pWSAPoll(fds, ix, 100);
ok(ret == 1, "expected 1, got %d\n", ret); ok(ret == 1, "expected 1, got %d\n", ret);
ok(POLL_ISSET(fdRead, POLLRDBAND), "fdRead socket events incorrect\n"); ok(POLL_ISSET(fdRead, POLLRDBAND), "fdRead socket events incorrect\n");
tmp_buf[0] = 0xAF; tmp_buf[0] = 0xAF;
...@@ -6385,7 +6384,7 @@ static void test_WSAPoll(void) ...@@ -6385,7 +6384,7 @@ static void test_WSAPoll(void)
POLL_CLEAR(); POLL_CLEAR();
POLL_SET(fdListen, POLLIN | POLLOUT); POLL_SET(fdListen, POLLIN | POLLOUT);
POLL_SET(fdRead, POLLIN | POLLOUT); POLL_SET(fdRead, POLLIN | POLLOUT);
ret = pWSAPoll(fds, ix, poll_timeout); ret = pWSAPoll(fds, ix, 100);
ok(ret == 1, "expected 1, got %d\n", ret); ok(ret == 1, "expected 1, got %d\n", ret);
tmp_buf[0] = 0xAF; tmp_buf[0] = 0xAF;
SetLastError(0xdeadbeef); SetLastError(0xdeadbeef);
...@@ -6402,34 +6401,34 @@ static void test_WSAPoll(void) ...@@ -6402,34 +6401,34 @@ static void test_WSAPoll(void)
POLL_CLEAR(); POLL_CLEAR();
POLL_SET(fdListen, POLLIN | POLLOUT); POLL_SET(fdListen, POLLIN | POLLOUT);
POLL_SET(fdWrite, POLLIN); POLL_SET(fdWrite, POLLIN);
ret = pWSAPoll(fds, ix, poll_timeout); ret = pWSAPoll(fds, ix, 100);
ok(ret == 1, "expected 1, got %d\n", ret); ok(ret == 1, "expected 1, got %d\n", ret);
ok(POLL_ISSET(fdWrite, POLLHUP), "fdWrite socket events incorrect\n"); ok(POLL_ISSET(fdWrite, POLLHUP), "fdWrite socket events incorrect\n");
ret = recv(fdWrite, tmp_buf, sizeof(tmp_buf), 0); ret = recv(fdWrite, tmp_buf, sizeof(tmp_buf), 0);
ok(ret == 0, "expected 0, got %d\n", ret); ok(ret == 0, "expected 0, got %d\n", ret);
/* When a connection is attempted to a non-listening socket due to a bug
* in the MS code it will never be notified. This is a long standing issue
* that will never be fixed for compatibility reasons so we have to deal
* with it manually. */
ret = closesocket(fdWrite); ret = closesocket(fdWrite);
ok(ret == 0, "expected 0, got %d\n", ret); ok(ret == 0, "expected 0, got %d\n", ret);
ret = closesocket(fdListen); ret = closesocket(fdListen);
ok(ret == 0, "expected 0, got %d\n", ret); ok(ret == 0, "expected 0, got %d\n", ret);
len = sizeof(address);
fdWrite = setup_connector_socket(&address, len, TRUE); /* The following WSAPoll() call times out on versions older than w10pro64,
POLL_CLEAR(); * but even on w10pro64 it takes over 2 seconds for an error to be reported,
POLL_SET(fdWrite, POLLIN | POLLOUT); * so make the test interactive-only. */
poll_timeout = 2000; if (winetest_interactive)
ret = pWSAPoll(fds, ix, poll_timeout); {
todo_wine len = sizeof(address);
ok(ret == 0, "expected 0, got %d\n", ret); fdWrite = setup_connector_socket(&address, len, TRUE);
len = sizeof(id); POLL_CLEAR();
id = 0xdeadbeef; POLL_SET(fdWrite, POLLIN | POLLOUT);
err = getsockopt(fdWrite, SOL_SOCKET, SO_ERROR, (char*)&id, &len); ret = pWSAPoll(fds, ix, 10000);
ok(!err, "getsockopt failed with %d\n", WSAGetLastError()); ok(ret == 1, "expected 0, got %d\n", ret);
ok(id == WSAECONNREFUSED, "expected 10061, got %d\n", id); len = sizeof(id);
closesocket(fdWrite); id = 0xdeadbeef;
err = getsockopt(fdWrite, SOL_SOCKET, SO_ERROR, (char*)&id, &len);
ok(!err, "getsockopt failed with %d\n", WSAGetLastError());
ok(id == WSAECONNREFUSED, "expected 10061, got %d\n", id);
closesocket(fdWrite);
}
/* Try poll() on a closed socket after connection */ /* Try poll() on a closed socket after connection */
tcp_socketpair(&fdRead, &fdWrite); tcp_socketpair(&fdRead, &fdWrite);
...@@ -6437,12 +6436,12 @@ todo_wine ...@@ -6437,12 +6436,12 @@ todo_wine
POLL_CLEAR(); POLL_CLEAR();
POLL_SET(fdWrite, POLLIN | POLLOUT); POLL_SET(fdWrite, POLLIN | POLLOUT);
POLL_SET(fdRead, POLLIN | POLLOUT); POLL_SET(fdRead, POLLIN | POLLOUT);
ret = pWSAPoll(fds, ix, poll_timeout); ret = pWSAPoll(fds, ix, 2000);
ok(ret == 1, "expected 1, got %d\n", ret); ok(ret == 1, "expected 1, got %d\n", ret);
ok(POLL_ISSET(fdRead, POLLNVAL), "fdRead socket events incorrect\n"); ok(POLL_ISSET(fdRead, POLLNVAL), "fdRead socket events incorrect\n");
POLL_CLEAR(); POLL_CLEAR();
POLL_SET(fdWrite, POLLIN | POLLOUT); POLL_SET(fdWrite, POLLIN | POLLOUT);
ret = pWSAPoll(fds, ix, poll_timeout); ret = pWSAPoll(fds, ix, 2000);
ok(ret == 1, "expected 1, got %d\n", ret); ok(ret == 1, "expected 1, got %d\n", ret);
todo_wine todo_wine
ok(POLL_ISSET(fdWrite, POLLWRNORM | POLLHUP) || broken(POLL_ISSET(fdWrite, POLLWRNORM)) /* <= 2008 */, ok(POLL_ISSET(fdWrite, POLLWRNORM | POLLHUP) || broken(POLL_ISSET(fdWrite, POLLWRNORM)) /* <= 2008 */,
...@@ -6455,7 +6454,7 @@ todo_wine ...@@ -6455,7 +6454,7 @@ todo_wine
ok(thread_handle != NULL, "CreateThread failed unexpectedly: %d\n", GetLastError()); ok(thread_handle != NULL, "CreateThread failed unexpectedly: %d\n", GetLastError());
POLL_CLEAR(); POLL_CLEAR();
POLL_SET(fdWrite, POLLIN | POLLOUT); POLL_SET(fdWrite, POLLIN | POLLOUT);
ret = pWSAPoll(fds, ix, poll_timeout); ret = pWSAPoll(fds, ix, 2000);
ok(ret == 1, "expected 1, got %d\n", ret); ok(ret == 1, "expected 1, got %d\n", ret);
ok(POLL_ISSET(fdWrite, POLLWRNORM), "fdWrite socket events incorrect\n"); ok(POLL_ISSET(fdWrite, POLLWRNORM), "fdWrite socket events incorrect\n");
WaitForSingleObject (thread_handle, 1000); WaitForSingleObject (thread_handle, 1000);
...@@ -6466,7 +6465,7 @@ todo_wine ...@@ -6466,7 +6465,7 @@ todo_wine
ok(thread_handle != NULL, "CreateThread failed unexpectedly: %d\n", GetLastError()); ok(thread_handle != NULL, "CreateThread failed unexpectedly: %d\n", GetLastError());
POLL_CLEAR(); POLL_CLEAR();
POLL_SET(fdWrite, POLLIN); POLL_SET(fdWrite, POLLIN);
ret = pWSAPoll(fds, ix, poll_timeout); ret = pWSAPoll(fds, ix, 2000);
ok(ret == 1, "expected 1, got %d\n", ret); ok(ret == 1, "expected 1, got %d\n", ret);
ok(POLL_ISSET(fdWrite, POLLNVAL), "fdWrite socket events incorrect\n"); ok(POLL_ISSET(fdWrite, POLLNVAL), "fdWrite socket events incorrect\n");
WaitForSingleObject (thread_handle, 1000); WaitForSingleObject (thread_handle, 1000);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment