8343875: Minor improvements of jpackage test library

Reviewed-by: almatvee
This commit is contained in:
Alexey Semenyuk 2024-11-14 04:18:26 +00:00
parent 90e92342fc
commit 95a00f8a18
11 changed files with 506 additions and 63 deletions

View File

@ -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 {

View File

@ -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;
}

View File

@ -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();
}

View File

@ -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));
}
}

View File

@ -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);

View File

@ -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];
} }

View File

@ -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();

View File

@ -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));

View File

@ -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));
} }
} }

View File

@ -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));
} }

View File

@ -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));
} }