RFR: 8343791: Socket.connect API should document whether the socket will be closed when hostname resolution fails or another error occurs [v26]
Daniel Fuchs
dfuchs at openjdk.org
Fri Nov 29 15:43:43 UTC 2024
On Fri, 29 Nov 2024 15:29:06 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 two additional commits since the last revision:
>
> - Improve Javadoc
> - Match `UHE` message in `Socket` and `SocketImpl`
>
> This discrepancy was causing following tests to fail:
>
> - javax/xml/jaxp/unittest/common/dtd/DOMTest.java
> - javax/xml/jaxp/unittest/common/dtd/SAXTest.java
> - javax/xml/jaxp/unittest/common/catalog/SAXTest.java
> - javax/xml/jaxp/unittest/common/catalog/DOMTest.java
Marked as reviewed by dfuchs (Reviewer).
src/java.base/share/classes/java/net/Socket.java line 664:
> 662:
> 663: if (epoint.isUnresolved()) {
> 664: var uhe = new UnknownHostException(epoint.getHostName());
In this instance, I believe reverting to the same message as was thrown before and reconciling Socket with SocketImpl is the right call. The change to the exception message was somewhat gratuitous. Since it makes several tests fail, let's avoid that.
-------------
PR Review: https://git.openjdk.org/jdk/pull/22160#pullrequestreview-2470195551
PR Review Comment: https://git.openjdk.org/jdk/pull/22160#discussion_r1863701395
More information about the net-dev
mailing list