RFR: 8343791: Socket.connect API should document whether the socket will be closed when hostname resolution fails or another error occurs [v4]
Volkan Yazıcı
duke at openjdk.org
Mon Nov 25 09:28:36 UTC 2024
On Wed, 20 Nov 2024 13:41:40 GMT, Alan Bateman <alanb at openjdk.org> wrote:
>> Imagine `bind()` succeeding, yet `connect()` failing due to an `IAE` thrown by `SocketImpl#connect()`. This would leave the socket in `BOUND` state. Hence, shouldn't we include the `connect()` in the try-catch block too?
>
> I don't mind if we have a broader try-finally but it would be a bug if connect were to throw IAE. All the validation should be done before delegating to the SocketImpl.
@AlanBateman, this assertion causes `IDNTest` to fail:
java.lang.AssertionError
at java.base/java.net.Socket.<init>(Socket.java:457)
at java.base/java.net.Socket.<init>(Socket.java:276)
at IDNTest.main(IDNTest.java:37)
How shall I proceed?
-------------
PR Review Comment: https://git.openjdk.org/jdk/pull/22160#discussion_r1856218107
More information about the net-dev
mailing list