RFR: 8343791: Socket.connect API should document whether the socket will be closed when hostname resolution fails or another error occurs [v13]
Mark Sheppard
msheppar at openjdk.org
Fri Nov 22 21:35:18 UTC 2024
On Fri, 22 Nov 2024 09:32:43 GMT, Volkan Yazıcı <duke at openjdk.org> wrote:
>> This PR, addressing 8343791, changes `Socket::connect()` methods to close the `Socket` in the event that the connection cannot be established, the timeout expires before the connection is established, or the socket address is unresolved.
>>
>> `tier3` tests pass against the 9f00f61d3b7fa42a5e23a04f80bb4bb1a2076ef2.
>
> Volkan Yazıcı has updated the pull request incrementally with one additional commit since the last revision:
>
> Improve naming in tests
test/jdk/java/net/Socket/CloseOnFailureTest.java line 162:
> 160: MockSocketImpl socketImpl = new MockSocketImpl(null, null);
> 161: try (Socket socket = new Socket(socketImpl) {}) {
> 162: InetSocketAddress address = InetSocketAddress.createUnresolved("no.such.host", 0xBEEF);
similar to DEADSERVERPORT
specifying a hex value, albeit a joke value, it is still a valid ephemeral port, and distracts from the main invocation InetAddress.createUnresolved, so consider a constant declaration for the port
private static final int NOSUCHHOSTPORT = 0xBEEF;
then the invocation is
InetAddress.createUnresolved("no.such.host", NOSUCHHOSTPORT);
presenting an unambiguous statement that the InetAddress not meant to be reachable !
-------------
PR Review Comment: https://git.openjdk.org/jdk/pull/22160#discussion_r1854729766
More information about the net-dev
mailing list