From f61a078bd2ac6da99df7e850a149edfcd5392e71 Mon Sep 17 00:00:00 2001 From: Brent Christian Date: Wed, 17 Jan 2018 16:15:15 -0800 Subject: [PATCH] 8194879: Runtime.Version parses string which does not conform to spec without throwing IAE Reviewed-by: alanb, iris, rriggs --- .../share/classes/java/lang/Runtime.java | 27 ++++++++++++------- test/jdk/java/lang/Runtime/Version/Basic.java | 5 ++-- 2 files changed, 20 insertions(+), 12 deletions(-) diff --git a/src/java.base/share/classes/java/lang/Runtime.java b/src/java.base/share/classes/java/lang/Runtime.java index d09c1a28b93..c2bb813ed5c 100644 --- a/src/java.base/share/classes/java/lang/Runtime.java +++ b/src/java.base/share/classes/java/lang/Runtime.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1995, 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1995, 2018, 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 @@ -1099,16 +1099,23 @@ public class Runtime { m.group(VersionPattern.OPT_GROUP)); // empty '+' - if ((m.group(VersionPattern.PLUS_GROUP) != null) - && !build.isPresent()) { - if (optional.isPresent()) { - if (pre.isPresent()) - throw new IllegalArgumentException("'+' found with" - + " pre-release and optional components:'" + s - + "'"); + if (!build.isPresent()) { + if (m.group(VersionPattern.PLUS_GROUP) != null) { + if (optional.isPresent()) { + if (pre.isPresent()) + throw new IllegalArgumentException("'+' found with" + + " pre-release and optional components:'" + s + + "'"); + } else { + throw new IllegalArgumentException("'+' found with neither" + + " build or optional components: '" + s + "'"); + } } else { - throw new IllegalArgumentException("'+' found with neither" - + " build or optional components: '" + s + "'"); + if (optional.isPresent() && !pre.isPresent()) { + throw new IllegalArgumentException("optional component" + + " must be preceeded by a pre-release component" + + " or '+': '" + s + "'"); + } } } return new Version(List.of(version), pre, build, optional); diff --git a/test/jdk/java/lang/Runtime/Version/Basic.java b/test/jdk/java/lang/Runtime/Version/Basic.java index 26c4c6df6f1..2389f0cbc3d 100644 --- a/test/jdk/java/lang/Runtime/Version/Basic.java +++ b/test/jdk/java/lang/Runtime/Version/Basic.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2018, 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 @@ -24,7 +24,7 @@ /* * @test * @summary Unit test for java.lang.Runtime.Version - * @bug 8072379 8144062 8161236 8160956 + * @bug 8072379 8144062 8161236 8160956 8194879 */ import java.lang.Runtime.Version; @@ -115,6 +115,7 @@ public class Basic { tryCatch("9-pre+-opt", IAE); tryCatch("1.4142+-", IAE); tryCatch("2.9979+-%", IAE); + tryCatch("10--ea", IAE); //// Test for Runtime.version() testVersion();