-
-
Notifications
You must be signed in to change notification settings - Fork 35k
Open
Labels
docIssues and PRs related to the documentations.Issues and PRs related to the documentations.netIssues and PRs related to the net subsystem.Issues and PRs related to the net subsystem.
Description
Version
22.14.0
Platform
N/A
Subsystem
No response
What steps will reproduce the bug?
Create a TCP socket and call socket.setKeepAlive(true, 400).
How often does it reproduce? Is there a required condition?
Any keepalive less than 1 second.
What is the expected behavior? Why is that the expected behavior?
This should send keepalive packets every 400 ms.
The documentation says as much:
keepAliveInitialDelay{number} If set to a positive number, it sets the
initial delay before the first keepalive probe is sent on an idle socket.
Default:0.
What do you see instead?
The code truncates to the nearest 1000ms, so the socket doesn't send keepalive packets and no error is issued.
Additional information
It seems this parameter is even broken in the tests.
node/test/parallel/test-net-keepalive.js
Line 42 in 3db5491
| connection.setKeepAlive(true, common.platformTimeout(50)); |
| const s = clientConnection.setKeepAlive(true, 400); |
Ideally, the keepalive interval would be respected in milliseconds. Assuming that's infeasible,
- a runtime warning should be issued if setKeepAlive is given a value <1000.
- the documentation should be updated to reflect that, even though the value is given in milliseconds, it will only be respected to the second.
Reactions are currently unavailable
Metadata
Metadata
Assignees
Labels
docIssues and PRs related to the documentations.Issues and PRs related to the documentations.netIssues and PRs related to the net subsystem.Issues and PRs related to the net subsystem.