9538f5d317
Reviewed-by: dfuchs, jpai
173 lines
6.3 KiB
Java
173 lines
6.3 KiB
Java
/*
|
|
* Copyright (c) 2015, 2024, 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
|
|
* under the terms of the GNU General Public License version 2 only, as
|
|
* published by the Free Software Foundation.
|
|
*
|
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
* version 2 for more details (a copy is included in the LICENSE file that
|
|
* accompanied this code).
|
|
*
|
|
* You should have received a copy of the GNU General Public License version
|
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
*
|
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
* or visit www.oracle.com if you need additional information or have any
|
|
* questions.
|
|
*/
|
|
|
|
/*
|
|
* @test
|
|
* @bug 8087112
|
|
* @library /test/lib
|
|
* @modules java.net.http
|
|
* java.logging
|
|
* jdk.httpserver
|
|
* @build jdk.test.lib.net.SimpleSSLContext jdk.test.lib.Utils
|
|
* @compile ../../../../com/sun/net/httpserver/LogFilter.java
|
|
* @compile ../../../../com/sun/net/httpserver/FileServerHandler.java
|
|
* @compile ../ProxyServer.java
|
|
* @build Security
|
|
*
|
|
* @run main/othervm Driver
|
|
*/
|
|
|
|
/**
|
|
* driver required for allocating free portnumbers and putting this number
|
|
* into security policy file used in some tests.
|
|
*
|
|
* The tests are in Security.java and port number supplied in -Dport.number
|
|
* and -Dport.number1 for tests that require a second free port
|
|
*/
|
|
import java.io.File;
|
|
import java.io.FileOutputStream;
|
|
import java.io.IOException;
|
|
import java.io.InputStream;
|
|
import java.io.OutputStream;
|
|
import java.nio.file.Files;
|
|
import java.nio.file.Path;
|
|
import java.nio.file.Paths;
|
|
import java.util.ArrayList;
|
|
import java.util.List;
|
|
import java.util.stream.Collectors;
|
|
import jdk.test.lib.Utils;
|
|
import jdk.test.lib.process.ProcessTools;
|
|
|
|
/**
|
|
* Driver for tests
|
|
*/
|
|
public class Driver {
|
|
// change the default value to "true" to get the subprocess traces.
|
|
final static boolean DEBUG = Boolean.parseBoolean(System.getProperty("test.debug", "true"));
|
|
|
|
public static void main(String[] args) throws Throwable {
|
|
System.out.println("Starting Driver");
|
|
runtest("1.policy", "1");
|
|
runtest("10.policy", "10");
|
|
runtest("11.policy", "11");
|
|
runtest("12.policy", "12");
|
|
runtest("16.policy", "16", "-Djdk.httpclient.allowRestrictedHeaders=Host");
|
|
runtest("17.policy", "17", "-Djdk.httpclient.allowRestrictedHeaders=Host");
|
|
System.out.println("DONE");
|
|
}
|
|
|
|
static final Path CWD = Paths.get(".");
|
|
|
|
static class Logger extends Thread {
|
|
private final OutputStream ps;
|
|
private final InputStream stdout;
|
|
|
|
Logger(String cmdLine, Process p) throws IOException {
|
|
super();
|
|
setDaemon(true);
|
|
cmdLine = "Command line = [" + cmdLine + "]\n";
|
|
stdout = p.getInputStream();
|
|
File f = Files.createTempFile(CWD, "debug", ".txt").toFile();
|
|
ps = new FileOutputStream(f);
|
|
ps.write(cmdLine.getBytes());
|
|
ps.flush();
|
|
if (DEBUG) {
|
|
System.out.print(cmdLine);
|
|
System.out.flush();
|
|
}
|
|
}
|
|
|
|
public void run() {
|
|
try {
|
|
byte[] buf = new byte[128];
|
|
int c;
|
|
while ((c = stdout.read(buf)) != -1) {
|
|
if (DEBUG) {
|
|
System.out.write(buf, 0, c);
|
|
System.out.flush();
|
|
}
|
|
ps.write(buf, 0, c);
|
|
ps.flush();
|
|
}
|
|
ps.close();
|
|
} catch (Throwable e) {
|
|
e.printStackTrace();
|
|
}
|
|
}
|
|
}
|
|
|
|
public static void runtest(String policy, String testnum) throws Throwable {
|
|
runtest(policy, testnum, null);
|
|
}
|
|
|
|
|
|
public static void runtest(String policy, String testnum, String addProp) throws Throwable {
|
|
String testJdk = System.getProperty("test.jdk", "?");
|
|
String testSrc = System.getProperty("test.src", "?");
|
|
String testClassPath = System.getProperty("test.class.path", "?");
|
|
String testClasses = System.getProperty("test.classes", "?");
|
|
String sep = System.getProperty("file.separator", "?");
|
|
int retval = 10; // 10 is special exit code denoting a bind error
|
|
// in which case, we retry
|
|
while (retval == 10) {
|
|
List<String> cmd = new ArrayList<>();
|
|
cmd.add("-ea");
|
|
cmd.add("-esa");
|
|
cmd.add("-Dtest.jdk=" + testJdk);
|
|
cmd.add("-Dtest.src=" + testSrc);
|
|
cmd.add("-Dtest.classes=" + testClasses);
|
|
cmd.add("-Djava.security.manager");
|
|
cmd.add("-Djava.security.policy=" + testSrc + sep + policy);
|
|
cmd.add("-Dport.number=" + Integer.toString(Utils.getFreePort()));
|
|
cmd.add("-Dport.number1=" + Integer.toString(Utils.getFreePort()));
|
|
cmd.add("-Djdk.httpclient.HttpClient.log=all,frames:all");
|
|
if (addProp != null) {
|
|
cmd.add(addProp);
|
|
}
|
|
cmd.add("-cp");
|
|
cmd.add(testClassPath);
|
|
cmd.add("Security");
|
|
cmd.add(testnum);
|
|
|
|
ProcessBuilder processBuilder = ProcessTools.createTestJavaProcessBuilder(cmd)
|
|
.redirectOutput(ProcessBuilder.Redirect.PIPE)
|
|
.redirectErrorStream(true);
|
|
|
|
String cmdLine = cmd.stream().collect(Collectors.joining(" "));
|
|
long start = System.currentTimeMillis();
|
|
Process child = processBuilder.start();
|
|
Logger log = new Logger(cmdLine, child);
|
|
log.start();
|
|
retval = child.waitFor();
|
|
long elapsed = System.currentTimeMillis() - start;
|
|
System.out.println("Security " + testnum
|
|
+ ": retval = " + retval
|
|
+ ", duration=" + elapsed+" ms");
|
|
}
|
|
if (retval != 0) {
|
|
Thread.sleep(2000);
|
|
throw new RuntimeException("Non zero return value");
|
|
}
|
|
}
|
|
}
|