8342811: java/net/httpclient/PlainProxyConnectionTest.java failed: Unexpected connection count: 5

Reviewed-by: dfuchs
This commit is contained in:
Volkan Yazıcı 2024-11-15 19:56:48 +00:00 committed by Daniel Fuchs
parent f3168082b8
commit 59ffac84d3

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2019, 2023, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2019, 2024, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -25,6 +25,8 @@ import com.sun.net.httpserver.HttpContext;
import com.sun.net.httpserver.HttpExchange; import com.sun.net.httpserver.HttpExchange;
import com.sun.net.httpserver.HttpHandler; import com.sun.net.httpserver.HttpHandler;
import com.sun.net.httpserver.HttpServer; import com.sun.net.httpserver.HttpServer;
import jdk.httpclient.test.lib.common.HttpServerAdapters;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.net.HttpURLConnection; import java.net.HttpURLConnection;
@ -54,15 +56,28 @@ import static java.net.Proxy.NO_PROXY;
* @bug 8230526 * @bug 8230526
* @summary Verifies that PlainProxyConnections are cached and reused properly. We do this by * @summary Verifies that PlainProxyConnections are cached and reused properly. We do this by
* verifying that the remote address of the HTTP exchange (on the fake proxy server) * verifying that the remote address of the HTTP exchange (on the fake proxy server)
* is always the same InetSocketAddress. * is always the same InetSocketAddress. Logging verbosity is increased to aid in
* @modules jdk.httpserver * diagnosis of intermittent failures.
* @run main/othervm -Djdk.tracePinnedThreads=full PlainProxyConnectionTest * @library /test/lib
* @author danielfuchs * /test/jdk/java/net/httpclient/lib
* @run main/othervm -Djdk.tracePinnedThreads=full
* -Djdk.httpclient.HttpClient.log=headers,requests,trace
* -Djdk.internal.httpclient.debug=true
* PlainProxyConnectionTest
*/ */
public class PlainProxyConnectionTest { public class PlainProxyConnectionTest {
// Increase logging verbosity to troubleshoot intermittent failures
static {
HttpServerAdapters.enableServerLogging();
}
static final String RESPONSE = "<html><body><p>Hello World!</body></html>"; static final String RESPONSE = "<html><body><p>Hello World!</body></html>";
static final String PATH = "/foo/";
// Adding some salt to the path to avoid other parallel running tests mistakenly connect to our test server
private static final String PATH = String.format(
"/%s-%d", PlainProxyConnectionTest.class.getSimpleName(), PlainProxyConnectionTest.class.hashCode());
static final ConcurrentLinkedQueue<InetSocketAddress> connections = new ConcurrentLinkedQueue<>(); static final ConcurrentLinkedQueue<InetSocketAddress> connections = new ConcurrentLinkedQueue<>();
private static final AtomicInteger IDS = new AtomicInteger(); private static final AtomicInteger IDS = new AtomicInteger();