From f09a7f1798b1762d0d254d9feca96e5f8e3874de Mon Sep 17 00:00:00 2001 From: Gaurav Gupta Date: Wed, 11 Dec 2019 12:59:32 +0530 Subject: [PATCH 1/2] ECOSYS-14 Parsing Java version with text suffix causes NumberFormatException --- .../eclipse/payara/tools/sdk/server/JDK.java | 233 ++++++++---------- .../payara/tools/sdk/server/ServerTasks.java | 36 +-- .../sdk/server/parser/JvmConfigReader.java | 3 +- 3 files changed, 124 insertions(+), 148 deletions(-) diff --git a/plugins/org.eclipse.payara.tools/src/org/eclipse/payara/tools/sdk/server/JDK.java b/plugins/org.eclipse.payara.tools/src/org/eclipse/payara/tools/sdk/server/JDK.java index 4ec54354..6fb59dc6 100644 --- a/plugins/org.eclipse.payara.tools/src/org/eclipse/payara/tools/sdk/server/JDK.java +++ b/plugins/org.eclipse.payara.tools/src/org/eclipse/payara/tools/sdk/server/JDK.java @@ -25,23 +25,25 @@ package org.eclipse.payara.tools.sdk.server; +import java.util.Arrays; import java.util.Optional; /** - * A simple class that fills a hole in the JDK. It parses out the version numbers - * of the JDK we are running. - * + * A simple class that fills a hole in the JDK. It parses out the version + * numbers of the JDK we are running. + * *

* Example:
- * + * * 1.6.0_u14 == major = 1 minor = 6, subminor = 0, update = 14 * * @author bnevins */ public final class JDK { - - /** - * See if the current JDK is legal for running GlassFish + + /** + * See if the current JDK is legal for running Payara + * * @return true if the JDK is >= 1.6.0 */ public static boolean ok() { @@ -51,6 +53,7 @@ public static boolean ok() { public static int getMajor() { return major; } + public static int getMinor() { return minor; } @@ -62,39 +65,28 @@ public static int getSubMinor() { public static int getUpdate() { return update; } - + public static String getVendor() { return vendor; } public static class Version { - - private final Optional vendor; - private final int major; + + private final int major; private final Optional minor; private final Optional subminor; private final Optional update; - - private Version(String version) { - // Split java version into its constituent parts, i.e. - // 1.2.3.4 -> [ 1, 2, 3, 4] - // 1.2.3u4 -> [ 1, 2, 3, 4] - // 1.2.3_4 -> [ 1, 2, 3, 4] - if (version.contains("-")) { - String[] versionSplit = version.split("-"); - this.vendor = versionSplit.length > 0 ? Optional.of(versionSplit[0]) : Optional.empty(); - version = versionSplit.length > 1 ? versionSplit[1] : ""; - } else { - this.vendor = Optional.empty(); - } - String[] split = version.split("[\\._u\\-]+"); - - major = split.length > 0 ? Integer.parseInt(split[0]) : 0; - minor = split.length > 1 ? Optional.of(Integer.parseInt(split[1])) : Optional.empty(); - subminor = split.length > 2 ? Optional.of(Integer.parseInt(split[2])) : Optional.empty(); - update = split.length > 3 ? Optional.of(Integer.parseInt(split[3])) : Optional.empty(); + private final Optional vendor; + + private Version(String version, String vendor) { + int[] versions = parseVersions(version); + this.major = versions[MAJOR_INDEX]; + this.minor = Optional.ofNullable(versions[MINOR_INDEX]); + this.subminor = Optional.ofNullable(versions[SUBMINOR_INDEX]); + this.update = Optional.ofNullable(versions[UPDATE_INDEX]); + this.vendor = Optional.ofNullable(vendor); } - + private Version(int major, int minor, int subminor, int update, String vendor) { this.major = major; this.minor = Optional.of(minor); @@ -107,17 +99,17 @@ public boolean newerThan(Version version) { if (major > version.major) { return true; } - + if (major == version.major) { if (greaterThan(minor, version.minor)) { return true; } - + if (equals(minor, version.minor)) { if (greaterThan(subminor, version.subminor)) { return true; } - + if (equals(subminor, version.subminor)) { if (greaterThan(update, version.update)) { return true; @@ -165,7 +157,7 @@ private static boolean lessThan(Optional leftHandSide, Optional leftHandSide, Optional rightHandSide) { - if(!leftHandSide.isPresent() || !rightHandSide.isPresent()) { + if (!leftHandSide.isPresent() || !rightHandSide.isPresent()) { return true; } return leftHandSide.orElse(0).equals(rightHandSide.orElse(0)); @@ -236,21 +228,15 @@ public String toString() { public static Version getVersion(String string) { return getVersion(string, null); } - - public static Version getVersion(String string, String vendor) { - if (string != null && string.matches("([0-9]+[\\._u\\-]+)*[0-9]+")) { + + public static Version getVersion(String version, String vendor) { + if (version != null && version.matches(VERSION_MATCHER)) { // Make sure the string is a valid JDK version, i.e. // 1.8.0_162 or something that is returned by "java -version" - return new Version(string); + return new Version(version, vendor); } - - return null; - } - - public static Version getVersion(String jv, String javaSpecificationVersion, String vendor) { - int[] versions = parseVersions(jv, javaSpecificationVersion); - return new Version(versions[MAJOR], versions[MINOR], versions[SUBMINOR], versions[UPDATE], vendor); + return null; } public static Version getVersion() { @@ -258,36 +244,40 @@ public static Version getVersion() { } public static boolean isCorrectJDK(Optional minVersion, Optional maxVersion) { - return isCorrectJDK(JDK_VERSION, Optional.empty(), minVersion, maxVersion); + return isCorrectJDK(JDK_VERSION, Optional.empty(), minVersion, maxVersion); } - - public static boolean isCorrectJDK(Version JDKversion, Optional vendor, Optional minVersion, Optional maxVersion) { + + public static boolean isCorrectJDK(Version version, Optional vendor, Optional minVersion, Optional maxVersion) { boolean correctJDK = true; - + if (vendor.isPresent()) { - correctJDK = JDKversion.vendor.get().contains(vendor.get()); + if (version.vendor.isPresent()) { + correctJDK = version.vendor.get().contains(vendor.get()); + } else { + correctJDK = false; + } } - if (correctJDK && minVersion.isPresent()) { - correctJDK = JDKversion.newerOrEquals(minVersion.get()); + if (correctJDK && minVersion.isPresent()) { + correctJDK = version.newerOrEquals(minVersion.get()); } if (correctJDK && maxVersion.isPresent()) { - correctJDK = JDKversion.olderOrEquals(maxVersion.get()); + correctJDK = version.olderOrEquals(maxVersion.get()); } - + return correctJDK; } - /** * No instances are allowed so it is pointless to override toString + * * @return Parsed version numbers */ public static String toStringStatic() { - return "major: " + JDK.getMajor() + - "\nminor: " + JDK.getMinor() + - "\nsubminor: " + JDK.getSubMinor() + - "\nupdate: " + JDK.getUpdate() + - "\nOK ==>" + JDK.ok(); + return "major: " + JDK.getMajor() + + "\nminor: " + JDK.getMinor() + + "\nsubminor: " + JDK.getSubMinor() + + "\nupdate: " + JDK.getUpdate() + + "\nOK ==>" + JDK.ok(); } static { @@ -300,23 +290,24 @@ public static String toStringStatic() { private static int subminor; private static int update; private static String vendor; - + // DO initialize these variables. You'll be sorry if you don't! - private final static int MAJOR = 0; - private final static int MINOR = 1; - private final static int SUBMINOR = 2; - private final static int UPDATE = 3; - + private final static int MAJOR_INDEX = 0; + private final static int MINOR_INDEX = 1; + private final static int SUBMINOR_INDEX = 2; + private final static int UPDATE_INDEX = 3; + // DO NOT initialize this variable. You'll again be sorry if you do! public static Version JDK_VERSION; + private static final String VERSION_MATCHER = "(\\d+(\\.\\d+)*)([_u\\-]+[\\S]+)*"; + private static void initialize() { - + // Silently fall back to ridiculous defaults if something is crazily wrong... major = 1; minor = subminor = update = 0; - - try { + String javaVersion = System.getProperty("java.version"); vendor = System.getProperty("java.vendor"); /*In JEP 223 java.specification.version will be a single number versioning , not a dotted versioning . So if we get a single @@ -327,77 +318,53 @@ private static void initialize() { For JDK 9: java.specification.version 9 java.version 9.1.2 - */ - String javaSpecificationVersion = System.getProperty("java.specification.version"); - - int[] versions = parseVersions(javaVersion, javaSpecificationVersion); - - major = versions[MAJOR]; - minor = versions[MINOR]; - subminor = versions[SUBMINOR]; - update = versions[UPDATE]; - } - catch(Exception e) { - // ignore -- use defaults - } - - JDK_VERSION = new Version(major, minor, subminor, update, vendor); + */ + int[] versions = parseVersions(javaVersion); + + major = versions[MAJOR_INDEX]; + minor = versions[MINOR_INDEX]; + subminor = versions[SUBMINOR_INDEX]; + update = versions[UPDATE_INDEX]; + + JDK_VERSION = new Version( + major, + minor, + subminor, + update, + vendor + ); } - - static int[] parseVersions(String jv, String javaSpecificationVersion) { - - int[] versions = {1, 0, 0, 0}; - - String[] jsvSplit = javaSpecificationVersion.split("\\."); - if (jsvSplit.length == 1) { - - // This is handle early access builds. For example "9-ea" - - String[] jvSplit = jv.split("-"); - String jvReal = jvSplit[0]; - String[] split = jvReal.split("[\\.]+"); - if (split.length > 0) { - if (split.length > 0) { - versions[MAJOR] = Integer.parseInt(split[0]); - } - if (split.length > 1) { - versions[MINOR] = Integer.parseInt(split[1]); - } - if (split.length > 2) { - versions[SUBMINOR] = Integer.parseInt(split[2]); - } - if (split.length > 3) { - versions[UPDATE] = Integer.parseInt(split[3]); - } - } - } else { - if (jv == null || jv.length() <= 0) { - return versions; // not likely!! - } + /** + * + * @param javaVersion the Java Version e.g 1.8.0u222, + * 1.8.0_232-ea-8u232-b09-0ubuntu1-b09, 11.0.5 + * @return + */ + static int[] parseVersions(String javaVersion) { - String[] ss = jv.split("\\."); + int[] versions = {1, 0, 0, 0}; + if (javaVersion == null || javaVersion.length() <= 0) { + return versions; // not likely!! + } + String[] javaVersionSplit = javaVersion.split("-"); + String[] split = javaVersionSplit[0].split("\\."); - if (ss.length < 3 || !ss[0].equals("1")) { - return versions; + if (split.length > 0) { + if (split.length > 0) { + versions[MAJOR_INDEX] = Short.parseShort(split[0]); } - - versions[MAJOR] = Integer.parseInt(ss[0]); - versions[MINOR] = Integer.parseInt(ss[1]); - - - ss = ss[2].split("_"); - if (ss.length < 1) { - return versions; + if (split.length > 1) { + versions[MINOR_INDEX] = Short.parseShort(split[1]); } - - versions[SUBMINOR] = Integer.parseInt(ss[0]); - - if (ss.length > 1) { - versions[UPDATE] = Integer.parseInt(ss[1]); + if (split.length > 2) { + split = split[2].split("[_u]"); + versions[SUBMINOR_INDEX] = Short.parseShort(split[0]); + if (split.length > 1) { + versions[UPDATE_INDEX] = Short.parseShort(split[1]); + } } } - return versions; } } diff --git a/plugins/org.eclipse.payara.tools/src/org/eclipse/payara/tools/sdk/server/ServerTasks.java b/plugins/org.eclipse.payara.tools/src/org/eclipse/payara/tools/sdk/server/ServerTasks.java index 01083ebf..17e76d27 100644 --- a/plugins/org.eclipse.payara.tools/src/org/eclipse/payara/tools/sdk/server/ServerTasks.java +++ b/plugins/org.eclipse.payara.tools/src/org/eclipse/payara/tools/sdk/server/ServerTasks.java @@ -37,6 +37,8 @@ import static org.eclipse.payara.tools.sdk.utils.ServerUtils.getJarName; import java.io.File; +import java.nio.file.Path; +import java.nio.file.Paths; import java.util.ArrayList; import java.util.Arrays; import java.util.HashMap; @@ -147,9 +149,10 @@ public static ResultProcess startServer(PayaraServer server, StartupArgs args, S if (!readXml(new File(domainXmlPath), jvmConfigReader)) { throw new PayaraIdeException(LOGGER.excMsg(METHOD, "readXMLerror"), domainXmlPath); } - - JDK.Version targetJDKVersion = JDK_VERSION != null ? JDK_VERSION : getJavaVersion(args); - + + JDK.Version jdkVersion = getJavaVersion(args); + JDK.Version targetJDKVersion = jdkVersion != null ? jdkVersion : JDK_VERSION; + // Filter out all options that are not applicable List optList = jvmConfigReader.getJvmOptions() @@ -157,8 +160,7 @@ public static ResultProcess startServer(PayaraServer server, StartupArgs args, S .filter(fullOption -> isCorrectJDK(targetJDKVersion, fullOption.vendor, fullOption.minVersion, fullOption.maxVersion)) .map(fullOption -> fullOption.option) .collect(toList()); - - + Map propMap = jvmConfigReader.getPropMap(); addJavaAgent(server, jvmConfigReader); @@ -228,17 +230,23 @@ public static ResultProcess startServer(PayaraServer server, StartupArgs args, S } private static JDK.Version getJavaVersion(StartupArgs args) { + String javaHome = System.getProperty("java.home"); + Path defaultPath = Paths.get(javaHome); + Path selectedPath = Paths.get(args.getJavaHome()); + + if (selectedPath.equals(defaultPath) + || (javaHome.endsWith("jre") && selectedPath.equals(defaultPath.getParent()))) { + System.out.println("same same " + defaultPath + selectedPath); + return JDK_VERSION; + } + String[] versions = JavaUtils.getJavaVersionString(args.getJavaHome()).split(":"); - JDK.Version targetJDKVersion; - - if (versions.length == 1) { - // Simple way, just using version string - targetJDKVersion = JDK.getVersion(versions[0]); - } else { - // More eleborate way using both version string and spec version - targetJDKVersion = JDK.getVersion(versions[0], versions[1], System.getProperty("java.vendor")); + JDK.Version targetJDKVersion = null; + + if (versions.length > 0) { + targetJDKVersion = JDK.getVersion(versions[0], System.getProperty("java.vendor")); } - + return targetJDKVersion; } diff --git a/plugins/org.eclipse.payara.tools/src/org/eclipse/payara/tools/sdk/server/parser/JvmConfigReader.java b/plugins/org.eclipse.payara.tools/src/org/eclipse/payara/tools/sdk/server/parser/JvmConfigReader.java index 86fdce60..eb873611 100644 --- a/plugins/org.eclipse.payara.tools/src/org/eclipse/payara/tools/sdk/server/parser/JvmConfigReader.java +++ b/plugins/org.eclipse.payara.tools/src/org/eclipse/payara/tools/sdk/server/parser/JvmConfigReader.java @@ -221,7 +221,8 @@ public static class JvmOption { public JvmOption(String option) { Matcher matcher = PATTERN.matcher(option); if (matcher.matches()) { - if (matcher.group(1).contains("-")) { + if (matcher.group(1).contains("-") + && Character.isLetter(matcher.group(1).charAt(0))) { String[] parts = matcher.group(1).split("-"); this.vendor = Optional.ofNullable(parts[0]); this.minVersion = Optional.ofNullable(JDK.getVersion(parts[1])); From 805c46d1bd600a344f5d40af22ce1be143eba0b0 Mon Sep 17 00:00:00 2001 From: Gaurav Gupta Date: Tue, 17 Dec 2019 13:24:44 +0530 Subject: [PATCH 2/2] ECOSYS-14 Unit test for JDK.Version --- plugins/org.eclipse.payara.tools/.classpath | 9 ++-- .../META-INF/MANIFEST.MF | 11 +++- .../eclipse/payara/tools/sdk/server/JDK.java | 10 ++-- .../payara/tools/sdk/server/JDKTest.java | 54 +++++++++++++++++++ 4 files changed, 74 insertions(+), 10 deletions(-) create mode 100644 plugins/org.eclipse.payara.tools/test/org/eclipse/payara/tools/sdk/server/JDKTest.java diff --git a/plugins/org.eclipse.payara.tools/.classpath b/plugins/org.eclipse.payara.tools/.classpath index eca7bdba..bbef1f79 100644 --- a/plugins/org.eclipse.payara.tools/.classpath +++ b/plugins/org.eclipse.payara.tools/.classpath @@ -1,7 +1,8 @@ - - - - + + + + + diff --git a/plugins/org.eclipse.payara.tools/META-INF/MANIFEST.MF b/plugins/org.eclipse.payara.tools/META-INF/MANIFEST.MF index 9dd0c1cd..42076e9d 100644 --- a/plugins/org.eclipse.payara.tools/META-INF/MANIFEST.MF +++ b/plugins/org.eclipse.payara.tools/META-INF/MANIFEST.MF @@ -34,7 +34,16 @@ Require-Bundle: org.apache.xerces, org.eclipse.jst.j2ee.core, org.eclipse.jst.server.generic.core, org.eclipse.sapphire.platform, - org.eclipse.jem.util + org.eclipse.jem.util, + org.junit, + org.junit.platform.commons, + org.junit.platform.engine, + org.junit.platform.launcher, + org.junit.platform.runner, + org.junit.platform.suite.api, + org.hamcrest.core, + org.opentest4j, + org.apiguardian Bundle-ActivationPolicy: lazy Export-Package: org.eclipse.payara.tools; uses:="org.eclipse.debug.core, diff --git a/plugins/org.eclipse.payara.tools/src/org/eclipse/payara/tools/sdk/server/JDK.java b/plugins/org.eclipse.payara.tools/src/org/eclipse/payara/tools/sdk/server/JDK.java index 6fb59dc6..e8bc92de 100644 --- a/plugins/org.eclipse.payara.tools/src/org/eclipse/payara/tools/sdk/server/JDK.java +++ b/plugins/org.eclipse.payara.tools/src/org/eclipse/payara/tools/sdk/server/JDK.java @@ -87,12 +87,12 @@ private Version(String version, String vendor) { this.vendor = Optional.ofNullable(vendor); } - private Version(int major, int minor, int subminor, int update, String vendor) { + Version(int major, int minor, int subminor, int update, String vendor) { this.major = major; - this.minor = Optional.of(minor); - this.subminor = Optional.of(subminor); - this.update = Optional.of(update); - this.vendor = Optional.of(vendor); + this.minor = Optional.ofNullable(minor); + this.subminor = Optional.ofNullable(subminor); + this.update = Optional.ofNullable(update); + this.vendor = Optional.ofNullable(vendor); } public boolean newerThan(Version version) { diff --git a/plugins/org.eclipse.payara.tools/test/org/eclipse/payara/tools/sdk/server/JDKTest.java b/plugins/org.eclipse.payara.tools/test/org/eclipse/payara/tools/sdk/server/JDKTest.java new file mode 100644 index 00000000..6b1c4196 --- /dev/null +++ b/plugins/org.eclipse.payara.tools/test/org/eclipse/payara/tools/sdk/server/JDKTest.java @@ -0,0 +1,54 @@ +/** **************************************************************************** + * Copyright (c) 2019 Payara Foundation + * All rights reserved. This program and the accompanying materials + * are made available under the terms of the Eclipse Public License v2.0 + * which accompanies this distribution, and is available at + * http://www.eclipse.org/legal/epl-v20.html + * SPDX-License-Identifier: EPL-2.0 + ***************************************************************************** */ +package org.eclipse.payara.tools.sdk.server; + +import java.util.HashMap; +import java.util.Map; +import java.util.Map.Entry; +import static org.junit.Assert.assertTrue; +import org.junit.Test; + + +/** + * Common JDK version functional test. + *

+ * @author Gaurav Gupta + */ +public class JDKTest { + + /** + * Test to parse the JDK.Version. + */ + @Test + public void parseJDKVersion() { + Map jdkVersions = new HashMap<>(); + jdkVersions.put("1.8", + new JDK.Version( 1, 8, 0, 0, null)); + jdkVersions.put("1.8.0", + new JDK.Version( 1, 8, 0, 0, null)); + jdkVersions.put("1.8.0u121", + new JDK.Version( 1, 8, 0, 121, null)); + jdkVersions.put("1.8.0_191", + new JDK.Version( 1, 8, 0, 191, null)); + jdkVersions.put("1.8.0_232-ea-8u232-b09-0ubuntu1-b09", + new JDK.Version( 1, 8, 0, 232, null)); + jdkVersions.put("9", + new JDK.Version( 9, 0, 0, 0, null)); + jdkVersions.put("11.0.6", + new JDK.Version( 11, 0, 6, 0, null)); + jdkVersions.put("11.0.6_234", + new JDK.Version( 11, 0, 6, 234, null)); + jdkVersions.put("11.0.6u234", + new JDK.Version( 11, 0, 6, 234, null)); + + for (Entry version : jdkVersions.entrySet()) { + assertTrue(version.getKey(), JDK.getVersion(version.getKey()).equals(version.getValue())); + } + } +}