8343875: Minor improvements of jpackage test library
Reviewed-by: almatvee
This commit is contained in:
parent
90e92342fc
commit
95a00f8a18
@ -39,15 +39,6 @@ import static jdk.jpackage.test.DirectoryContentVerifierTest.AssertType.MATCH;
|
||||
import jdk.jpackage.test.TKit.DirectoryContentVerifier;
|
||||
import static jdk.jpackage.test.TKit.assertAssert;
|
||||
|
||||
/*
|
||||
* @test
|
||||
* @summary Test TKit.DirectoryContentVerifier from jpackage test library
|
||||
* @library /test/jdk/tools/jpackage/helpers
|
||||
* @build jdk.jpackage.test.*
|
||||
* @compile DirectoryContentVerifierTest.java
|
||||
* @run main/othervm/timeout=360 -Xmx512m jdk.jpackage.test.Main
|
||||
* --jpt-run=jdk.jpackage.test.DirectoryContentVerifierTest
|
||||
*/
|
||||
public class DirectoryContentVerifierTest {
|
||||
|
||||
enum AssertType {
|
||||
|
@ -0,0 +1,98 @@
|
||||
/*
|
||||
* Copyright (c) 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.
|
||||
*/
|
||||
package jdk.jpackage.test;
|
||||
|
||||
import java.nio.file.Path;
|
||||
import java.util.List;
|
||||
import java.util.function.UnaryOperator;
|
||||
import jdk.jpackage.test.Annotations.Parameter;
|
||||
import jdk.jpackage.test.Annotations.Test;
|
||||
import jdk.jpackage.test.Annotations.Parameters;
|
||||
|
||||
public class JavaAppDescTest {
|
||||
|
||||
public JavaAppDescTest(JavaAppDesc expectedAppDesc, JavaAppDesc actualAppDesc) {
|
||||
this.expectedAppDesc = expectedAppDesc;
|
||||
this.actualAppDesc = actualAppDesc;
|
||||
}
|
||||
|
||||
@Test
|
||||
public void test() {
|
||||
TKit.assertEquals(expectedAppDesc.toString(), actualAppDesc.toString(), null);
|
||||
TKit.assertTrue(expectedAppDesc.equals(actualAppDesc), null);
|
||||
}
|
||||
|
||||
@Test
|
||||
@Parameter({"Foo", "Foo.class"})
|
||||
@Parameter({"com.bar.A", "com/bar/A.class"})
|
||||
@Parameter({"module/com.bar.A", "com/bar/A.class"})
|
||||
public static void testClassFilePath(String... args) {
|
||||
var appDesc = args[0];
|
||||
var expectedClassFilePath = Path.of(args[1]);
|
||||
TKit.assertEquals(expectedClassFilePath.toString(), JavaAppDesc.parse(
|
||||
appDesc).classFilePath().toString(), null);
|
||||
}
|
||||
|
||||
@Parameters
|
||||
public static List<Object[]> input() {
|
||||
return List.of(new Object[][] {
|
||||
createTestCase("", "hello.jar:Hello"),
|
||||
createTestCase("foo.jar*", "foo.jar*hello.jar:Hello"),
|
||||
createTestCase("Bye", "hello.jar:Bye"),
|
||||
createTestCase("bye.jar:", "bye.jar:Hello"),
|
||||
createTestCase("duke.jar:com.other/com.other.foo.bar.Buz!@3.7", appDesc -> {
|
||||
return appDesc
|
||||
.setBundleFileName("duke.jar")
|
||||
.setModuleName("com.other")
|
||||
.setClassName("com.other.foo.bar.Buz")
|
||||
.setWithMainClass(true)
|
||||
.setModuleVersion("3.7");
|
||||
}),
|
||||
});
|
||||
}
|
||||
|
||||
private static JavaAppDesc[] createTestCase(String inputAppDesc, String expectedAppDescStr) {
|
||||
return createTestCase(inputAppDesc, appDesc -> {
|
||||
return stripDefaultSrcJavaPath(JavaAppDesc.parse(expectedAppDescStr));
|
||||
});
|
||||
}
|
||||
|
||||
private static JavaAppDesc stripDefaultSrcJavaPath(JavaAppDesc appDesc) {
|
||||
var defaultAppDesc = HelloApp.createDefaltAppDesc();
|
||||
if (appDesc.srcJavaPath().equals(defaultAppDesc.srcJavaPath())) {
|
||||
appDesc.setSrcJavaPath(null);
|
||||
}
|
||||
return appDesc;
|
||||
}
|
||||
|
||||
private static JavaAppDesc[] createTestCase(String appDesc, UnaryOperator<JavaAppDesc> config) {
|
||||
var actualAppDesc = stripDefaultSrcJavaPath(JavaAppDesc.parse(appDesc));
|
||||
|
||||
var expectedAppDesc = config.apply(stripDefaultSrcJavaPath(HelloApp.createDefaltAppDesc()));
|
||||
|
||||
return new JavaAppDesc[] {expectedAppDesc, actualAppDesc};
|
||||
}
|
||||
|
||||
private final JavaAppDesc expectedAppDesc;
|
||||
private final JavaAppDesc actualAppDesc;
|
||||
}
|
@ -0,0 +1,244 @@
|
||||
/*
|
||||
* Copyright (c) 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.
|
||||
*/
|
||||
package jdk.jpackage.test;
|
||||
|
||||
import java.io.BufferedReader;
|
||||
import java.io.ByteArrayInputStream;
|
||||
import java.io.ByteArrayOutputStream;
|
||||
import java.io.InputStreamReader;
|
||||
import java.io.PrintStream;
|
||||
import java.lang.reflect.Method;
|
||||
import java.nio.charset.StandardCharsets;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Arrays;
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
import java.util.Objects;
|
||||
import java.util.stream.Stream;
|
||||
import jdk.jpackage.test.Annotations.Parameters;
|
||||
import jdk.jpackage.test.Annotations.Test;
|
||||
import jdk.jpackage.test.Functional.ThrowingRunnable;
|
||||
import static jdk.jpackage.test.Functional.ThrowingRunnable.toRunnable;
|
||||
import static jdk.jpackage.test.Functional.ThrowingSupplier.toSupplier;
|
||||
|
||||
public class TKitTest {
|
||||
|
||||
@Parameters
|
||||
public static Collection<Object[]> assertTestsData() {
|
||||
List<MethodCallConfig> data = new ArrayList<>();
|
||||
|
||||
var assertFunc = MethodCallConfig.build("assertTrue", boolean.class, String.class);
|
||||
data.addAll(List.of(assertFunc.args(true).pass().expectLog("assertTrue()").createForMessage("Catbird")));
|
||||
data.addAll(List.of(assertFunc.args(false).fail().expectLog("Failed").createForMessage("Catbird")));
|
||||
|
||||
assertFunc = MethodCallConfig.build("assertFalse", boolean.class, String.class);
|
||||
data.addAll(List.of(assertFunc.args(false).pass().expectLog("assertFalse()").createForMessage("Stork")));
|
||||
data.addAll(List.of(assertFunc.args(true).fail().expectLog("Failed").createForMessage("Stork")));
|
||||
|
||||
assertFunc = MethodCallConfig.build("assertEquals", String.class, String.class, String.class);
|
||||
data.addAll(List.of(assertFunc.args("a", "a").pass().expectLog("assertEquals(a)").createForMessage("Crow")));
|
||||
data.addAll(List.of(assertFunc.args("a", "b").fail().expectLog("Expected [a]. Actual [b]").createForMessage("Crow")));
|
||||
|
||||
assertFunc = MethodCallConfig.build("assertEquals", long.class, long.class, String.class);
|
||||
data.addAll(List.of(assertFunc.args(7, 7).pass().expectLog("assertEquals(7)").createForMessage("Owl")));
|
||||
data.addAll(List.of(assertFunc.args(7, 10).fail().expectLog("Expected [7]. Actual [10]").createForMessage("Owl")));
|
||||
|
||||
assertFunc = MethodCallConfig.build("assertNotEquals", String.class, String.class, String.class);
|
||||
data.addAll(List.of(assertFunc.args("a", "b").pass().expectLog("assertNotEquals(a, b)").createForMessage("Tit")));
|
||||
data.addAll(List.of(assertFunc.args("a", "a").fail().expectLog("Unexpected [a] value").createForMessage("Tit")));
|
||||
|
||||
assertFunc = MethodCallConfig.build("assertNotEquals", long.class, long.class, String.class);
|
||||
data.addAll(List.of(assertFunc.args(7, 10).pass().expectLog("assertNotEquals(7, 10)").createForMessage("Duck")));
|
||||
data.addAll(List.of(assertFunc.args(7, 7).fail().expectLog("Unexpected [7] value").createForMessage("Duck")));
|
||||
|
||||
assertFunc = MethodCallConfig.build("assertNull", Object.class, String.class);
|
||||
data.addAll(List.of(assertFunc.args((Object) null).pass().expectLog("assertNull()").createForMessage("Ibis")));
|
||||
data.addAll(List.of(assertFunc.args("v").fail().expectLog("Unexpected not null value [v]").createForMessage("Ibis")));
|
||||
|
||||
assertFunc = MethodCallConfig.build("assertNotNull", Object.class, String.class);
|
||||
data.addAll(List.of(assertFunc.args("v").pass().expectLog("assertNotNull(v)").createForMessage("Pigeon")));
|
||||
data.addAll(List.of(assertFunc.args((Object) null).fail().expectLog("Unexpected null value").createForMessage("Pigeon")));
|
||||
|
||||
assertFunc = MethodCallConfig.build("assertStringListEquals", List.class, List.class, String.class);
|
||||
data.addAll(List.of(assertFunc.args(List.of(), List.of()).pass().expectLog(
|
||||
"assertStringListEquals()").createForMessage("Gull")));
|
||||
|
||||
data.addAll(List.of(assertFunc.args(List.of("a", "b"), List.of("a", "b")).pass().expectLog(
|
||||
"assertStringListEquals()",
|
||||
"assertStringListEquals(1, a)",
|
||||
"assertStringListEquals(2, b)").createForMessage("Pelican")));
|
||||
|
||||
assertFunc.fail().withAutoExpectLogPrefix(false);
|
||||
for (var msg : new String[] { "Raven", null }) {
|
||||
data.addAll(List.of(assertFunc.args(List.of("a"), List.of("a", "b"), msg).expectLog(
|
||||
concatMessages("TRACE: assertStringListEquals()", msg),
|
||||
"TRACE: assertStringListEquals(1, a)",
|
||||
concatMessages("ERROR: Actual list is longer than expected by 1 elements", msg)
|
||||
).create()));
|
||||
|
||||
data.addAll(List.of(assertFunc.args(List.of("n", "m"), List.of("n"), msg).expectLog(
|
||||
concatMessages("TRACE: assertStringListEquals()", msg),
|
||||
"TRACE: assertStringListEquals(1, n)",
|
||||
concatMessages("ERROR: Actual list is shorter than expected by 1 elements", msg)
|
||||
).create()));
|
||||
|
||||
data.addAll(List.of(assertFunc.args(List.of("a", "b"), List.of("n", "m"), msg).expectLog(
|
||||
concatMessages("TRACE: assertStringListEquals()", msg),
|
||||
concatMessages("ERROR: (1) Expected [a]. Actual [n]", msg)
|
||||
).create()));
|
||||
}
|
||||
|
||||
return data.stream().map(v -> {
|
||||
return new Object[]{v};
|
||||
}).toList();
|
||||
}
|
||||
|
||||
public record MethodCallConfig(Method method, Object[] args, boolean expectFail, String[] expectLog) {
|
||||
@Override
|
||||
public String toString() {
|
||||
return String.format("%s%s%s", method.getName(), Arrays.toString(args), expectFail ? "!" : "");
|
||||
}
|
||||
|
||||
static Builder build(String name, Class<?> ... parameterTypes) {
|
||||
return new Builder(name, parameterTypes);
|
||||
}
|
||||
|
||||
private static class Builder {
|
||||
Builder(Method method) {
|
||||
Objects.requireNonNull(method);
|
||||
this.method = method;
|
||||
}
|
||||
|
||||
Builder(String name, Class<?> ... parameterTypes) {
|
||||
method = toSupplier(() -> TKit.class.getMethod(name, parameterTypes)).get();
|
||||
}
|
||||
|
||||
MethodCallConfig create() {
|
||||
String[] effectiveExpectLog;
|
||||
if (!withAutoExpectLogPrefix) {
|
||||
effectiveExpectLog = expectLog;
|
||||
} else {
|
||||
var prefix = expectFail ? "ERROR: " : "TRACE: ";
|
||||
effectiveExpectLog = Stream.of(expectLog).map(line -> {
|
||||
return prefix + line;
|
||||
}).toArray(String[]::new);
|
||||
}
|
||||
return new MethodCallConfig(method, args, expectFail, effectiveExpectLog);
|
||||
}
|
||||
|
||||
MethodCallConfig[] createForMessage(String msg) {
|
||||
return Arrays.asList(msg, null).stream().map(curMsg -> {
|
||||
var builder = new Builder(method);
|
||||
builder.expectFail = expectFail;
|
||||
builder.withAutoExpectLogPrefix = withAutoExpectLogPrefix;
|
||||
builder.args = Stream.concat(Stream.of(args), Stream.of(curMsg)).toArray();
|
||||
builder.expectLog = Arrays.copyOf(expectLog, expectLog.length);
|
||||
builder.expectLog[0] = concatMessages(builder.expectLog[0], curMsg);
|
||||
return builder.create();
|
||||
}).toArray(MethodCallConfig[]::new);
|
||||
}
|
||||
|
||||
Builder fail() {
|
||||
expectFail = true;
|
||||
return this;
|
||||
}
|
||||
|
||||
Builder pass() {
|
||||
expectFail = false;
|
||||
return this;
|
||||
}
|
||||
|
||||
Builder args(Object ... v) {
|
||||
args = v;
|
||||
return this;
|
||||
}
|
||||
|
||||
Builder expectLog(String expectLogFirstStr, String ... extra) {
|
||||
expectLog = Stream.concat(Stream.of(expectLogFirstStr), Stream.of(extra)).toArray(String[]::new);
|
||||
return this;
|
||||
}
|
||||
|
||||
Builder withAutoExpectLogPrefix(boolean v) {
|
||||
withAutoExpectLogPrefix = v;
|
||||
return this;
|
||||
}
|
||||
|
||||
private final Method method;
|
||||
private Object[] args = new Object[0];
|
||||
private boolean expectFail;
|
||||
private String[] expectLog;
|
||||
private boolean withAutoExpectLogPrefix = true;
|
||||
}
|
||||
}
|
||||
|
||||
public TKitTest(MethodCallConfig methodCall) {
|
||||
this.methodCall = methodCall;
|
||||
}
|
||||
|
||||
@Test
|
||||
public void test() {
|
||||
runAssertWithExpectedLogOutput(() -> {
|
||||
methodCall.method.invoke(null, methodCall.args);
|
||||
}, methodCall.expectFail, methodCall.expectLog);
|
||||
}
|
||||
|
||||
private static void runAssertWithExpectedLogOutput(ThrowingRunnable action,
|
||||
boolean expectFail, String... expectLogStrings) {
|
||||
runWithExpectedLogOutput(() -> {
|
||||
TKit.assertAssert(!expectFail, toRunnable(action));
|
||||
}, expectLogStrings);
|
||||
}
|
||||
|
||||
private static void runWithExpectedLogOutput(ThrowingRunnable action,
|
||||
String... expectLogStrings) {
|
||||
final var buf = new ByteArrayOutputStream();
|
||||
try (PrintStream ps = new PrintStream(buf, true, StandardCharsets.UTF_8)) {
|
||||
TKit.withExtraLogStream(action, ps);
|
||||
} finally {
|
||||
toRunnable(() -> {
|
||||
var output = new BufferedReader(new InputStreamReader(
|
||||
new ByteArrayInputStream(buf.toByteArray()),
|
||||
StandardCharsets.UTF_8)).lines().map(line -> {
|
||||
// Skip timestamp
|
||||
return line.substring(LOG_MSG_TIMESTAMP_LENGTH);
|
||||
}).toList();
|
||||
if (output.size() == 1 && expectLogStrings.length == 1) {
|
||||
TKit.assertEquals(expectLogStrings[0], output.get(0), null);
|
||||
} else {
|
||||
TKit.assertStringListEquals(List.of(expectLogStrings), output, null);
|
||||
}
|
||||
}).run();
|
||||
}
|
||||
}
|
||||
|
||||
private static String concatMessages(String msg, String msg2) {
|
||||
if (msg2 != null && !msg2.isBlank()) {
|
||||
return msg + ": " + msg2;
|
||||
}
|
||||
return msg;
|
||||
}
|
||||
|
||||
private final MethodCallConfig methodCall;
|
||||
|
||||
private static final int LOG_MSG_TIMESTAMP_LENGTH = "[HH:mm:ss.SSS] ".length();
|
||||
}
|
@ -0,0 +1,63 @@
|
||||
/*
|
||||
* Copyright (c) 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.
|
||||
*/
|
||||
package jdk.jpackage.test;
|
||||
|
||||
import java.nio.file.Files;
|
||||
import java.nio.file.Path;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
/*
|
||||
* @test
|
||||
* @summary Unit tests for jpackage test library
|
||||
* @library /test/jdk/tools/jpackage/helpers
|
||||
* @library /test/jdk/tools/jpackage/helpers-test
|
||||
* @build jdk.jpackage.test.*
|
||||
* @run main/othervm/timeout=360 -Xmx512m jdk.jpackage.test.TestSuite
|
||||
*/
|
||||
|
||||
public final class TestSuite {
|
||||
public static void main(String args[]) throws Throwable {
|
||||
final var pkgName = TestSuite.class.getPackageName();
|
||||
final var javaSuffix = ".java";
|
||||
final var testSrcNameSuffix = "Test" + javaSuffix;
|
||||
|
||||
final var unitTestDir = TKit.TEST_SRC_ROOT.resolve(Path.of("helpers-test", pkgName.split("\\.")));
|
||||
|
||||
final List<String> runTestArgs = new ArrayList<>();
|
||||
runTestArgs.addAll(List.of(args));
|
||||
|
||||
try (var javaSources = Files.list(unitTestDir)) {
|
||||
runTestArgs.addAll(javaSources.filter(path -> {
|
||||
return path.getFileName().toString().endsWith(testSrcNameSuffix);
|
||||
}).map(path -> {
|
||||
var filename = path.getFileName().toString();
|
||||
return String.join(".", pkgName, filename.substring(0, filename.length() - javaSuffix.length()));
|
||||
}).map(testClassName -> {
|
||||
return "--jpt-run=" + testClassName;
|
||||
}).toList());
|
||||
}
|
||||
|
||||
Main.main(runTestArgs.toArray(String[]::new));
|
||||
}
|
||||
}
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 2019, 2022, 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.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
@ -151,12 +151,16 @@ public class Functional {
|
||||
@SuppressWarnings("unchecked")
|
||||
public static RuntimeException rethrowUnchecked(Throwable throwable) throws
|
||||
ExceptionBox {
|
||||
if (throwable instanceof RuntimeException) {
|
||||
throw (RuntimeException)throwable;
|
||||
if (throwable instanceof RuntimeException err) {
|
||||
throw err;
|
||||
}
|
||||
|
||||
if (throwable instanceof InvocationTargetException) {
|
||||
throw new ExceptionBox(throwable.getCause());
|
||||
if (throwable instanceof Error err) {
|
||||
throw err;
|
||||
}
|
||||
|
||||
if (throwable instanceof InvocationTargetException err) {
|
||||
throw rethrowUnchecked(err.getCause());
|
||||
}
|
||||
|
||||
throw new ExceptionBox(throwable);
|
||||
|
@ -22,7 +22,6 @@
|
||||
*/
|
||||
package jdk.jpackage.test;
|
||||
|
||||
import java.io.File;
|
||||
import java.io.IOException;
|
||||
import java.nio.file.Files;
|
||||
import java.nio.file.Path;
|
||||
@ -57,15 +56,10 @@ public final class HelloApp {
|
||||
|
||||
private JarBuilder prepareSources(Path srcDir) throws IOException {
|
||||
final String srcClassName = appDesc.srcClassName();
|
||||
|
||||
final String qualifiedClassName = appDesc.className();
|
||||
|
||||
final String className = qualifiedClassName.substring(
|
||||
qualifiedClassName.lastIndexOf('.') + 1);
|
||||
final String className = appDesc.shortClassName();
|
||||
final String packageName = appDesc.packageName();
|
||||
|
||||
final Path srcFile = srcDir.resolve(Path.of(String.join(
|
||||
File.separator, qualifiedClassName.split("\\.")) + ".java"));
|
||||
final Path srcFile = srcDir.resolve(appDesc.classNameAsPath(".java"));
|
||||
Files.createDirectories(srcFile.getParent());
|
||||
|
||||
JarBuilder jarBuilder = createJarBuilder().addSourceFile(srcFile);
|
||||
@ -351,7 +345,7 @@ public final class HelloApp {
|
||||
}
|
||||
|
||||
|
||||
public final static class AppOutputVerifier {
|
||||
public static final class AppOutputVerifier {
|
||||
AppOutputVerifier(Path helloAppLauncher) {
|
||||
this.launcherPath = helloAppLauncher;
|
||||
this.outputFilePath = TKit.workDir().resolve(OUTPUT_FILENAME);
|
||||
@ -493,13 +487,13 @@ public final class HelloApp {
|
||||
return new AppOutputVerifier(helloAppLauncher);
|
||||
}
|
||||
|
||||
final static String OUTPUT_FILENAME = "appOutput.txt";
|
||||
static final String OUTPUT_FILENAME = "appOutput.txt";
|
||||
|
||||
private final JavaAppDesc appDesc;
|
||||
|
||||
private static final Path HELLO_JAVA = TKit.TEST_SRC_ROOT.resolve(
|
||||
"apps/Hello.java");
|
||||
|
||||
private final static String CLASS_NAME = HELLO_JAVA.getFileName().toString().split(
|
||||
private static final String CLASS_NAME = HELLO_JAVA.getFileName().toString().split(
|
||||
"\\.", 2)[0];
|
||||
}
|
||||
|
@ -22,8 +22,9 @@
|
||||
*/
|
||||
package jdk.jpackage.test;
|
||||
|
||||
import java.io.File;
|
||||
import java.nio.file.Path;
|
||||
import java.util.Objects;
|
||||
import java.util.stream.Stream;
|
||||
|
||||
|
||||
public final class JavaAppDesc {
|
||||
@ -73,9 +74,18 @@ public final class JavaAppDesc {
|
||||
return qualifiedClassName;
|
||||
}
|
||||
|
||||
public String shortClassName() {
|
||||
return qualifiedClassName.substring(qualifiedClassName.lastIndexOf('.') + 1);
|
||||
}
|
||||
|
||||
Path classNameAsPath(String extension) {
|
||||
final String[] pathComponents = qualifiedClassName.split("\\.");
|
||||
pathComponents[pathComponents.length - 1] = shortClassName() + extension;
|
||||
return Stream.of(pathComponents).map(Path::of).reduce(Path::resolve).get();
|
||||
}
|
||||
|
||||
public Path classFilePath() {
|
||||
return Path.of(qualifiedClassName.replace(".", File.separator)
|
||||
+ ".class");
|
||||
return classNameAsPath(".class");
|
||||
}
|
||||
|
||||
public String moduleName() {
|
||||
@ -124,6 +134,48 @@ public final class JavaAppDesc {
|
||||
return withMainClass;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int hashCode() {
|
||||
int hash = 5;
|
||||
hash = 79 * hash + Objects.hashCode(this.srcJavaPath);
|
||||
hash = 79 * hash + Objects.hashCode(this.qualifiedClassName);
|
||||
hash = 79 * hash + Objects.hashCode(this.moduleName);
|
||||
hash = 79 * hash + Objects.hashCode(this.bundleFileName);
|
||||
hash = 79 * hash + Objects.hashCode(this.moduleVersion);
|
||||
hash = 79 * hash + (this.withMainClass ? 1 : 0);
|
||||
return hash;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean equals(Object obj) {
|
||||
if (this == obj) {
|
||||
return true;
|
||||
}
|
||||
if (obj == null) {
|
||||
return false;
|
||||
}
|
||||
if (getClass() != obj.getClass()) {
|
||||
return false;
|
||||
}
|
||||
final JavaAppDesc other = (JavaAppDesc) obj;
|
||||
if (this.withMainClass != other.withMainClass) {
|
||||
return false;
|
||||
}
|
||||
if (!Objects.equals(this.qualifiedClassName, other.qualifiedClassName)) {
|
||||
return false;
|
||||
}
|
||||
if (!Objects.equals(this.moduleName, other.moduleName)) {
|
||||
return false;
|
||||
}
|
||||
if (!Objects.equals(this.bundleFileName, other.bundleFileName)) {
|
||||
return false;
|
||||
}
|
||||
if (!Objects.equals(this.moduleVersion, other.moduleVersion)) {
|
||||
return false;
|
||||
}
|
||||
return Objects.equals(this.srcJavaPath, other.srcJavaPath);
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
StringBuilder sb = new StringBuilder();
|
||||
|
@ -22,9 +22,7 @@
|
||||
*/
|
||||
package jdk.jpackage.test;
|
||||
|
||||
import java.awt.Desktop;
|
||||
import java.awt.GraphicsEnvironment;
|
||||
import java.io.File;
|
||||
import java.io.IOException;
|
||||
import java.nio.file.Files;
|
||||
import java.nio.file.Path;
|
||||
@ -788,7 +786,7 @@ public final class PackageTest extends RunnablePackageTest {
|
||||
private Map<PackageType, PackageHandlers> packageHandlers;
|
||||
private boolean ignoreBundleOutputDir;
|
||||
|
||||
private static final File BUNDLE_OUTPUT_DIR;
|
||||
private static final Path BUNDLE_OUTPUT_DIR;
|
||||
|
||||
static {
|
||||
final String propertyName = "output";
|
||||
@ -796,9 +794,9 @@ public final class PackageTest extends RunnablePackageTest {
|
||||
if (val == null) {
|
||||
BUNDLE_OUTPUT_DIR = null;
|
||||
} else {
|
||||
BUNDLE_OUTPUT_DIR = new File(val).getAbsoluteFile();
|
||||
BUNDLE_OUTPUT_DIR = Path.of(val).toAbsolutePath();
|
||||
|
||||
if (!BUNDLE_OUTPUT_DIR.isDirectory()) {
|
||||
if (!Files.isDirectory(BUNDLE_OUTPUT_DIR)) {
|
||||
throw new IllegalArgumentException(String.format("Invalid value of %s sytem property: [%s]. Should be existing directory",
|
||||
TKit.getConfigPropertyName(propertyName),
|
||||
BUNDLE_OUTPUT_DIR));
|
||||
|
@ -23,7 +23,6 @@
|
||||
package jdk.jpackage.test;
|
||||
|
||||
import java.io.Closeable;
|
||||
import java.io.File;
|
||||
import java.io.FileOutputStream;
|
||||
import java.io.IOException;
|
||||
import java.io.PrintStream;
|
||||
@ -107,14 +106,21 @@ public final class TKit {
|
||||
ThrowingRunnable.toRunnable(action).run();
|
||||
} else {
|
||||
try (PrintStream logStream = openLogStream()) {
|
||||
extraLogStream = logStream;
|
||||
ThrowingRunnable.toRunnable(action).run();
|
||||
} finally {
|
||||
extraLogStream = null;
|
||||
withExtraLogStream(action, logStream);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
static void withExtraLogStream(ThrowingRunnable action, PrintStream logStream) {
|
||||
var oldExtraLogStream = extraLogStream;
|
||||
try {
|
||||
extraLogStream = logStream;
|
||||
ThrowingRunnable.toRunnable(action).run();
|
||||
} finally {
|
||||
extraLogStream = oldExtraLogStream;
|
||||
}
|
||||
}
|
||||
|
||||
static void runTests(List<TestInstance> tests) {
|
||||
if (currentTest != null) {
|
||||
throw new IllegalStateException(
|
||||
@ -187,11 +193,7 @@ public final class TKit {
|
||||
}
|
||||
|
||||
public static boolean isLinuxAPT() {
|
||||
if (!isLinux()) {
|
||||
return false;
|
||||
}
|
||||
File aptFile = new File("/usr/bin/apt-get");
|
||||
return aptFile.exists();
|
||||
return isLinux() && Files.exists(Path.of("/usr/bin/apt-get"));
|
||||
}
|
||||
|
||||
private static String addTimestamp(String msg) {
|
||||
@ -598,7 +600,7 @@ public final class TKit {
|
||||
msg));
|
||||
}
|
||||
|
||||
traceAssert(String.format("assertEquals(%d): %s", expected, msg));
|
||||
traceAssert(concatMessages(String.format("assertEquals(%d)", expected), msg));
|
||||
}
|
||||
|
||||
public static void assertNotEquals(long expected, long actual, String msg) {
|
||||
@ -608,8 +610,8 @@ public final class TKit {
|
||||
msg));
|
||||
}
|
||||
|
||||
traceAssert(String.format("assertNotEquals(%d, %d): %s", expected,
|
||||
actual, msg));
|
||||
traceAssert(concatMessages(String.format("assertNotEquals(%d, %d)", expected,
|
||||
actual), msg));
|
||||
}
|
||||
|
||||
public static void assertEquals(String expected, String actual, String msg) {
|
||||
@ -621,7 +623,7 @@ public final class TKit {
|
||||
msg));
|
||||
}
|
||||
|
||||
traceAssert(String.format("assertEquals(%s): %s", expected, msg));
|
||||
traceAssert(concatMessages(String.format("assertEquals(%s)", expected), msg));
|
||||
}
|
||||
|
||||
public static void assertNotEquals(String expected, String actual, String msg) {
|
||||
@ -629,8 +631,8 @@ public final class TKit {
|
||||
if ((actual != null && !actual.equals(expected))
|
||||
|| (expected != null && !expected.equals(actual))) {
|
||||
|
||||
traceAssert(String.format("assertNotEquals(%s, %s): %s", expected,
|
||||
actual, msg));
|
||||
traceAssert(concatMessages(String.format("assertNotEquals(%s, %s)", expected,
|
||||
actual), msg));
|
||||
return;
|
||||
}
|
||||
|
||||
@ -644,7 +646,7 @@ public final class TKit {
|
||||
value), msg));
|
||||
}
|
||||
|
||||
traceAssert(String.format("assertNull(): %s", msg));
|
||||
traceAssert(concatMessages("assertNull()", msg));
|
||||
}
|
||||
|
||||
public static void assertNotNull(Object value, String msg) {
|
||||
@ -653,7 +655,7 @@ public final class TKit {
|
||||
error(concatMessages("Unexpected null value", msg));
|
||||
}
|
||||
|
||||
traceAssert(String.format("assertNotNull(%s): %s", value, msg));
|
||||
traceAssert(concatMessages(String.format("assertNotNull(%s)", value), msg));
|
||||
}
|
||||
|
||||
public static void assertTrue(boolean actual, String msg) {
|
||||
@ -673,7 +675,7 @@ public final class TKit {
|
||||
error(concatMessages("Failed", msg));
|
||||
}
|
||||
|
||||
traceAssert(String.format("assertTrue(): %s", msg));
|
||||
traceAssert(concatMessages("assertTrue()", msg));
|
||||
}
|
||||
|
||||
public static void assertFalse(boolean actual, String msg, Runnable onFail) {
|
||||
@ -685,7 +687,7 @@ public final class TKit {
|
||||
error(concatMessages("Failed", msg));
|
||||
}
|
||||
|
||||
traceAssert(String.format("assertFalse(): %s", msg));
|
||||
traceAssert(concatMessages("assertFalse()", msg));
|
||||
}
|
||||
|
||||
public static void assertPathExists(Path path, boolean exists) {
|
||||
@ -865,7 +867,7 @@ public final class TKit {
|
||||
List<String> actual, String msg) {
|
||||
currentTest.notifyAssert();
|
||||
|
||||
traceAssert(String.format("assertStringListEquals(): %s", msg));
|
||||
traceAssert(concatMessages("assertStringListEquals()", msg));
|
||||
|
||||
String idxFieldFormat = Functional.identity(() -> {
|
||||
int listSize = expected.size();
|
||||
@ -895,7 +897,7 @@ public final class TKit {
|
||||
expectedStr));
|
||||
});
|
||||
|
||||
if (expected.size() < actual.size()) {
|
||||
if (actual.size() > expected.size()) {
|
||||
// Actual string list is longer than expected
|
||||
error(concatMessages(String.format(
|
||||
"Actual list is longer than expected by %d elements",
|
||||
@ -905,7 +907,7 @@ public final class TKit {
|
||||
if (actual.size() < expected.size()) {
|
||||
// Actual string list is shorter than expected
|
||||
error(concatMessages(String.format(
|
||||
"Actual list is longer than expected by %d elements",
|
||||
"Actual list is shorter than expected by %d elements",
|
||||
expected.size() - actual.size()), msg));
|
||||
}
|
||||
}
|
||||
|
@ -22,8 +22,6 @@
|
||||
*/
|
||||
|
||||
import java.nio.file.Path;
|
||||
import java.io.File;
|
||||
import java.util.Map;
|
||||
import java.lang.invoke.MethodHandles;
|
||||
import jdk.jpackage.test.PackageTest;
|
||||
import jdk.jpackage.test.FileAssociations;
|
||||
@ -109,6 +107,6 @@ public class AddLShortcutTest {
|
||||
packageTest.run();
|
||||
}
|
||||
|
||||
private final static Path GOLDEN_ICON = TKit.TEST_SRC_ROOT.resolve(Path.of(
|
||||
private static final Path GOLDEN_ICON = TKit.TEST_SRC_ROOT.resolve(Path.of(
|
||||
"resources", "icon" + TKit.ICON_SUFFIX));
|
||||
}
|
||||
|
@ -22,7 +22,6 @@
|
||||
*/
|
||||
|
||||
import java.nio.file.Path;
|
||||
import java.io.File;
|
||||
import java.util.Map;
|
||||
import java.lang.invoke.MethodHandles;
|
||||
import jdk.jpackage.test.PackageTest;
|
||||
@ -229,11 +228,11 @@ public class AddLauncherTest {
|
||||
TKit.assertEquals(ExpectedCN, mainClass,
|
||||
String.format("Check value of app.mainclass=[%s]" +
|
||||
"in NonModularAppLauncher cfg file is as expected", ExpectedCN));
|
||||
TKit.assertTrue(classpath.startsWith("$APPDIR" + File.separator
|
||||
+ nonModularAppDesc.jarFileName()),
|
||||
TKit.assertTrue(classpath.startsWith(Path.of("$APPDIR",
|
||||
nonModularAppDesc.jarFileName()).toString()),
|
||||
"Check app.classpath value in ModularAppLauncher cfg file");
|
||||
}
|
||||
|
||||
private final static Path GOLDEN_ICON = TKit.TEST_SRC_ROOT.resolve(Path.of(
|
||||
private static final Path GOLDEN_ICON = TKit.TEST_SRC_ROOT.resolve(Path.of(
|
||||
"resources", "icon" + TKit.ICON_SUFFIX));
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user