diff --git a/test/jdk/java/net/ProxySelector/LoopbackAddresses.java b/test/jdk/java/net/ProxySelector/LoopbackAddresses.java index 16c1315e820..cd5eb919b97 100644 --- a/test/jdk/java/net/ProxySelector/LoopbackAddresses.java +++ b/test/jdk/java/net/ProxySelector/LoopbackAddresses.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2019, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -23,9 +23,12 @@ /* @test * @bug 4924226 - * @summary PIT: Can no launch jnlp application via 127.0.0.1 address on the web server + * @key intermittent + * @summary PIT: Can no launch jnlp application via 127.0.0.1 address on the web server. + * This test might fail intermittently as it needs a server that + * binds to the wildcard address. * @modules java.base/sun.net.www - * @library ../../../sun/net/www/httptest/ + * @library ../../../sun/net/www/httptest/ /test/lib * @build ClosedChannelList TestHttpServer HttpTransaction HttpCallback * @compile LoopbackAddresses.java * @run main/othervm LoopbackAddresses @@ -33,6 +36,7 @@ import java.net.*; import java.io.*; +import jdk.test.lib.net.URIBuilder; /** * Our default proxy selector should bypass localhost and loopback @@ -53,12 +57,18 @@ public class LoopbackAddresses implements HttpCallback { public static void main(String[] args) { try { + InetAddress loopback = InetAddress.getLoopbackAddress(); + + // This server needs to bind to the wildcard address as we want it + // to answer both for the loopback and "localhost". + // Though "localhost" usually point to the loopback there is no + // hard guarantee. server = new TestHttpServer (new LoopbackAddresses(), 1, 10, 0); ProxyServer pserver = new ProxyServer(InetAddress.getByName("localhost"), server.getLocalPort()); // start proxy server new Thread(pserver).start(); - System.setProperty("http.proxyHost", "localhost"); + System.setProperty("http.proxyHost", loopback.getHostAddress()); System.setProperty("http.proxyPort", pserver.getPort()+""); URL url = new URL("http://localhost:"+server.getLocalPort()); @@ -72,7 +82,11 @@ public class LoopbackAddresses implements HttpCallback { } try { - url = new URL("http://127.0.0.1:"+server.getLocalPort()); + url = URIBuilder.newBuilder() + .scheme("http") + .host(loopback.getHostAddress()) + .port(server.getLocalPort()) + .toURL(); HttpURLConnection urlc = (HttpURLConnection)url.openConnection (); int respCode = urlc.getResponseCode(); urlc.disconnect(); @@ -104,7 +118,8 @@ public class LoopbackAddresses implements HttpCallback { public ProxyServer(InetAddress server, int port) throws IOException { serverInetAddr = server; serverPort = port; - ss = new ServerSocket(0); + ss = new ServerSocket(); + ss.bind(new InetSocketAddress(InetAddress.getLoopbackAddress(), 0)); } public void run() { diff --git a/test/jdk/java/net/ProxySelector/ProxyTest.java b/test/jdk/java/net/ProxySelector/ProxyTest.java index c1b6c2ba41a..d2cb56617d7 100644 --- a/test/jdk/java/net/ProxySelector/ProxyTest.java +++ b/test/jdk/java/net/ProxySelector/ProxyTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2019, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,7 +26,7 @@ * @bug 4696512 * @summary HTTP client: Improve proxy server configuration and selection * @modules java.base/sun.net.www - * @library ../../../sun/net/www/httptest/ + * @library ../../../sun/net/www/httptest/ /test/lib * @build ClosedChannelList TestHttpServer HttpTransaction HttpCallback * @compile ProxyTest.java * @run main/othervm -Dhttp.proxyHost=inexistant -Dhttp.proxyPort=8080 ProxyTest @@ -35,6 +35,7 @@ import java.net.*; import java.io.*; import java.util.ArrayList; +import jdk.test.lib.net.URIBuilder; public class ProxyTest implements HttpCallback { static TestHttpServer server; @@ -52,8 +53,8 @@ public class ProxyTest implements HttpCallback { } static public class MyProxySelector extends ProxySelector { - private ProxySelector def = null; - private ArrayList noProxy; + private static volatile URI lastURI; + private final ArrayList noProxy; public MyProxySelector() { noProxy = new ArrayList(1); @@ -61,13 +62,16 @@ public class ProxyTest implements HttpCallback { } public java.util.List select(URI uri) { + System.out.println("Selecting no proxy for " + uri); + lastURI = uri; return noProxy; } public void connectFailed(URI uri, SocketAddress sa, IOException ioe) { } - } + public static URI lastURI() { return lastURI; } + } public static void main(String[] args) { ProxySelector defSelector = ProxySelector.getDefault(); @@ -75,12 +79,21 @@ public class ProxyTest implements HttpCallback { throw new RuntimeException("Default ProxySelector is null"); ProxySelector.setDefault(new MyProxySelector()); try { + InetAddress loopback = InetAddress.getLoopbackAddress(); server = new TestHttpServer (new ProxyTest(), 1, 10, 0); - URL url = new URL("http://localhost:"+server.getLocalPort()); + URL url = URIBuilder.newBuilder() + .scheme("http") + .loopback() + .port(server.getLocalPort()) + .toURL(); System.out.println ("client opening connection to: " + url); HttpURLConnection urlc = (HttpURLConnection)url.openConnection (); InputStream is = urlc.getInputStream (); is.close(); + URI lastURI = MyProxySelector.lastURI(); + if (!String.valueOf(lastURI).equals(url + "/")) { + throw new AssertionError("Custom proxy was not used: last URI was " + lastURI); + } } catch (Exception e) { throw new RuntimeException(e); } finally { diff --git a/test/jdk/java/net/ResponseCache/B6181108.java b/test/jdk/java/net/ResponseCache/B6181108.java index 5b8b0f4e058..5c8c4658d67 100644 --- a/test/jdk/java/net/ResponseCache/B6181108.java +++ b/test/jdk/java/net/ResponseCache/B6181108.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2004, 2010, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2004, 2019, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -24,6 +24,7 @@ /** * @test * @bug 6181108 + * @library /test/lib * @summary double encoded URL passed to ResponseCache * @author Edward Wang */ @@ -31,7 +32,7 @@ import java.net.*; import java.util.*; import java.io.*; - +import jdk.test.lib.net.URIBuilder; public class B6181108 implements Runnable { ServerSocket ss; @@ -44,7 +45,7 @@ public class B6181108 implements Runnable { try { Socket s = ss.accept(); - InputStream is = s.getInputStream (); + InputStream is = s.getInputStream(); BufferedReader r = new BufferedReader(new InputStreamReader(is)); String x; while ((x=r.readLine()) != null) { @@ -75,32 +76,38 @@ public class B6181108 implements Runnable { } static class ResponseCache extends java.net.ResponseCache { - public CacheResponse get (URI uri, String method, Map> hdrs) { - System.out.println ("get uri = " + uri); + public CacheResponse get(URI uri, String method, Map> hdrs) { + System.out.println("get uri = " + uri); if (!urlWithSpace.equals(uri.toString())) { throw new RuntimeException("test failed"); } return null; } - public CacheRequest put (URI uri, URLConnection urlc) { - System.out.println ("put uri = " + uri); + public CacheRequest put(URI uri, URLConnection urlc) { + System.out.println("put uri = " + uri); return null; } } B6181108() throws Exception { /* start the server */ - ss = new ServerSocket(0); + InetAddress loopback = InetAddress.getLoopbackAddress(); + ss = new ServerSocket(); + ss.bind(new InetSocketAddress(loopback, 0)); (new Thread(this)).start(); - ResponseCache.setDefault (new ResponseCache()); - urlWithSpace = "http://localhost:" + - Integer.toString(ss.getLocalPort()) + - "/space%20test/page1.html"; - URL url = new URL (urlWithSpace); + ResponseCache.setDefault(new ResponseCache()); + String base = URIBuilder.newBuilder() + .scheme("http") + .loopback() + .port(ss.getLocalPort()) + .build() + .toString(); + urlWithSpace = base + "/space%20test/page1.html"; + URL url = new URL(urlWithSpace); URLConnection urlc = url.openConnection(); int i = ((HttpURLConnection)(urlc)).getResponseCode(); - System.out.println ("response code = " + i); + System.out.println("response code = " + i); ResponseCache.setDefault(null); } diff --git a/test/jdk/java/net/SocketInputStream/SocketClosedException.java b/test/jdk/java/net/SocketInputStream/SocketClosedException.java index 45bc9a265d0..78808f23039 100644 --- a/test/jdk/java/net/SocketInputStream/SocketClosedException.java +++ b/test/jdk/java/net/SocketInputStream/SocketClosedException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2002, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2002, 2019, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -51,7 +51,8 @@ public class SocketClosedException { } static void doClientSide(int port) throws Exception { - Socket socket = new Socket("localhost", port); + InetAddress loopback = InetAddress.getLoopbackAddress(); + Socket socket = new Socket(loopback, port); InputStream is = socket.getInputStream(); is.read(); @@ -64,7 +65,9 @@ public class SocketClosedException { public static void main(String[] args) throws Exception { IPSupport.throwSkippedExceptionIfNonOperational(); - serverSocket = new ServerSocket(0); + InetAddress loopback = InetAddress.getLoopbackAddress(); + serverSocket = new ServerSocket(); + serverSocket.bind(new InetSocketAddress(loopback, 0)); startServer(); try { doClientSide(serverSocket.getLocalPort()); diff --git a/test/jdk/java/net/SocketPermission/SocketPermissionTest.java b/test/jdk/java/net/SocketPermission/SocketPermissionTest.java index c0c3260380a..a787be39c96 100644 --- a/test/jdk/java/net/SocketPermission/SocketPermissionTest.java +++ b/test/jdk/java/net/SocketPermission/SocketPermissionTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2019, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -24,7 +24,10 @@ /* * @test * @bug 8047031 - * @summary SocketPermission tests for legacy socket types + * @key intermittent + * @summary SocketPermission tests for legacy socket types. + * This test needs to bind its servers to the wildcard + * address and as such may fail intermittently. * @library /test/lib * @build jdk.test.lib.NetworkConfiguration * jdk.test.lib.Platform diff --git a/test/jdk/java/net/URLConnection/DisconnectAfterEOF.java b/test/jdk/java/net/URLConnection/DisconnectAfterEOF.java index 8ae427bb194..b3fc25617bd 100644 --- a/test/jdk/java/net/URLConnection/DisconnectAfterEOF.java +++ b/test/jdk/java/net/URLConnection/DisconnectAfterEOF.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2002, 2010, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2002, 2019, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -24,6 +24,7 @@ /** * @test * @bug 4774503 + * @library /test/lib * @summary Calling HttpURLConnection's disconnect method after the * response has been received causes havoc with persistent * connections. @@ -31,6 +32,9 @@ import java.net.*; import java.io.*; import java.util.*; +import jdk.test.lib.net.URIBuilder; + + public class DisconnectAfterEOF { @@ -239,13 +243,18 @@ public class DisconnectAfterEOF { public static void main(String args[]) throws Exception { // start server - ServerSocket ss = new ServerSocket(0); + InetAddress loopback = InetAddress.getLoopbackAddress(); + ServerSocket ss = new ServerSocket(); + ss.bind(new InetSocketAddress(loopback, 0)); Server svr = new Server(ss); svr.start(); - String uri = "http://localhost:" + - Integer.toString(ss.getLocalPort()) + - "/foo.html"; + String uri = URIBuilder.newBuilder() + .scheme("http") + .loopback() + .port(ss.getLocalPort()) + .path("/foo.html") + .build().toString(); /* * The following is the test scenario we create here :- diff --git a/test/jdk/java/net/URLConnection/contentHandler/UserContentHandler.java b/test/jdk/java/net/URLConnection/contentHandler/UserContentHandler.java index da433b6c7c6..3df5de1448b 100644 --- a/test/jdk/java/net/URLConnection/contentHandler/UserContentHandler.java +++ b/test/jdk/java/net/URLConnection/contentHandler/UserContentHandler.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2019, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -24,6 +24,7 @@ /* @test * @bug 4191147 * @summary 1.2beta4 does not load user defined content handlers + * @library /test/lib * @build UserContentHandler * @run main/othervm UserContentHandler */ @@ -38,6 +39,7 @@ import java.net.*; import java.io.*; import java.util.*; +import jdk.test.lib.net.URIBuilder; public class UserContentHandler implements Runnable { @@ -74,7 +76,9 @@ public class UserContentHandler implements Runnable { UserContentHandler() throws Exception { - ss = new ServerSocket(0); + InetAddress loopback = InetAddress.getLoopbackAddress(); + ss = new ServerSocket(); + ss.bind(new InetSocketAddress(loopback, 0)); Thread thr = new Thread(this); thr.start(); @@ -87,8 +91,13 @@ public class UserContentHandler implements Runnable { props.put("java.content.handler.pkgs", "COM.foo.content"); System.setProperties(props); - URL u = new URL("http://localhost:" + ss.getLocalPort() + - "/anything.txt"); + URL u = URIBuilder.newBuilder() + .scheme("http") + .loopback() + .port(ss.getLocalPort()) + .path("/anything.txt") + .toURL(); + if (!(u.openConnection().getContent() instanceof String)) { throw new RuntimeException("Load user defined content handler failed."); } else { diff --git a/test/jdk/sun/net/www/http/HttpClient/B7025238.java b/test/jdk/sun/net/www/http/HttpClient/B7025238.java index 1af7ec83d5f..ef7ef82bea6 100644 --- a/test/jdk/sun/net/www/http/HttpClient/B7025238.java +++ b/test/jdk/sun/net/www/http/HttpClient/B7025238.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 2019, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,11 +26,13 @@ import java.io.IOException; import java.io.OutputStream; import java.net.*; import java.util.concurrent.Executors; +import jdk.test.lib.net.URIBuilder; /* * @test * @bug 7025238 * @modules jdk.httpserver + * @library /test/lib * @summary HttpURLConnection does not handle URLs with an empty path component */ public class B7025238 { @@ -44,7 +46,13 @@ public class B7025238 { try { s = new Server(); s.startServer(); - URL url = new URL("http://localhost:" + s.getPort() + "?q=test"); + URL url = URIBuilder.newBuilder() + .scheme("http") + .loopback() + .port(s.getPort()) + .query("q=test") + .toURL(); + System.out.println("Connecting to: " + url); HttpURLConnection urlConnection = (HttpURLConnection)url.openConnection(); urlConnection.setRequestMethod("GET"); urlConnection.connect(); @@ -62,7 +70,8 @@ public class B7025238 { HttpServer server; public void startServer() { - InetSocketAddress addr = new InetSocketAddress(0); + InetAddress loopback = InetAddress.getLoopbackAddress(); + InetSocketAddress addr = new InetSocketAddress(loopback, 0); try { server = HttpServer.create(addr, 0); } catch (IOException ioe) { @@ -101,4 +110,3 @@ public class B7025238 { } } } - diff --git a/test/jdk/sun/net/www/http/HttpClient/ProxyFromCache.java b/test/jdk/sun/net/www/http/HttpClient/ProxyFromCache.java index 920e5b0e254..f8885c637ed 100644 --- a/test/jdk/sun/net/www/http/HttpClient/ProxyFromCache.java +++ b/test/jdk/sun/net/www/http/HttpClient/ProxyFromCache.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2006, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2006, 2019, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,12 +26,14 @@ * @bug 6498566 * @summary URL.openConnection(Proxy.NO_PROXY) may connect through a proxy. * @modules java.base/sun.net.www + * @library /test/lib * @run main/othervm ProxyFromCache */ import java.net.*; import java.io.*; import sun.net.www.MessageHeader; +import jdk.test.lib.net.URIBuilder; /* Creates a simple proxy and http server that just return 200 OK. * Open a URL pointing to the http server and specify that the @@ -43,18 +45,21 @@ import sun.net.www.MessageHeader; public class ProxyFromCache { - public static void main(String[] args) { + public static void main(String[] args) throws Exception { ServerSocket proxySSocket, httpSSocket; int proxyPort, httpPort; + InetAddress loopback = InetAddress.getLoopbackAddress(); try { - proxySSocket = new ServerSocket(0); + proxySSocket = new ServerSocket(); + proxySSocket.bind(new InetSocketAddress(loopback, 0)); proxyPort = proxySSocket.getLocalPort(); - httpSSocket = new ServerSocket(0); + httpSSocket = new ServerSocket(); + httpSSocket.bind(new InetSocketAddress(loopback, 0)); httpPort = httpSSocket.getLocalPort(); } catch (Exception e) { System.out.println ("Exception: " + e); - return; + throw e; } SimpleServer proxyServer = new SimpleServer(proxySSocket); @@ -62,12 +67,18 @@ public class ProxyFromCache SimpleServer httpServer = new SimpleServer(httpSSocket); httpServer.start(); - InetSocketAddress addr = new InetSocketAddress("localhost", proxyPort); + InetSocketAddress addr = new InetSocketAddress(loopback, proxyPort); Proxy proxy = new Proxy(Proxy.Type.HTTP, addr); try { - String urlStr = "http://localhost:" + httpPort + "/"; - URL url = new URL(urlStr); + URL url = URIBuilder.newBuilder() + .scheme("http") + .loopback() + .port(httpPort) + .path("/") + .toURL(); + + String urlStr = url.toString(); // 1st connection. HttpURLConnection uc = (HttpURLConnection) url.openConnection(proxy); @@ -100,7 +111,7 @@ public class ProxyFromCache throw new RuntimeException("Failed: Proxy being sent " + proxyCount + " requests"); } } catch (IOException e) { - throw new RuntimeException(e); + throw e; } } }