< prev index next >
test/jdk/tools/jpackage/share/AddLauncherBase.java
Print this page
@@ -27,15 +27,13 @@
import java.io.PrintWriter;
import java.nio.file.Files;
import java.util.ArrayList;
import java.util.List;
-public class JPackageCreateAppImageAddLauncherBase {
+public class AddLauncherBase {
private static final String app = JPackagePath.getApp();
- private static final String app2 = JPackagePath.getAppSL();
private static final String appOutput = JPackagePath.getAppOutputFile();
- private static final String appWorkingDir = JPackagePath.getAppWorkingDir();
// Note: quotes in argument for add launcher is not support by test
private static final String ARGUMENT1 = "argument 1";
private static final String ARGUMENT2 = "argument 2";
private static final String ARGUMENT3 = "argument 3";
@@ -45,76 +43,117 @@
private static final String PARAM1 = "-Dparam1=Some Param 1";
private static final String PARAM2 = "-Dparam2=Some Param 2";
private static final String PARAM3 = "-Dparam3=Some Param 3";
private static final List<String> vmArguments = new ArrayList<>();
+ private static final List<String> empty = new ArrayList<>();
private static void validateResult(List<String> args, List<String> vmArgs)
throws Exception {
- File outfile = new File(appWorkingDir + File.separator + appOutput);
+ File outfile = new File(appOutput);
if (!outfile.exists()) {
throw new AssertionError(appOutput + " was not created");
}
String output = Files.readString(outfile.toPath());
String[] result = output.split("\n");
- if (result.length != (args.size() + vmArgs.size() + 2)) {
+ int expected = 2 + args.size() + vmArgs.size();
+
+ if (result.length != expected) {
throw new AssertionError("Unexpected number of lines: "
- + result.length);
+ + result.length + " expected: " + expected + " - results: " + output);
}
- if (!result[0].trim().equals("jpackage test application")) {
+ if (!result[0].trim().endsWith("jpackage test application")) {
throw new AssertionError("Unexpected result[0]: " + result[0]);
}
if (!result[1].trim().equals("args.length: " + args.size())) {
throw new AssertionError("Unexpected result[1]: " + result[1]);
}
int index = 2;
for (String arg : args) {
if (!result[index].trim().equals(arg)) {
- throw new AssertionError("Unexpected result[" + index + "]: "
- + result[index]);
+ throw new AssertionError("Unexpected result["
+ + index + "]: " + result[index]);
}
index++;
}
for (String vmArg : vmArgs) {
if (!result[index].trim().equals(vmArg)) {
- throw new AssertionError("Unexpected result[" + index + "]: "
- + result[index]);
+ throw new AssertionError("Unexpected result["
+ + index + "]: " + result[index]);
}
index++;
}
}
- private static void validate() throws Exception {
+ private static void validate(boolean includeArgs, String name)
+ throws Exception {
int retVal = JPackageHelper.execute(null, app);
if (retVal != 0) {
- throw new AssertionError("Test application exited with error: "
- + retVal);
+ throw new AssertionError("Test application " + app
+ + " exited with error: " + retVal);
}
validateResult(new ArrayList<>(), new ArrayList<>());
+ String app2 = JPackagePath.getAppSL(name);
retVal = JPackageHelper.execute(null, app2);
if (retVal != 0) {
- throw new AssertionError("Test application exited with error: "
- + retVal);
+ throw new AssertionError("Test application " + app2
+ + " exited with error: " + retVal);
}
+ if (includeArgs) {
validateResult(arguments, vmArguments);
+ } else {
+ validateResult(empty, empty);
+ }
}
public static void testCreateAppImage(String [] cmd) throws Exception {
+ testCreateAppImage(cmd, true, "test2");
+ }
+
+ public static void testCreateAppImage(String [] cmd,
+ boolean includeArgs, String name) throws Exception {
JPackageHelper.executeCLI(true, cmd);
- validate();
+ validate(includeArgs, name);
+ }
+
+ public static void testCreateAppImageToolProvider(String [] cmd)
+ throws Exception {
+ testCreateAppImageToolProvider(cmd, true, "test2");
}
- public static void testCreateAppImageToolProvider(String [] cmd) throws Exception {
+ public static void testCreateAppImageToolProvider(String [] cmd,
+ boolean includeArgs, String name) throws Exception {
JPackageHelper.executeToolProvider(true, cmd);
- validate();
+ validate(includeArgs, name);
+ }
+
+ public static void testCreateAppImage(String [] cmd,
+ ArrayList<String> argList, ArrayList <String> optionList)
+ throws Exception {
+ JPackageHelper.executeCLI(true, cmd);
+ int retVal = JPackageHelper.execute(null, app);
+ if (retVal != 0) {
+ throw new AssertionError("Test application " + app
+ + " exited with error: " + retVal);
+ }
+ validateResult(argList, optionList);
+ String name = "test4";
+
+ String app2 = JPackagePath.getAppSL(name);
+ retVal = JPackageHelper.execute(null, app2);
+ if (retVal != 0) {
+ throw new AssertionError("Test application " + app2
+ + " exited with error: " + retVal);
+ }
+ validateResult(arguments, vmArguments);
}
public static void createSLProperties() throws Exception {
arguments.add(ARGUMENT1);
arguments.add(ARGUMENT2);
@@ -133,8 +172,22 @@
try (PrintWriter out = new PrintWriter(new BufferedWriter(
new FileWriter("sl.properties")))) {
out.println("arguments=" + argumentsMap);
out.println("java-options=" + vmArgumentsMap);
}
+
+ try (PrintWriter out = new PrintWriter(new BufferedWriter(
+ new FileWriter("m1.properties")))) {
+ out.println("module=com.hello/com.hello.Hello");
+ out.println("main-jar=");
+ }
+
+ try (PrintWriter out = new PrintWriter(new BufferedWriter(
+ new FileWriter("j1.properties")))) {
+ out.println("main-jar hello.jar");
+ out.println("main-class Hello");
+ }
+
+
}
}
< prev index next >