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 jdk.jpackage.test.TKit.DirectoryContentVerifier;
|
||||||
import static jdk.jpackage.test.TKit.assertAssert;
|
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 {
|
public class DirectoryContentVerifierTest {
|
||||||
|
|
||||||
enum AssertType {
|
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.
|
* 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
|
||||||
@ -151,12 +151,16 @@ public class Functional {
|
|||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
public static RuntimeException rethrowUnchecked(Throwable throwable) throws
|
public static RuntimeException rethrowUnchecked(Throwable throwable) throws
|
||||||
ExceptionBox {
|
ExceptionBox {
|
||||||
if (throwable instanceof RuntimeException) {
|
if (throwable instanceof RuntimeException err) {
|
||||||
throw (RuntimeException)throwable;
|
throw err;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (throwable instanceof InvocationTargetException) {
|
if (throwable instanceof Error err) {
|
||||||
throw new ExceptionBox(throwable.getCause());
|
throw err;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (throwable instanceof InvocationTargetException err) {
|
||||||
|
throw rethrowUnchecked(err.getCause());
|
||||||
}
|
}
|
||||||
|
|
||||||
throw new ExceptionBox(throwable);
|
throw new ExceptionBox(throwable);
|
||||||
|
@ -22,7 +22,6 @@
|
|||||||
*/
|
*/
|
||||||
package jdk.jpackage.test;
|
package jdk.jpackage.test;
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.nio.file.Files;
|
import java.nio.file.Files;
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
@ -57,15 +56,10 @@ public final class HelloApp {
|
|||||||
|
|
||||||
private JarBuilder prepareSources(Path srcDir) throws IOException {
|
private JarBuilder prepareSources(Path srcDir) throws IOException {
|
||||||
final String srcClassName = appDesc.srcClassName();
|
final String srcClassName = appDesc.srcClassName();
|
||||||
|
final String className = appDesc.shortClassName();
|
||||||
final String qualifiedClassName = appDesc.className();
|
|
||||||
|
|
||||||
final String className = qualifiedClassName.substring(
|
|
||||||
qualifiedClassName.lastIndexOf('.') + 1);
|
|
||||||
final String packageName = appDesc.packageName();
|
final String packageName = appDesc.packageName();
|
||||||
|
|
||||||
final Path srcFile = srcDir.resolve(Path.of(String.join(
|
final Path srcFile = srcDir.resolve(appDesc.classNameAsPath(".java"));
|
||||||
File.separator, qualifiedClassName.split("\\.")) + ".java"));
|
|
||||||
Files.createDirectories(srcFile.getParent());
|
Files.createDirectories(srcFile.getParent());
|
||||||
|
|
||||||
JarBuilder jarBuilder = createJarBuilder().addSourceFile(srcFile);
|
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) {
|
AppOutputVerifier(Path helloAppLauncher) {
|
||||||
this.launcherPath = helloAppLauncher;
|
this.launcherPath = helloAppLauncher;
|
||||||
this.outputFilePath = TKit.workDir().resolve(OUTPUT_FILENAME);
|
this.outputFilePath = TKit.workDir().resolve(OUTPUT_FILENAME);
|
||||||
@ -493,13 +487,13 @@ public final class HelloApp {
|
|||||||
return new AppOutputVerifier(helloAppLauncher);
|
return new AppOutputVerifier(helloAppLauncher);
|
||||||
}
|
}
|
||||||
|
|
||||||
final static String OUTPUT_FILENAME = "appOutput.txt";
|
static final String OUTPUT_FILENAME = "appOutput.txt";
|
||||||
|
|
||||||
private final JavaAppDesc appDesc;
|
private final JavaAppDesc appDesc;
|
||||||
|
|
||||||
private static final Path HELLO_JAVA = TKit.TEST_SRC_ROOT.resolve(
|
private static final Path HELLO_JAVA = TKit.TEST_SRC_ROOT.resolve(
|
||||||
"apps/Hello.java");
|
"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];
|
"\\.", 2)[0];
|
||||||
}
|
}
|
||||||
|
@ -22,8 +22,9 @@
|
|||||||
*/
|
*/
|
||||||
package jdk.jpackage.test;
|
package jdk.jpackage.test;
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
|
import java.util.Objects;
|
||||||
|
import java.util.stream.Stream;
|
||||||
|
|
||||||
|
|
||||||
public final class JavaAppDesc {
|
public final class JavaAppDesc {
|
||||||
@ -73,9 +74,18 @@ public final class JavaAppDesc {
|
|||||||
return qualifiedClassName;
|
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() {
|
public Path classFilePath() {
|
||||||
return Path.of(qualifiedClassName.replace(".", File.separator)
|
return classNameAsPath(".class");
|
||||||
+ ".class");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public String moduleName() {
|
public String moduleName() {
|
||||||
@ -124,6 +134,48 @@ public final class JavaAppDesc {
|
|||||||
return withMainClass;
|
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
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
StringBuilder sb = new StringBuilder();
|
StringBuilder sb = new StringBuilder();
|
||||||
|
@ -22,9 +22,7 @@
|
|||||||
*/
|
*/
|
||||||
package jdk.jpackage.test;
|
package jdk.jpackage.test;
|
||||||
|
|
||||||
import java.awt.Desktop;
|
|
||||||
import java.awt.GraphicsEnvironment;
|
import java.awt.GraphicsEnvironment;
|
||||||
import java.io.File;
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.nio.file.Files;
|
import java.nio.file.Files;
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
@ -788,7 +786,7 @@ public final class PackageTest extends RunnablePackageTest {
|
|||||||
private Map<PackageType, PackageHandlers> packageHandlers;
|
private Map<PackageType, PackageHandlers> packageHandlers;
|
||||||
private boolean ignoreBundleOutputDir;
|
private boolean ignoreBundleOutputDir;
|
||||||
|
|
||||||
private static final File BUNDLE_OUTPUT_DIR;
|
private static final Path BUNDLE_OUTPUT_DIR;
|
||||||
|
|
||||||
static {
|
static {
|
||||||
final String propertyName = "output";
|
final String propertyName = "output";
|
||||||
@ -796,9 +794,9 @@ public final class PackageTest extends RunnablePackageTest {
|
|||||||
if (val == null) {
|
if (val == null) {
|
||||||
BUNDLE_OUTPUT_DIR = null;
|
BUNDLE_OUTPUT_DIR = null;
|
||||||
} else {
|
} 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",
|
throw new IllegalArgumentException(String.format("Invalid value of %s sytem property: [%s]. Should be existing directory",
|
||||||
TKit.getConfigPropertyName(propertyName),
|
TKit.getConfigPropertyName(propertyName),
|
||||||
BUNDLE_OUTPUT_DIR));
|
BUNDLE_OUTPUT_DIR));
|
||||||
|
@ -23,7 +23,6 @@
|
|||||||
package jdk.jpackage.test;
|
package jdk.jpackage.test;
|
||||||
|
|
||||||
import java.io.Closeable;
|
import java.io.Closeable;
|
||||||
import java.io.File;
|
|
||||||
import java.io.FileOutputStream;
|
import java.io.FileOutputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.PrintStream;
|
import java.io.PrintStream;
|
||||||
@ -107,11 +106,18 @@ public final class TKit {
|
|||||||
ThrowingRunnable.toRunnable(action).run();
|
ThrowingRunnable.toRunnable(action).run();
|
||||||
} else {
|
} else {
|
||||||
try (PrintStream logStream = openLogStream()) {
|
try (PrintStream logStream = openLogStream()) {
|
||||||
|
withExtraLogStream(action, logStream);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void withExtraLogStream(ThrowingRunnable action, PrintStream logStream) {
|
||||||
|
var oldExtraLogStream = extraLogStream;
|
||||||
|
try {
|
||||||
extraLogStream = logStream;
|
extraLogStream = logStream;
|
||||||
ThrowingRunnable.toRunnable(action).run();
|
ThrowingRunnable.toRunnable(action).run();
|
||||||
} finally {
|
} finally {
|
||||||
extraLogStream = null;
|
extraLogStream = oldExtraLogStream;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -187,11 +193,7 @@ public final class TKit {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static boolean isLinuxAPT() {
|
public static boolean isLinuxAPT() {
|
||||||
if (!isLinux()) {
|
return isLinux() && Files.exists(Path.of("/usr/bin/apt-get"));
|
||||||
return false;
|
|
||||||
}
|
|
||||||
File aptFile = new File("/usr/bin/apt-get");
|
|
||||||
return aptFile.exists();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static String addTimestamp(String msg) {
|
private static String addTimestamp(String msg) {
|
||||||
@ -598,7 +600,7 @@ public final class TKit {
|
|||||||
msg));
|
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) {
|
public static void assertNotEquals(long expected, long actual, String msg) {
|
||||||
@ -608,8 +610,8 @@ public final class TKit {
|
|||||||
msg));
|
msg));
|
||||||
}
|
}
|
||||||
|
|
||||||
traceAssert(String.format("assertNotEquals(%d, %d): %s", expected,
|
traceAssert(concatMessages(String.format("assertNotEquals(%d, %d)", expected,
|
||||||
actual, msg));
|
actual), msg));
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void assertEquals(String expected, String actual, String msg) {
|
public static void assertEquals(String expected, String actual, String msg) {
|
||||||
@ -621,7 +623,7 @@ public final class TKit {
|
|||||||
msg));
|
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) {
|
public static void assertNotEquals(String expected, String actual, String msg) {
|
||||||
@ -629,8 +631,8 @@ public final class TKit {
|
|||||||
if ((actual != null && !actual.equals(expected))
|
if ((actual != null && !actual.equals(expected))
|
||||||
|| (expected != null && !expected.equals(actual))) {
|
|| (expected != null && !expected.equals(actual))) {
|
||||||
|
|
||||||
traceAssert(String.format("assertNotEquals(%s, %s): %s", expected,
|
traceAssert(concatMessages(String.format("assertNotEquals(%s, %s)", expected,
|
||||||
actual, msg));
|
actual), msg));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -644,7 +646,7 @@ public final class TKit {
|
|||||||
value), msg));
|
value), msg));
|
||||||
}
|
}
|
||||||
|
|
||||||
traceAssert(String.format("assertNull(): %s", msg));
|
traceAssert(concatMessages("assertNull()", msg));
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void assertNotNull(Object value, String msg) {
|
public static void assertNotNull(Object value, String msg) {
|
||||||
@ -653,7 +655,7 @@ public final class TKit {
|
|||||||
error(concatMessages("Unexpected null value", msg));
|
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) {
|
public static void assertTrue(boolean actual, String msg) {
|
||||||
@ -673,7 +675,7 @@ public final class TKit {
|
|||||||
error(concatMessages("Failed", msg));
|
error(concatMessages("Failed", msg));
|
||||||
}
|
}
|
||||||
|
|
||||||
traceAssert(String.format("assertTrue(): %s", msg));
|
traceAssert(concatMessages("assertTrue()", msg));
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void assertFalse(boolean actual, String msg, Runnable onFail) {
|
public static void assertFalse(boolean actual, String msg, Runnable onFail) {
|
||||||
@ -685,7 +687,7 @@ public final class TKit {
|
|||||||
error(concatMessages("Failed", msg));
|
error(concatMessages("Failed", msg));
|
||||||
}
|
}
|
||||||
|
|
||||||
traceAssert(String.format("assertFalse(): %s", msg));
|
traceAssert(concatMessages("assertFalse()", msg));
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void assertPathExists(Path path, boolean exists) {
|
public static void assertPathExists(Path path, boolean exists) {
|
||||||
@ -865,7 +867,7 @@ public final class TKit {
|
|||||||
List<String> actual, String msg) {
|
List<String> actual, String msg) {
|
||||||
currentTest.notifyAssert();
|
currentTest.notifyAssert();
|
||||||
|
|
||||||
traceAssert(String.format("assertStringListEquals(): %s", msg));
|
traceAssert(concatMessages("assertStringListEquals()", msg));
|
||||||
|
|
||||||
String idxFieldFormat = Functional.identity(() -> {
|
String idxFieldFormat = Functional.identity(() -> {
|
||||||
int listSize = expected.size();
|
int listSize = expected.size();
|
||||||
@ -895,7 +897,7 @@ public final class TKit {
|
|||||||
expectedStr));
|
expectedStr));
|
||||||
});
|
});
|
||||||
|
|
||||||
if (expected.size() < actual.size()) {
|
if (actual.size() > expected.size()) {
|
||||||
// Actual string list is longer than expected
|
// Actual string list is longer than expected
|
||||||
error(concatMessages(String.format(
|
error(concatMessages(String.format(
|
||||||
"Actual list is longer than expected by %d elements",
|
"Actual list is longer than expected by %d elements",
|
||||||
@ -905,7 +907,7 @@ public final class TKit {
|
|||||||
if (actual.size() < expected.size()) {
|
if (actual.size() < expected.size()) {
|
||||||
// Actual string list is shorter than expected
|
// Actual string list is shorter than expected
|
||||||
error(concatMessages(String.format(
|
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));
|
expected.size() - actual.size()), msg));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -22,8 +22,6 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
import java.io.File;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.lang.invoke.MethodHandles;
|
import java.lang.invoke.MethodHandles;
|
||||||
import jdk.jpackage.test.PackageTest;
|
import jdk.jpackage.test.PackageTest;
|
||||||
import jdk.jpackage.test.FileAssociations;
|
import jdk.jpackage.test.FileAssociations;
|
||||||
@ -109,6 +107,6 @@ public class AddLShortcutTest {
|
|||||||
packageTest.run();
|
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));
|
"resources", "icon" + TKit.ICON_SUFFIX));
|
||||||
}
|
}
|
||||||
|
@ -22,7 +22,6 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
import java.io.File;
|
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.lang.invoke.MethodHandles;
|
import java.lang.invoke.MethodHandles;
|
||||||
import jdk.jpackage.test.PackageTest;
|
import jdk.jpackage.test.PackageTest;
|
||||||
@ -229,11 +228,11 @@ public class AddLauncherTest {
|
|||||||
TKit.assertEquals(ExpectedCN, mainClass,
|
TKit.assertEquals(ExpectedCN, mainClass,
|
||||||
String.format("Check value of app.mainclass=[%s]" +
|
String.format("Check value of app.mainclass=[%s]" +
|
||||||
"in NonModularAppLauncher cfg file is as expected", ExpectedCN));
|
"in NonModularAppLauncher cfg file is as expected", ExpectedCN));
|
||||||
TKit.assertTrue(classpath.startsWith("$APPDIR" + File.separator
|
TKit.assertTrue(classpath.startsWith(Path.of("$APPDIR",
|
||||||
+ nonModularAppDesc.jarFileName()),
|
nonModularAppDesc.jarFileName()).toString()),
|
||||||
"Check app.classpath value in ModularAppLauncher cfg file");
|
"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));
|
"resources", "icon" + TKit.ICON_SUFFIX));
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user