186 lines
7.9 KiB
Java
Raw Normal View History

/*
* Copyright (c) 2022, 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 8279366
* @summary Test app class paths checking with the longest common path taken into account.
* @requires vm.cds
* @library /test/lib /test/hotspot/jtreg/runtime/cds/appcds
* @build jdk.test.whitebox.WhiteBox
* @compile ../test-classes/Hello.java
* @compile ../test-classes/HelloMore.java
* @run driver jdk.test.lib.helpers.ClassFileInstaller jdk.test.whitebox.WhiteBox
* @run main/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xbootclasspath/a:. CommonAppClasspath
*/
import java.io.File;
import java.nio.file.Path;
import java.nio.file.Paths;
import jdk.test.lib.cds.CDSTestUtils;
public class CommonAppClasspath extends DynamicArchiveTestBase {
private static final Path USER_DIR = Paths.get(CDSTestUtils.getOutputDir());
private static final String failedMessage = "shared class paths mismatch";
private static final String successMessage1 = "Hello source: shared objects file";
private static final String successMessage2 = "HelloMore source: shared objects file";
private static void runtimeTest(String topArchiveName, String classPath,
String mainClass, int expectedExitValue,
String ... checkMessages) throws Exception {
CDSTestUtils.Result result = run(topArchiveName,
"-Xlog:class+load",
"-Xlog:cds+dynamic=debug,cds=debug",
"-cp", classPath, mainClass);
if (expectedExitValue == 0) {
result.assertNormalExit( output -> {
for (String s : checkMessages) {
output.shouldContain(s);
}
});
} else {
result.assertAbnormalExit( output -> {
for (String s : checkMessages) {
output.shouldContain(s);
}
});
}
}
public static void main(String[] args) throws Exception {
runTest(CommonAppClasspath::testDefaultBase);
}
static void testDefaultBase() throws Exception {
String topArchiveName = getNewArchiveName("top");
doTest(topArchiveName);
}
private static void doTest(String topArchiveName) throws Exception {
String mainClass = "HelloMore";
String appJar = JarBuilder.getOrCreateHelloJar();
String appJar2 = JarBuilder.build("AppendClasspath_HelloMore", mainClass);
// dump an archive with only appJar in the original location
String jars = appJar;
dump(topArchiveName,
"-Xlog:cds",
"-Xlog:cds+dynamic=debug",
"-cp", jars, "Hello")
.assertNormalExit(output -> {
output.shouldContain("Written dynamic archive 0x");
});
// copy hello.jar to tmp dir
Path destPath = CDSTestUtils.copyFile(appJar, System.getProperty("java.io.tmpdir"));
// Run with appJar relocated to tmp dir - should PASS
jars = destPath.toString();
runtimeTest(topArchiveName, jars, "Hello", 0, successMessage1);
// dump an archive with both jars in the original location
jars = appJar + File.pathSeparator + appJar2;
dump(topArchiveName,
"-Xlog:cds",
"-Xlog:cds+dynamic=debug",
"-cp", jars, mainClass)
.assertNormalExit(output -> {
output.shouldContain("Written dynamic archive 0x");
});
// copy hello.jar to USER_DIR/deploy
String newDir = USER_DIR.toString() + File.separator + "deploy";
destPath = CDSTestUtils.copyFile(appJar, newDir);
// copy AppendClasspath_HelloMore.jar to USER_DIR/deploy
Path destPath2 = CDSTestUtils.copyFile(appJar2, newDir);
// Run with both jars relocated to USER_DIR/dpeloy - should PASS
jars = destPath.toString() + File.pathSeparator + destPath2.toString();
runtimeTest(topArchiveName, jars, mainClass, 0, successMessage1, successMessage2);
// Run with relocation of only the second jar - should FAIL
jars = appJar + File.pathSeparator + destPath2.toString();
runtimeTest(topArchiveName, jars, mainClass, 1, failedMessage);
// Run with relocation of only the first jar - should FAIL
jars = destPath.toString() + File.pathSeparator + appJar2;
runtimeTest(topArchiveName, jars, mainClass, 1, failedMessage);
// Dump CDS archive with the first jar relocated.
jars = destPath.toString() + File.pathSeparator + appJar2;
dump(topArchiveName,
"-Xlog:cds",
"-Xlog:cds+dynamic=debug",
"-cp", jars, mainClass)
.assertNormalExit(output -> {
output.shouldContain("Written dynamic archive 0x");
});
// Run with first jar relocated - should PASS
jars = destPath.toString() + File.pathSeparator + appJar2;
runtimeTest(topArchiveName, jars, mainClass, 0, successMessage1, successMessage2);
// Run with both jars relocated - should FAIL
jars = destPath.toString() + File.pathSeparator + destPath2.toString();
runtimeTest(topArchiveName, jars, mainClass, 1, failedMessage);
// Copy hello.jar to USER_DIR/a
destPath = CDSTestUtils.copyFile(appJar, USER_DIR.toString() + File.separator + "a");
// copy AppendClasspath_HelloMore.jar to USER_DIR/aa
destPath2 = CDSTestUtils.copyFile(appJar2, USER_DIR.toString() + File.separator + "aa");
// Dump CDS archive with the both jar files relocated
// appJar to USER_DIR/a
// appJar2 to USER_DIR/aa
jars = destPath.toString() + File.pathSeparator + destPath2.toString();
dump(topArchiveName,
"-Xlog:cds",
"-Xlog:cds+dynamic=debug",
"-cp", jars, mainClass)
.assertNormalExit(output -> {
output.shouldContain("Written dynamic archive 0x");
});
// Copy hello.jar to USER_DIR/x/a
Path runPath = CDSTestUtils.copyFile(appJar, USER_DIR.toString() + File.separator + "x" + File.separator + "a");
// copy AppendClasspath_HelloMore.jar to USER_DIR/x/aa
Path runPath2= CDSTestUtils.copyFile(appJar2, USER_DIR.toString() + File.separator + "x" + File.separator + "aa");
// Run with both jars relocated to USER_DIR/x/a and USER_DIR/x/aa dirs - should PASS
jars = runPath.toString() + File.pathSeparator + runPath2.toString();
runtimeTest(topArchiveName, jars, mainClass, 0, successMessage1, successMessage2);
// copy AppendClasspath_HelloMore.jar to USER_DIR/x/a
runPath2= CDSTestUtils.copyFile(appJar2, USER_DIR.toString() + File.separator + "x" + File.separator + "a");
// Run with both jars relocated to USER_DIR/x/a dir - should FAIL
jars = runPath.toString() + File.pathSeparator + runPath2.toString();
runtimeTest(topArchiveName, jars, mainClass, 1, failedMessage);
}
}