From bd27bb9cbedebd09f589679947ff32261f9ef352 Mon Sep 17 00:00:00 2001 From: Igor Ignatyev Date: Thu, 12 Aug 2021 03:45:44 +0000 Subject: [PATCH] 8272345: macos doesn't check `os::set_boot_path()` result Reviewed-by: dholmes --- src/hotspot/os/bsd/os_bsd.cpp | 4 +++- .../hotspot/jtreg/runtime/cds/appcds/MoveJDKTest.java | 11 +++++------ 2 files changed, 8 insertions(+), 7 deletions(-) diff --git a/src/hotspot/os/bsd/os_bsd.cpp b/src/hotspot/os/bsd/os_bsd.cpp index 900fedc1f78..2c0ecd0fe6b 100644 --- a/src/hotspot/os/bsd/os_bsd.cpp +++ b/src/hotspot/os/bsd/os_bsd.cpp @@ -452,7 +452,9 @@ void os::init_system_properties_values() { } } Arguments::set_java_home(buf); - set_boot_path('/', ':'); + if (!set_boot_path('/', ':')) { + vm_exit_during_initialization("Failed setting boot class path.", NULL); + } } // Where to look for native libraries. diff --git a/test/hotspot/jtreg/runtime/cds/appcds/MoveJDKTest.java b/test/hotspot/jtreg/runtime/cds/appcds/MoveJDKTest.java index c5cc952f0d5..ba8acf0c970 100644 --- a/test/hotspot/jtreg/runtime/cds/appcds/MoveJDKTest.java +++ b/test/hotspot/jtreg/runtime/cds/appcds/MoveJDKTest.java @@ -25,17 +25,15 @@ /* * @test * @summary Test that CDS still works when the JDK is moved to a new directory + * @bug 8272345 * @requires vm.cds - * @requires os.family == "linux" + * @comment This test doesn't work on Windows because it depends on symlinks + * @requires os.family != "windows" * @library /test/lib * @compile test-classes/Hello.java * @run driver MoveJDKTest */ -// This test works only on Linux because it depends on symlinks and the name of the hotspot DLL (libjvm.so). -// It probably doesn't work on Windows. -// TODO: change libjvm.so to libjvm.dylib on MacOS, before adding "@requires os.family == mac" - import java.io.File; import java.nio.file.Files; import java.nio.file.Path; @@ -134,6 +132,7 @@ public class MoveJDKTest { throw new RuntimeException("Cannot create directory: " + dst); } } + final String jvmLib = System.mapLibraryName("jvm"); for (String child : src.list()) { if (child.equals(".") || child.equals("..")) { continue; @@ -145,7 +144,7 @@ public class MoveJDKTest { throw new RuntimeException("Already exists: " + child_dst); } if (child_src.isFile()) { - if (child.equals("libjvm.so") || child.equals("java")) { + if (child.equals(jvmLib) || child.equals("java")) { Files.copy(child_src.toPath(), /* copy data to -> */ child_dst.toPath()); } else { Files.createSymbolicLink(child_dst.toPath(), /* link to -> */ child_src.toPath());