RFR: 8350546: Several java/net/InetAddress tests fails UnknownHostException
Mikhail Yankelevich
duke at openjdk.org
Mon Mar 3 10:47:57 UTC 2025
On Tue, 25 Feb 2025 08:57:00 GMT, SendaoYan <syan at openjdk.org> wrote:
> Hi all,
>
> Two java/net/InetAddress tests fails "java.net.UnknownHostException" on some special machines. The machine cannot connect to the Internet directly and needs to be connected to the Internet through a jump machine. The java/net/InetAddress tests report "java.net.UnknownHostException: bugs.openjdk.org: Temporary failure in name resolution" failure do not caused by JVM bug but environmentalk issue, so this PR match the java.net.UnknownHostException and throw jtreg.SkippedException instead of report test fails.
>
> And run the tests with JVM options `-Dhttp.proxyHost=192.168.50.1 -Dhttp.proxyPort=10991 -Dhttps.proxyHost=192.168.50.1 -Dhttps.proxyPort=10991 -DsocksProxyHost=192.168.50.1 -DsocksProxyPort=10991` can not work around. So I create this PR to fix the test bug.
>
> Command wget shows that the machine should connect to internet through a jumper machine(192.168.50.1:10991):
>
>> wget www.bing.com
> --2025-02-24 17:56:25-- http://www.bing.com/
> Connecting to 192.168.50.1:10991... connected.
> Proxy request sent, awaiting response... 301 Moved Permanently
> Location: http://cn.bing.com/ [following]
> --2025-02-24 17:56:25-- http://cn.bing.com/
> Reusing existing connection to 192.168.50.1:10991.
> Proxy request sent, awaiting response... 200 OK
> Length: 13006 (13K) [text/html]
> Saving to: ‘index.html’
>
>
> Change has been verified locally, test-fix only and make tests more robustness, no risk.
Overall looks good to me, just minor cleanup comments and a question about `@build jtreg.SkippedException`
test/jdk/java/net/InetAddress/IsReachableViaLoopbackTest.java line 26:
> 24: import java.io.*;
> 25: import java.net.*;
> 26: import java.util.*;
I know, this is not a part of your change, but this import is not used. Could you please remove it?
test/jdk/java/net/InetAddress/IsReachableViaLoopbackTest.java line 35:
> 33: * @key intermittent
> 34: * @library /test/lib
> 35: * @build jtreg.SkippedException
AFAIK,`@build jtreg.SkippedException` is not needed. Tried to remove and it worked fine locally, does it work for you?
Also this is the same for the line 30 in the `getOriginalHostName.java`
test/jdk/java/net/InetAddress/IsReachableViaLoopbackTest.java line 64:
> 62: } catch (java.net.UnknownHostException e) {
> 63: e.printStackTrace();
> 64: throw new SkippedException("Network setup issue, skip this test");
Minor: Do you think it would make the comment cleaner if it would be just `"Network setup issue"`? It seems to be repeating itself for me (skip exception already states, that the test is skipped).
Don't have a strong opinion, so it's completely up you :)
Also this is the same for the line 60 in the `getOriginalHostName.java`
-------------
PR Review: https://git.openjdk.org/jdk/pull/23767#pullrequestreview-2653693064
PR Review Comment: https://git.openjdk.org/jdk/pull/23767#discussion_r1977263320
PR Review Comment: https://git.openjdk.org/jdk/pull/23767#discussion_r1977254299
PR Review Comment: https://git.openjdk.org/jdk/pull/23767#discussion_r1977283080
More information about the net-dev
mailing list