RFR: JDK-8238225: Issues reported after replacing symlink at Contents/MacOS/libjli.dylib with binary
Erik Joelsson
erik.joelsson at oracle.com
Tue Feb 4 17:45:26 UTC 2020
Does anyone have an opinion on this?
/Erik
On 2020-01-31 07:31, Erik Joelsson wrote:
> In JDK-8235687 the MacOS bundle distribution of the JDK was changed to
> conform to Apple requirements by changing Contents/MacOS/libjli.dylib
> from a symlink into ../Home/lib/libjli.dylib to a copy of that file.
> The problem with having a symlink there is that
> Contents/MacOS/libjli.dylib is the declared CFBundleExecutable of the
> bundle and that executable may not be a symlink. The history around
> why that particular library was put there seems lost in ancient
> history. All we know is that it was there when Apple donated the Mac
> port and according to this bug report, there are users out there
> relying on it.
>
> When changing Contents/MacOS/libjli.dylib to a copy, loading that
> dylib and using it to launch a JVM no longer works. This patch fixes
> that by making libjli.dylib aware of potentially being located there
> and if so, finding the JDK home dir in ../Home.
>
> I've also expanded the existing test for launching a JVM through
> libjli.dylib directly to also test this location when possible. In
> local testing, this will not be covered unless the user explicitly
> specifies that the JDK under test should be the bundle image on the
> command line like this:
>
> $ make test-only TEST=open/test/jdk/tools/launcher/JliLaunchTest.java
> JDK_IMAGE_DIR=$PWD/build/macosx-x64/images/jdk-bundle/jdk-15.jdk/Contents/Home
>
> But, at least in Oracle's distributed testing, the JDK on MacOS is
> distributed in the bundle layout, so there this functionality will be
> tested.
>
> Bug: https://bugs.openjdk.java.net/browse/JDK-8238225
>
> Webrev: http://cr.openjdk.java.net/~erikj/8238225/webrev.01/
>
> /Erik
>
More information about the build-dev
mailing list