1
0
mirror of https://github.com/libuv/libuv synced 2025-03-28 21:13:16 +00:00

unix,tcp: allow 0 delay in uv_tcp_keepalive

The removed check was introduced in
https://github.com/libuv/libuv/pull/4272 but it breaks previously
working (and documented) behavior: https://nodejs.org/api/net.html#socketsetkeepaliveenable-initialdelay
This commit is contained in:
Saúl Ibarra Corretgé 2024-03-08 11:28:00 +01:00
parent 6912038d72
commit 14403a8f63
2 changed files with 7 additions and 4 deletions

View File

@ -467,9 +467,6 @@ int uv__tcp_keepalive(int fd, int on, unsigned int delay) {
if (!on)
return 0;
if (delay == 0)
return -1;
#ifdef __sun
/* The implementation of TCP keep-alive on Solaris/SmartOS is a bit unusual
* compared to other Unix-like systems.

View File

@ -33,7 +33,7 @@ TEST_IMPL(tcp_flags) {
loop = uv_default_loop();
r = uv_tcp_init(loop, &handle);
r = uv_tcp_init_ex(loop, &handle, AF_INET);
ASSERT_OK(r);
r = uv_tcp_nodelay(&handle, 1);
@ -42,6 +42,12 @@ TEST_IMPL(tcp_flags) {
r = uv_tcp_keepalive(&handle, 1, 60);
ASSERT_OK(r);
r = uv_tcp_keepalive(&handle, 0, 0);
ASSERT_OK(r);
r = uv_tcp_keepalive(&handle, 1, 0);
ASSERT_OK(r);
uv_close((uv_handle_t*)&handle, NULL);
r = uv_run(loop, UV_RUN_DEFAULT);