RFR: 8343791: Socket.connect API should document whether the socket will be closed when hostname resolution fails or another error occurs [v13]
Volkan Yazıcı
duke at openjdk.org
Mon Nov 25 09:28:36 UTC 2024
On Fri, 22 Nov 2024 21:08:11 GMT, Mark Sheppard <msheppar at openjdk.org> wrote:
>> 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 59:
>
>> 57:
>> 58: private static final VarHandle SOCKET_IMPL_FACTORY_HANDLE = createSocketImplFactoryHandle();
>> 59:
>
> private static final int DEADSERVERPORT = 0xDEAD;
Fixed in 35d680123f83b97b2a62fe99969aa0c18a75e6b1.
> test/jdk/java/net/Socket/CloseOnFailureTest.java line 84:
>
>> 82:
>> 83: private final AtomicInteger closeInvocationCounter = new AtomicInteger(0);
>> 84:
>
> replacing Error with Exception in the variable names allows for easier and quicker scanning of a line
>
> private final Exception bindException;
>
> private final Exception connectException;
>
> private MockSocketImpl(Exception bindException, Exception connectException) {
> this.bindException = bindException;
> this.connectException = connectException;
> }
>
> and this replacement suggestion propagates down through the rest of the code
>
>
> ```
> Throwable
> |
> | IS_A
> |
> Error Exception
>
>
> avoid Error in the variable name avoid the subconscious association with an Error class
Replaced all occurrences of `error` in variable names with `exception` in 35d680123f83b97b2a62fe99969aa0c18a75e6b1.
> test/jdk/java/net/Socket/CloseOnFailureTest.java line 140:
>
>> 138: InetAddress serverAddress = InetAddress.getLoopbackAddress();
>> 139: int deadServerPort = 0xDEAD;
>> 140: new Socket(serverAddress, deadServerPort, null, 0);
>
> new Socket(serverAddress, DEADSERVERPORT, null, 0); // DEADSERVERPORT declared as a constant above
Fixed in 35d680123f83b97b2a62fe99969aa0c18a75e6b1.
> 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 !
Reused the `DEAD_SERVER_PORT` constant here in 35d680123f83b97b2a62fe99969aa0c18a75e6b1.
-------------
PR Review Comment: https://git.openjdk.org/jdk/pull/22160#discussion_r1856214817
PR Review Comment: https://git.openjdk.org/jdk/pull/22160#discussion_r1856215001
PR Review Comment: https://git.openjdk.org/jdk/pull/22160#discussion_r1856214705
PR Review Comment: https://git.openjdk.org/jdk/pull/22160#discussion_r1856215137
More information about the net-dev
mailing list