Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

8311302: Implement JEP 493: Linking Run-Time Images without JMODs #14787

Closed
wants to merge 188 commits into from
Closed
Changes from 6 commits
Commits
Show all changes
188 commits
Select commit Hold shift + click to select a range
ed47623
8311302: Allow for jlinking a custom runtime without packaged modules…
jerboaa Mar 6, 2023
baeaaf5
Use 'run-image' as the term shown with --verbose
jerboaa Aug 8, 2023
2479726
Exit the jlink on modified files by default
jerboaa Aug 9, 2023
738b8a3
Implementation for run-image link and single-hop
jerboaa Aug 10, 2023
518e1d2
Merge branch 'master' into jdk-8311302-jmodless-link
jerboaa Oct 3, 2023
4d471e0
Fix tests after merge
jerboaa Oct 3, 2023
2e73e30
Work-around JDK-8317609 (jdk.jcmd module doesn't verify)
jerboaa Oct 5, 2023
d4126fb
Merge branch 'master' into jdk-8311302-jmodless-link
jerboaa Oct 16, 2023
80d76ad
JmodLessArchive => RunImageArchive rename
jerboaa Oct 16, 2023
c0bd98f
Use a single option --unlock-run-image for single hop and warnings
jerboaa Oct 16, 2023
ef1bca8
Improve error message of run-image recursive link
jerboaa Oct 16, 2023
b6a9fac
--add-jmod-resources => --add-run-image-resources rename
jerboaa Oct 17, 2023
d0a60b6
AddJmodResourcesPlugin => AddRunImageResourcesPlugin rename
jerboaa Oct 17, 2023
abbff09
Add hint to the modified file case
jerboaa Oct 17, 2023
b82efb0
Add a message when a run-image based link is being performed
jerboaa Oct 18, 2023
fea34e3
Merge branch 'master' into jdk-8311302-jmodless-link
jerboaa Nov 13, 2023
6849fd7
Rename resource file to jdk_internal_runimage
jerboaa Nov 14, 2023
b228ba6
Don't show --add-run-image-resources plugin in listing
jerboaa Nov 14, 2023
101033d
Remove 'Please double check!' phrase.
jerboaa Nov 14, 2023
ac01194
First pass at 'run-image' => 'run-time image'
jerboaa Nov 14, 2023
eacb0bb
Use internal package name for run-image resources
jerboaa Nov 20, 2023
4c10db2
Fix some comments in GenerateJLIClassesPlugin
jerboaa Nov 21, 2023
319d400
Mark --unlock-run-image as a hidden option
jerboaa Nov 21, 2023
3c04539
Update some comments
jerboaa Nov 21, 2023
c6d69ea
Fix GenerateJLIClassesPlugin in run-time link mode
jerboaa Nov 22, 2023
c24cd58
Fix SystemModulesPlugin in run-time link mode
jerboaa Nov 23, 2023
5595ab4
Remove work-arounds for AddOptions and SaveJlinkArgfiles Plugins
jerboaa Nov 23, 2023
d2ef41a
Fix corner case of system modules not consistently being enabled
jerboaa Nov 23, 2023
ac15bf2
Add a proper test for generate-jli-classes in run-image based link mode
jerboaa Nov 23, 2023
3539c6a
Typo fix.
jerboaa Nov 23, 2023
f1130d1
Tighten ModifiedFilesExitTest
jerboaa Nov 24, 2023
bd6fa28
Address some review feedback
jerboaa Nov 29, 2023
24736e5
Move exclude pattern to plugins
jerboaa Nov 30, 2023
64c7f77
Initial work to track base image link and plugin options
jerboaa Nov 30, 2023
0df27fd
Add runTimeImageLinkPersistent() API to Plugin interface
jerboaa Dec 4, 2023
85f0454
Use merged CLI args to persist
jerboaa Dec 4, 2023
823f150
Rename AddRunImageResourcesPlugin => JlinkResourcesListPlugin
jerboaa Dec 4, 2023
41aa46f
First round of addressing review feedback.
jerboaa Dec 4, 2023
9b069db
Rename RunImageArchive => JRTArchive and RunImageLinkException => Run…
jerboaa Dec 5, 2023
4d9dc95
Localize messages, switch expression
jerboaa Dec 5, 2023
b443ac8
Remove the hidden option hint.
jerboaa Dec 5, 2023
7f02400
Use '_files' over '_resources' as the suffix for listing resources
jerboaa Dec 5, 2023
3745cb8
Don't show the verbose hint when already verbose
jerboaa Dec 5, 2023
e2a9fa7
Merge branch 'master' into jdk-8311302-jmodless-link
jerboaa Dec 5, 2023
da69aa9
Fix SystemModulesPlugin after merge
jerboaa Dec 5, 2023
a797ea6
Add @enablePreview for JImageValidator that uses classfile API
jerboaa Dec 5, 2023
b21585b
Only check for existing path when not a scratch task
jerboaa Dec 11, 2023
821857a
Disallow packaged modules and run-time image link
jerboaa Dec 11, 2023
d0e3e78
The constants such as the pathname of the timestamp file and the inte…
mlchung Dec 16, 2023
1acc326
Fix IntegrationTest (no runtime image link)
jerboaa Jan 17, 2024
266a9a0
Remove --unlock-run-image from jlink.properties
jerboaa Jan 17, 2024
835353e
Rename '--unlock-run-image' to '--ignore-modified-runtime'
jerboaa Jan 17, 2024
eeadbb9
Merge branch 'master' into jdk-8311302-jmodless-link
jerboaa Jan 22, 2024
e970817
Always add the runtime image stamp file
jerboaa Jan 23, 2024
9635ba5
Add some details for run-time link
jerboaa Jan 23, 2024
1e69bc9
Rename singleHop field.
jerboaa Jan 23, 2024
bcfc2c8
Some cleanup
jerboaa Feb 19, 2024
e355cd3
First working version of new design
jerboaa Feb 19, 2024
0627d18
Add jimage diff generator tool
jerboaa Feb 20, 2024
f5c2199
Initial work on build setup for run-time link image
jerboaa Feb 20, 2024
382097d
Duplicate ResourceDiff class for now
jerboaa Feb 20, 2024
0c4c58a
Fixes for full build workflow
jerboaa Feb 20, 2024
9ad7302
Merge branch 'master' into jdk-8311302-jmodless-link-new-approach
jerboaa Feb 21, 2024
f56a314
Some sanity checks and clean-ups from the earlier design
jerboaa Feb 21, 2024
b557b02
--enable-runtime-link-image now replaces default jdk image
jerboaa Feb 22, 2024
6a4875f
Initial work for tests
jerboaa Feb 22, 2024
1965590
Add copyright headers
jerboaa Feb 22, 2024
fe57677
Fix runtime link tests
jerboaa Feb 22, 2024
48a3577
Add verification step that runtime link is being performed
jerboaa Feb 26, 2024
e0484eb
Add support for custom modules via the module path
jerboaa Feb 26, 2024
cd47f3d
Update copyright year.
jerboaa Feb 26, 2024
00caf77
Merge branch 'master' into jdk-8311302-jmodless-link
jerboaa Feb 26, 2024
b034cce
Only show runtime image suffix for JDK modules
jerboaa Feb 27, 2024
7449638
Move to build-only jlink plugin approach
jerboaa Mar 12, 2024
77c3f3c
Merge branch 'master' into jdk-8311302-jmodless-link
jerboaa Mar 14, 2024
d01eba4
Remove unneded export
jerboaa Mar 14, 2024
2a29e67
Further reduce exports
jerboaa Mar 14, 2024
9227358
Remove extraneous empty line
jerboaa Mar 14, 2024
5fda7f0
Fix comment
jerboaa Mar 14, 2024
8127957
Remove extraneous comment
jerboaa Mar 14, 2024
21ef16d
Ensure build-only plugin isn't propagated to the final image
jerboaa Mar 14, 2024
b7e5d82
Add copyright header/comments
jerboaa Mar 14, 2024
bbc4f84
Update some comments
jerboaa Mar 14, 2024
0d94b51
Restore GenerateJLIClassesPluginTest.java
jerboaa Mar 14, 2024
5404d4e
Remove no longer needed plugin options
jerboaa Mar 14, 2024
1fe6161
Fix comment in autoconf file
jerboaa Mar 14, 2024
760aae3
Review feedback and Windows build fix (FixPath)
jerboaa Mar 15, 2024
2ea9cab
Fix comment.
jerboaa Mar 15, 2024
29b2e55
Merge branch 'master' into jdk-8311302-jmodless-link
jerboaa Mar 18, 2024
e25dd44
Fix race wrt. first and second image generation.
jerboaa Mar 18, 2024
5a6d2e4
Move CreateLinkableRuntimePlugin to build folder
jerboaa Mar 19, 2024
744cad0
Fix copyright year
jerboaa Mar 19, 2024
8bf9c06
Merge branch 'master' into jdk-8311302-jmodless-link
jerboaa Apr 2, 2024
918bf1c
Make generation of fs_$module_files unconditional
jerboaa Apr 2, 2024
f752fdf
Update to new build-time approach with delta in lib
jerboaa Apr 3, 2024
4d76f7c
Follow build tools naming convention
jerboaa Apr 4, 2024
38d5b31
Revert some now unneded build changes
jerboaa Apr 4, 2024
fcac9fc
Fix typo
jerboaa Apr 4, 2024
46ba5ff
Fix comment
jerboaa Apr 4, 2024
ce04f42
Fix coment
jerboaa Apr 4, 2024
186e451
Remove dependency on CDS which isn't needed anymore
jerboaa Apr 4, 2024
1004a38
Review feedback from Erik J.
jerboaa Apr 4, 2024
84d4fef
Use shorter name for the build tool
jerboaa Apr 4, 2024
2c41d54
Merge branch 'master' into jdk-8311302-jmodless-link
jerboaa May 7, 2024
67aea4c
Generate the runtime image link diff at jlink time
jerboaa May 7, 2024
ab2a7aa
Only add runtime track files for linkable runtimes
jerboaa May 15, 2024
be30a18
Simplify JLINK_JDK_EXTRA_OPTS var handling
jerboaa May 15, 2024
8cca277
Merge branch 'master' into jdk-8311302-jmodless-link
jerboaa May 15, 2024
6fe8b8a
Fix new line in jlink.properties
jerboaa May 22, 2024
e1e3f02
Merge branch 'master' into jdk-8311302-jmodless-link
jerboaa May 22, 2024
84abe2b
Merge branch 'master' into jdk-8311302-jmodless-link
jerboaa Jun 4, 2024
5fef297
Correctly set packaged modules default
jerboaa Jun 4, 2024
0eb1e48
Mark some tests with requiring packaged modules
jerboaa Jun 4, 2024
36e9b04
Rename JLINK_PRODUCE_RUNTIME_LINK_JDK to JLINK_PRODUCE_LINKABLE_RUNTIME
jerboaa Jun 5, 2024
b3147ff
Use pattern matching for instanceof in JRTArchive::equals
jerboaa Jun 5, 2024
c7da0f9
Fix comment. Stream.toList()
jerboaa Jun 5, 2024
2b96a05
Remove printStackTrace()
jerboaa Jun 5, 2024
0e5ffff
Update wording on multi-hop.
jerboaa Jun 5, 2024
b72648b
Move JImageHelper
jerboaa Jun 5, 2024
7a8f839
Fix default description of keep-packaged-modules
jerboaa Jun 6, 2024
724b86e
Merge branch 'master' into jdk-8311302-jmodless-link
jerboaa Jun 20, 2024
6023507
Rename configure option to '--enable-linkable-runtime'
jerboaa Jun 20, 2024
3ce8cf1
Formatting and some cleanup.
jerboaa Jun 20, 2024
63be8fd
Documentation and formatting clean-up in ImageFileCreator
jerboaa Jun 20, 2024
823cba0
Cleanup and doc for JlinkTask
jerboaa Jun 21, 2024
8bc23c3
Add test for --keep-packaged-modules (should be negative)
jerboaa Jun 21, 2024
e784e99
Fixup for JlinkTask
jerboaa Jun 21, 2024
2a379ab
Test clean-up. class-file API module.
jerboaa Jun 21, 2024
ac06785
Helper support for linkable JDK runtimes
jerboaa Jun 21, 2024
a90d28d
Comments and clean-up in JlinkTask
jerboaa Jun 21, 2024
39c45ba
Comment fixes in ImageFileCreator
jerboaa Jun 21, 2024
a3df5a7
Comment fix in JRTArchive. Long line in JlinkTask
jerboaa Jun 21, 2024
5a8db44
Remove restriction on directory based modules
jerboaa Jun 21, 2024
9accb1b
Enable JLinkReproducibleTest.java for linkable JDK images
jerboaa Jun 21, 2024
16dde3d
Enable GenerateJLIClassesPluginTest.java test
jerboaa Jun 24, 2024
2c9568d
Enable IncludeLocalesPluginTest
jerboaa Jun 24, 2024
04cd98f
JLinkDedupTestBatchSizeOne.java test fix
jerboaa Jun 24, 2024
59a3924
Merge branch 'master' into jdk-8311302-jmodless-link
jerboaa Jul 16, 2024
7e2bc4e
Merge branch 'master' into jdk-8311302-jmodless-link
jerboaa Aug 20, 2024
5999787
Merge branch 'master' into jdk-8311302-jmodless-link
jerboaa Aug 27, 2024
ec68b0a
Merge branch 'master' into jdk-8311302-jmodless-link
jerboaa Sep 3, 2024
4f06579
Merge branch 'master' into jdk-8311302-jmodless-link
jerboaa Sep 16, 2024
182c4aa
Update error message when linking jdk.jlink
jerboaa Sep 16, 2024
4a50b4c
Merge branch 'master' into jdk-8311302-jmodless-link
jerboaa Oct 15, 2024
6859a3b
Only show info message about runtime link when verbose
jerboaa Oct 15, 2024
22eb4b8
Merge branch 'master' into jdk-8311302-jmodless-link
jerboaa Oct 22, 2024
f3f1a65
Show run-time image based capability in help
jerboaa Oct 22, 2024
b4842cf
Fix provider verification when some JMODs are present
jerboaa Oct 24, 2024
ce32b2b
Fix tests for builds with --enable-linable-runtime
jerboaa Oct 25, 2024
d8e1e83
Add /othervm to some langtools tier1 tests
jerboaa Oct 25, 2024
83a86d0
Better handle patched modules
jerboaa Oct 25, 2024
015fe36
Mandy's review feedback
jerboaa Oct 29, 2024
32e28e4
Remove pre-existing unused functions in ImageFileCreator
jerboaa Oct 29, 2024
ee7aaca
Fix wording in error messages
jerboaa Oct 29, 2024
fd28347
Add javadoc in JimageDiffGenerator
jerboaa Oct 29, 2024
3baafe9
Feedback from Erik Joelsson
jerboaa Oct 29, 2024
f7a2685
Remove period
jerboaa Oct 30, 2024
2bd028d
Comment clean-up in ImageFileCreator
jerboaa Oct 30, 2024
e8b8a44
More updates to the wording
jerboaa Oct 30, 2024
c767077
More cleanup of wording (tests)
jerboaa Oct 30, 2024
575ae97
More wording updates
jerboaa Oct 30, 2024
bb8dc39
Some more wording updates
jerboaa Oct 30, 2024
bfe0745
Fix description of configure option
jerboaa Oct 30, 2024
1cca01a
More comment fix-ups (JRTArchive)
jerboaa Oct 30, 2024
bdb6eda
Move some comments around
jerboaa Oct 30, 2024
5e40a30
More comment fixes (JlinkTask)
jerboaa Oct 30, 2024
fa48eca
Remove ImageReader (like JmodsReader)
jerboaa Oct 30, 2024
e41daec
Fix comment in RuntimeImageLinkException
jerboaa Oct 30, 2024
8688fcf
Revert changes to ResourcePoolEntry
jerboaa Oct 30, 2024
fc8d821
Remove period in jlink.properties
jerboaa Oct 30, 2024
e6b3aeb
Some test fixes
jerboaa Oct 30, 2024
b702ba8
Merge branch 'master' into jdk-8311302-jmodless-link
jerboaa Oct 31, 2024
fe0969a
Mandy's feedback
jerboaa Nov 4, 2024
131e49a
Refactor tests so that they run for default build
jerboaa Nov 5, 2024
40c9213
Rename JmodLess => runtimeImage
jerboaa Nov 5, 2024
40a3f7e
Rename PackagedModulesVsJmodLessTest => PackagedModulesVsRuntimeImage…
jerboaa Nov 5, 2024
96443be
Fix SystemModulesTest2 when linkable runtime but no packaged modules
jerboaa Nov 5, 2024
ec04850
Fix comment
jerboaa Nov 5, 2024
fdd0571
Make capability in --help human readable
jerboaa Nov 6, 2024
e83b958
Merge branch 'master' into jdk-8311302-jmodless-link
jerboaa Nov 6, 2024
0a73d94
Simplify runtimeImage tests
jerboaa Nov 7, 2024
9801924
Fix plugins/GenerateJLIClassesPluginTest.java test
jerboaa Nov 7, 2024
3bcc50a
Fix plugins/IncludeLocalesPluginTest.java
jerboaa Nov 7, 2024
714fb70
Fix JLinkDedupTestBatchSizeOne.java
jerboaa Nov 7, 2024
d2c011e
Remove "jlink.runtime.linkable" property from VMProps
jerboaa Nov 7, 2024
f55bb85
Mandy's feedback
jerboaa Nov 7, 2024
0bf4843
Remove unused imports from VMProps
jerboaa Nov 8, 2024
2042fc3
Update copyright headers
jerboaa Nov 8, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -127,9 +127,6 @@ public Stream<Entry> entries() {
collectFiles();
} catch (IOException e) {
throw new UncheckedIOException(e);
} catch (RuntimeImageLinkException e) {
// populate modified files exception
throw e;
}
return files.stream().map(JRTFile::toEntry);
}
Original file line number Diff line number Diff line change
@@ -25,6 +25,8 @@

package jdk.tools.jlink.internal.runtimelink;

import java.util.Objects;

/**
* Exception thrown when linking from the run-time image
*/
@@ -41,8 +43,8 @@ public static enum Reason {
private final Reason reason;

public RuntimeImageLinkException(String file, Reason reason) {
this.file = file;
this.reason = reason;
this.file = Objects.requireNonNull(file);
this.reason = Objects.requireNonNull(reason);
}

public String getFile() {
Original file line number Diff line number Diff line change
@@ -123,7 +123,7 @@ err.runtime.link.not.linkable.runtime=This JDK does not support linking from the
err.runtime.link.jdk.jlink.prohibited=This JDK does not contain packaged modules\
\ and cannot be used to create another image with the jdk.jlink module
err.runtime.link.packaged.mods=This JDK has no packaged modules.\
\ --keep-packaged-modules is not supported.
\ --keep-packaged-modules is not supported
err.runtime.link.modified.file={0} has been modified
err.runtime.link.patched.module=File {0} not found in the modules image.\
\ --patch-module is not supported when linking from the run-time image
33 changes: 6 additions & 27 deletions test/jdk/tools/jlink/JLinkDedupTestBatchSizeOne.java
Original file line number Diff line number Diff line change
@@ -27,29 +27,12 @@
import java.nio.file.Paths;

import jdk.test.lib.compiler.CompilerUtils;
import jdk.tools.jlink.internal.LinkableRuntimeImage;
import tests.JImageGenerator;

/*
* @test id=packaged_modules
* @summary Make sure that modules can be linked using jlink
* and deduplication works correctly when creating sub methods
* @bug 8311591
* @library /test/lib
* ../lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
* jdk.jlink/jdk.tools.jlink.internal
* jdk.jlink/jdk.tools.jlink.plugin
* jdk.jlink/jdk.tools.jmod
* jdk.jlink/jdk.tools.jimage
* jdk.compiler
* @build tests.* JLinkDedupTestBatchSizeOne jdk.test.lib.compiler.CompilerUtils
* @requires jlink.packagedModules
* @run main/othervm -Xmx1g -Xlog:init=debug -XX:+UnlockDiagnosticVMOptions -XX:+BytecodeVerificationLocal JLinkDedupTestBatchSizeOne false
*/

/*
* @test id=linkable_jdk_runtimes
* @test
* @summary Make sure that modules can be linked using jlink
* and deduplication works correctly when creating sub methods
* @bug 8311591
@@ -62,9 +45,8 @@
* jdk.jlink/jdk.tools.jmod
* jdk.jlink/jdk.tools.jimage
* jdk.compiler
* @requires (jlink.runtime.linkable & !jlink.packagedModules)
* @build tests.* JLinkDedupTestBatchSizeOne jdk.test.lib.compiler.CompilerUtils
* @run main/othervm -Xmx1g -Xlog:init=debug -XX:+UnlockDiagnosticVMOptions -XX:+BytecodeVerificationLocal JLinkDedupTestBatchSizeOne true
* @run main/othervm -Xmx1g -Xlog:init=debug -XX:+UnlockDiagnosticVMOptions -XX:+BytecodeVerificationLocal JLinkDedupTestBatchSizeOne
*/
public class JLinkDedupTestBatchSizeOne {

@@ -101,13 +83,10 @@ public static void compileAll(boolean linkableRuntime) throws Throwable {
}

public static void main(String[] args) throws Throwable {
if (args.length != 1) {
throw new AssertionError("Wrong number of arguments for the test!");
}
boolean linkableRuntime = Boolean.parseBoolean(args[0]);
boolean linkableRuntime = LinkableRuntimeImage.isLinkableRuntime();
System.out.println("Running test on " +
(linkableRuntime ? "a linkable JDK runtime" :
"packaged modules") + ".");
(linkableRuntime ? "enabled" : "disabled") +
" capability of linking from the run-time image.");
compileAll(linkableRuntime);
Path image = Paths.get("bug8311591");

18 changes: 7 additions & 11 deletions test/jdk/tools/jlink/JLinkHelpCapabilityTest.java
Original file line number Diff line number Diff line change
@@ -25,18 +25,14 @@
import java.io.StringWriter;
import java.util.spi.ToolProvider;

/*
* @test id=run-time-image-cap-yes
* @summary Test jlink --help for capability output (true)
* @requires (vm.compMode != "Xcomp" & jlink.runtime.linkable)
* @run main/othervm -Duser.language=en JLinkHelpCapabilityTest true
*/
import jdk.tools.jlink.internal.LinkableRuntimeImage;

/*
* @test id=run-time-image-cap-no
* @summary Test jlink --help for capability output (false)
* @requires (vm.compMode != "Xcomp" & !jlink.runtime.linkable)
* @run main/othervm -Duser.language=en JLinkHelpCapabilityTest false
* @test
* @summary Test jlink --help for capability output
* @modules jdk.jlink/jdk.tools.jlink.internal
* @requires vm.compMode != "Xcomp"
* @run main/othervm -Duser.language=en JLinkHelpCapabilityTest
*/
public class JLinkHelpCapabilityTest {
static final ToolProvider JLINK_TOOL = ToolProvider.findFirst("jlink")
@@ -45,7 +41,7 @@ public class JLinkHelpCapabilityTest {
);

public static void main(String[] args) throws Exception {
boolean runtimeLinkCap = Boolean.parseBoolean(args[0]);
boolean runtimeLinkCap = LinkableRuntimeImage.isLinkableRuntime();
String capabilities = String.format("Linking from run-time image %s",
runtimeLinkCap ? "enabled" : "disabled");
{
40 changes: 13 additions & 27 deletions test/jdk/tools/jlink/plugins/GenerateJLIClassesPluginTest.java
Original file line number Diff line number Diff line change
@@ -38,29 +38,15 @@
import org.testng.annotations.BeforeTest;
import org.testng.annotations.Test;

import jdk.tools.jlink.internal.LinkableRuntimeImage;
import tests.Helper;
import tests.JImageGenerator;
import tests.JImageValidator;
import tests.Result;

/*
* @test id=packaged_modules
* @bug 8252919 8327499
* @library ../../lib
* @summary Test --generate-jli-classes plugin
* @enablePreview
* @modules java.base/jdk.internal.jimage
* jdk.jlink/jdk.tools.jlink.internal
* jdk.jlink/jdk.tools.jlink.internal.plugins
* jdk.jlink/jdk.tools.jmod
* jdk.jlink/jdk.tools.jimage
* @requires jlink.packagedModules
* @build tests.*
* @run testng/othervm -DlinkableRuntime=false GenerateJLIClassesPluginTest
*/

/*
* @test id=linkable_jdk_runtimes
* @test
* @bug 8252919 8327499
* @library ../../lib
* @summary Test --generate-jli-classes plugin
@@ -70,26 +56,29 @@
* jdk.jlink/jdk.tools.jlink.internal.plugins
* jdk.jlink/jdk.tools.jmod
* jdk.jlink/jdk.tools.jimage
* @requires (jlink.runtime.linkable & !jlink.packagedModules)
* @build tests.*
* @run testng/othervm -DlinkableRuntime=true GenerateJLIClassesPluginTest
* @run testng/othervm GenerateJLIClassesPluginTest
*/
public class GenerateJLIClassesPluginTest {

private static final String LINKABLE_RUNTIME_PROP = "linkableRuntime";
private static Helper helper;

@BeforeTest
public static void setup() throws Exception {
boolean isLinkableRuntime = Boolean.getBoolean(LINKABLE_RUNTIME_PROP);
System.out.println("Tests run on " +
(isLinkableRuntime ? "linkable JDK runtime." : "packaged modules."));
boolean isLinkableRuntime = LinkableRuntimeImage.isLinkableRuntime();
System.out.println("DEBUG: Tests run on " +
(isLinkableRuntime ? "enabled" : "disabled") +
" capability of linking from the run-time image.");
System.out.println("DEBUG: default module-path, 'jmods', " +
(Helper.jdkHasPackagedModules() ? "" : "NOT ") +
"present.");
helper = Helper.newHelper(isLinkableRuntime);
if (helper == null) {
// In case of no linkable run-time image and also no packaged
// modules, helper will be null.
System.err.println("Test not run");
return;
}
helper.generateDefaultModules();
}

@Test
@@ -100,7 +89,6 @@ public static void testSpecies() throws IOException {
String fileString = "[SPECIES_RESOLVE] java.lang.invoke.BoundMethodHandle$Species_" + species + " (salvaged)\n";
Files.write(baseFile, fileString.getBytes(Charset.defaultCharset()));
Result result = JImageGenerator.getJLinkTask()
.modulePath(helper.defaultModulePath())
.output(helper.createNewImageDir("generate-jli-file"))
.option("--generate-jli-classes=@" + baseFile.toString())
.addMods("java.base")
@@ -126,7 +114,6 @@ public static void testInvalidSignatures() throws IOException {
fileString = "[LF_RESOLVE] java.lang.invoke.DirectMethodHandle$Holder invokeVirtual L_L (success)\n";
Files.write(failFile, fileString.getBytes(Charset.defaultCharset()));
Result result = JImageGenerator.getJLinkTask()
.modulePath(helper.defaultModulePath())
.output(helper.createNewImageDir("invalid-signature"))
.option("--generate-jli-classes=@" + failFile.toString())
.addMods("java.base")
@@ -139,7 +126,6 @@ public static void testInvalidSignatures() throws IOException {
@Test
public static void nonExistentTraceFile() throws IOException {
Result result = JImageGenerator.getJLinkTask()
.modulePath(helper.defaultModulePath())
.output(helper.createNewImageDir("non-existent-tracefile"))
.option("--generate-jli-classes=@NON_EXISTENT_FILE")
.addMods("java.base")
@@ -155,7 +141,6 @@ public static void testInvokers() throws IOException {
Path invokersTrace = Files.createTempFile("invokers", "trace");
Files.writeString(invokersTrace, fileString, Charset.defaultCharset());
Result result = JImageGenerator.getJLinkTask()
.modulePath(helper.defaultModulePath())
.output(helper.createNewImageDir("jli-invokers"))
.option("--generate-jli-classes=@" + invokersTrace.toString())
.addMods("java.base")
@@ -204,4 +189,5 @@ private static List<String> classFilesForSpecies(Collection<String> species) {
.map(s -> "/java.base/java/lang/invoke/BoundMethodHandle$Species_" + s + ".class")
.collect(Collectors.toList());
}

}
44 changes: 10 additions & 34 deletions test/jdk/tools/jlink/plugins/IncludeLocalesPluginTest.java
Original file line number Diff line number Diff line change
@@ -28,6 +28,7 @@
import java.util.Locale;
import java.util.stream.Collectors;

import jdk.tools.jlink.internal.LinkableRuntimeImage;
import jdk.tools.jlink.internal.TaskHelper;
import jdk.tools.jlink.internal.plugins.PluginsResourceBundle;
import jdk.tools.jlink.plugin.PluginException;
@@ -36,36 +37,15 @@
import tests.JImageValidator;
import tests.Result;

/*
* @test id=packaged_modules
* @bug 8152143 8152704 8155649 8165804 8185841 8176841 8190918
* 8179071 8202537 8221432 8222098 8251317 8258794 8265315
* 8296248 8306116 8174269 8333582
* @summary IncludeLocalesPlugin tests
* @author Naoto Sato
* @requires (jlink.packagedModules & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
* jdk.jlink/jdk.tools.jlink.internal
* jdk.jlink/jdk.tools.jlink.internal.plugins
* jdk.jlink/jdk.tools.jlink.plugin
* jdk.jlink/jdk.tools.jmod
* jdk.jlink/jdk.tools.jimage
* jdk.compiler
* @build tests.*
* @build tools.jlink.plugins.GetAvailableLocales
* @run main/othervm/timeout=180 -Xmx1g IncludeLocalesPluginTest false
*/

/*
* @test id=linkable_jdk_runtimes
* @test
* @bug 8152143 8152704 8155649 8165804 8185841 8176841 8190918
* 8179071 8202537 8221432 8222098 8251317 8258794 8265315
* 8296248 8306116 8174269
* @summary IncludeLocalesPlugin tests
* @author Naoto Sato
* @requires (jlink.runtime.linkable & !jlink.packagedModules & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @requires (vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
@@ -77,7 +57,7 @@
* jdk.compiler
* @build tests.*
* @build tools.jlink.plugins.GetAvailableLocales
* @run main/othervm/timeout=180 -Xmx1g IncludeLocalesPluginTest true
* @run main/othervm/timeout=180 -Xmx1g IncludeLocalesPluginTest
*/
public class IncludeLocalesPluginTest {

@@ -435,35 +415,31 @@ public class IncludeLocalesPluginTest {
};

public static void main(String[] args) throws Exception {
if (args.length != 1) {
throw new RuntimeException("Usage: " +
IncludeLocalesPluginTest.class.getSimpleName() +
" {true,false}");
}
boolean isLinkableRuntime = Boolean.parseBoolean(args[0]);
boolean isLinkableRuntime = LinkableRuntimeImage.isLinkableRuntime();
System.out.println("Running test on " +
(isLinkableRuntime ? "linkable JDK runtime." : "packaged modules."));
(isLinkableRuntime ? "enabled" : "disabled") +
" capability of linking from the run-time image.");
System.out.println("Default module-path, 'jmods', " +
(Helper.jdkHasPackagedModules() ? "" : "NOT ") +
"present.");

helper = Helper.newHelper(isLinkableRuntime);
if (helper == null) {
throw new RuntimeException("Helper could not be initialized");
}
helper.generateDefaultModules();

for (Object[] data : testData) {
// create image for each test data
Result result;
if (data[INCLUDE_LOCALES_OPTION].toString().isEmpty()) {
System.out.println("Invoking jlink with no --include-locales option");
result = JImageGenerator.getJLinkTask()
.modulePath(helper.defaultModulePath())
.output(helper.createNewImageDir(moduleName))
.addMods((String) data[ADDMODS_OPTION])
.call();
} else {
System.out.println("Invoking jlink with \"" + data[INCLUDE_LOCALES_OPTION] + "\"");
result = JImageGenerator.getJLinkTask()
.modulePath(helper.defaultModulePath())
.output(helper.createNewImageDir(moduleName))
.addMods((String) data[ADDMODS_OPTION])
.option((String) data[INCLUDE_LOCALES_OPTION])
Original file line number Diff line number Diff line change
@@ -41,6 +41,7 @@

import jdk.test.lib.process.OutputAnalyzer;
import jdk.test.lib.process.ProcessTools;
import jdk.tools.jlink.internal.LinkableRuntimeImage;
import tests.Helper;
import tests.JImageGenerator;
import tests.JImageGenerator.JLinkTask;
@@ -50,7 +51,8 @@ public abstract class AbstractLinkableRuntimeTest {

protected static final boolean DEBUG = true;

public void run(boolean isLinkableRuntime) throws Exception {
public void run() throws Exception {
boolean isLinkableRuntime = LinkableRuntimeImage.isLinkableRuntime();
Helper helper = Helper.newHelper(isLinkableRuntime);
if (helper == null) {
System.err.println(AbstractLinkableRuntimeTest.class.getSimpleName() +
27 changes: 4 additions & 23 deletions test/jdk/tools/jlink/runtimeImage/AddOptionsTest.java
Original file line number Diff line number Diff line change
@@ -29,9 +29,9 @@
import tests.Helper;

/*
* @test id=linkable_runtime
* @test
* @summary Test --add-options jlink plugin when linking from the run-time image
* @requires (jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @requires (vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
@@ -40,32 +40,13 @@
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g AddOptionsTest true
*/

/*
* @test id=default_build
* @summary Test --add-options jlink plugin when linking from the run-time image
* @requires (!jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
* jdk.jlink/jdk.tools.jlink.internal
* jdk.jlink/jdk.tools.jlink.plugin
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g AddOptionsTest false
* @run main/othervm -Xmx1g AddOptionsTest
*/
public class AddOptionsTest extends AbstractLinkableRuntimeTest {

public static void main(String[] args) throws Exception {
if (args.length != 1) {
throw new IllegalArgumentException("Wrong number of passed arguments");
}
boolean isLinkableRuntime = Boolean.parseBoolean(args[0]);
AddOptionsTest test = new AddOptionsTest();
test.run(isLinkableRuntime);
test.run();
}

@Override
28 changes: 4 additions & 24 deletions test/jdk/tools/jlink/runtimeImage/BasicJlinkMissingJavaBase.java
Original file line number Diff line number Diff line change
@@ -29,10 +29,10 @@


/*
* @test id=linkable_runtime
* @test
* @summary Test basic linking from the run-time image with java.base.jmod missing
* but java.xml.jmod present. It should link from the run-time image without errors.
* @requires (jlink.packagedModules & jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @requires (jlink.packagedModules & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
@@ -41,23 +41,7 @@
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g BasicJlinkMissingJavaBase true
*/

/*
* @test id=default_build
* @summary Test basic linking from the run-time image with java.base.jmod missing
* but java.xml.jmod present. It should link from the run-time image without errors.
* @requires (jlink.packagedModules & !jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
* jdk.jlink/jdk.tools.jlink.internal
* jdk.jlink/jdk.tools.jlink.plugin
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g BasicJlinkMissingJavaBase false
* @run main/othervm -Xmx1g BasicJlinkMissingJavaBase
*/
public class BasicJlinkMissingJavaBase extends AbstractLinkableRuntimeTest {

@@ -81,12 +65,8 @@ private Path createJavaXMLRuntimeLink(Helper helper, String name, boolean isLink
}

public static void main(String[] args) throws Exception {
if (args.length != 1) {
throw new IllegalArgumentException("Wrong number of passed arguments");
}
boolean isLinkableRuntime = Boolean.parseBoolean(args[0]);
BasicJlinkMissingJavaBase test = new BasicJlinkMissingJavaBase();
test.run(isLinkableRuntime);
test.run();
}

}
25 changes: 3 additions & 22 deletions test/jdk/tools/jlink/runtimeImage/BasicJlinkTest.java
Original file line number Diff line number Diff line change
@@ -28,24 +28,9 @@


/*
* @test id=linkable_runtime
* @test
* @summary Test basic linking from the run-time image
* @requires (jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
* jdk.jlink/jdk.tools.jlink.internal
* jdk.jlink/jdk.tools.jlink.plugin
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g BasicJlinkTest true
*/

/*
* @test id=default_build
* @summary Test basic linking from the run-time image
* @requires (!jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @requires (vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
@@ -77,12 +62,8 @@ private Path createJavaBaseRuntimeLink(Helper helper, String name, boolean isLin
}

public static void main(String[] args) throws Exception {
if (args.length != 1) {
throw new IllegalArgumentException("Wrong number of passed arguments");
}
boolean isLinkableRuntime = Boolean.parseBoolean(args[0]);
BasicJlinkTest test = new BasicJlinkTest();
test.run(isLinkableRuntime);
test.run();
}

}
27 changes: 4 additions & 23 deletions test/jdk/tools/jlink/runtimeImage/CustomModuleJlinkTest.java
Original file line number Diff line number Diff line change
@@ -28,9 +28,9 @@


/*
* @test id=linkable_runtime
* @test
* @summary Test jmod-less jlink with a custom module
* @requires (jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @requires (vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
@@ -39,32 +39,13 @@
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g CustomModuleJlinkTest true
*/

/*
* @test id=default_build
* @summary Test jmod-less jlink with a custom module
* @requires (!jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
* jdk.jlink/jdk.tools.jlink.internal
* jdk.jlink/jdk.tools.jlink.plugin
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g CustomModuleJlinkTest false
* @run main/othervm -Xmx1g CustomModuleJlinkTest
*/
public class CustomModuleJlinkTest extends AbstractLinkableRuntimeTest {

public static void main(String[] args) throws Exception {
if (args.length != 1) {
throw new IllegalArgumentException("Wrong number of passed arguments");
}
boolean isLinkableRuntime = Boolean.parseBoolean(args[0]);
CustomModuleJlinkTest test = new CustomModuleJlinkTest();
test.run(isLinkableRuntime);
test.run();
}

@Override
27 changes: 4 additions & 23 deletions test/jdk/tools/jlink/runtimeImage/GenerateJLIClassesTest.java
Original file line number Diff line number Diff line change
@@ -28,9 +28,9 @@
import tests.Helper;

/*
* @test id=linkable_runtime
* @test
* @summary Verify JLI class generation in run-time image link mode
* @requires (jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @requires (vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
@@ -39,32 +39,13 @@
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g GenerateJLIClassesTest true
*/

/*
* @test id=default_build
* @summary Verify JLI class generation in run-time image link mode
* @requires (!jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
* jdk.jlink/jdk.tools.jlink.internal
* jdk.jlink/jdk.tools.jlink.plugin
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g GenerateJLIClassesTest false
* @run main/othervm -Xmx1g GenerateJLIClassesTest
*/
public class GenerateJLIClassesTest extends AbstractLinkableRuntimeTest {

public static void main(String[] args) throws Exception {
if (args.length != 1) {
throw new IllegalArgumentException("Wrong number of passed arguments");
}
boolean isLinkableRuntime = Boolean.parseBoolean(args[0]);
GenerateJLIClassesTest test = new GenerateJLIClassesTest();
test.run(isLinkableRuntime);
test.run();
}

/*
27 changes: 4 additions & 23 deletions test/jdk/tools/jlink/runtimeImage/JavaSEReproducibleTest.java
Original file line number Diff line number Diff line change
@@ -26,27 +26,12 @@

import tests.Helper;

/*
* @test id=linkable_runtime
* @summary Test reproducibility of linking an java.se image using the run-time
* image.
* @requires (jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
* jdk.jlink/jdk.tools.jlink.internal
* jdk.jlink/jdk.tools.jlink.plugin
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g JavaSEReproducibleTest true
*/

/*
* @test id=default_build
* @test
* @summary Test reproducibility of linking an java.se image using the run-time
* image.
* @requires (!jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @requires (vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
@@ -55,17 +40,13 @@
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g JavaSEReproducibleTest false
* @run main/othervm -Xmx1g JavaSEReproducibleTest
*/
public class JavaSEReproducibleTest extends AbstractLinkableRuntimeTest {

public static void main(String[] args) throws Exception {
if (args.length != 1) {
throw new IllegalArgumentException("Wrong number of passed arguments");
}
boolean isLinkableRuntime = Boolean.parseBoolean(args[0]);
JavaSEReproducibleTest test = new JavaSEReproducibleTest();
test.run(isLinkableRuntime);
test.run();
}

@Override
28 changes: 4 additions & 24 deletions test/jdk/tools/jlink/runtimeImage/KeepPackagedModulesFailTest.java
Original file line number Diff line number Diff line change
@@ -29,10 +29,10 @@


/*
* @test id=linkable_runtime
* @test
* @summary Verify that jlink with an empty module path, but trying to use
* --keep-packaged-modules fails as expected.
* @requires (jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @requires (vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
@@ -41,33 +41,13 @@
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g KeepPackagedModulesFailTest true
*/

/*
* @test id=default_build
* @summary Verify that jlink with an empty module path, but trying to use
* --keep-packaged-modules fails as expected.
* @requires (!jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
* jdk.jlink/jdk.tools.jlink.internal
* jdk.jlink/jdk.tools.jlink.plugin
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g KeepPackagedModulesFailTest false
* @run main/othervm -Xmx1g KeepPackagedModulesFailTest
*/
public class KeepPackagedModulesFailTest extends AbstractLinkableRuntimeTest {

public static void main(String[] args) throws Exception {
if (args.length != 1) {
throw new IllegalArgumentException("Wrong number of passed arguments");
}
boolean isLinkableRuntime = Boolean.parseBoolean(args[0]);
KeepPackagedModulesFailTest test = new KeepPackagedModulesFailTest();
test.run(isLinkableRuntime);
test.run();
}

@Override
28 changes: 4 additions & 24 deletions test/jdk/tools/jlink/runtimeImage/ModifiedFilesExitTest.java
Original file line number Diff line number Diff line change
@@ -28,10 +28,10 @@
import tests.Helper;

/*
* @test id=linkable_runtime
* @test
* @summary Verify jlink fails by default when linking from the run-time image
* and files have been modified
* @requires (jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @requires (vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
@@ -40,33 +40,13 @@
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g ModifiedFilesExitTest true
*/

/*
* @test id=default_build
* @summary Verify jlink fails by default when linking from the run-time image
* and files have been modified
* @requires (!jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
* jdk.jlink/jdk.tools.jlink.internal
* jdk.jlink/jdk.tools.jlink.plugin
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g ModifiedFilesExitTest false
* @run main/othervm -Xmx1g ModifiedFilesExitTest
*/
public class ModifiedFilesExitTest extends ModifiedFilesTest {

public static void main(String[] args) throws Exception {
if (args.length != 1) {
throw new IllegalArgumentException("Wrong number of passed arguments");
}
boolean isLinkableRuntime = Boolean.parseBoolean(args[0]);
ModifiedFilesExitTest test = new ModifiedFilesExitTest();
test.run(isLinkableRuntime);
test.run();
}

@Override
28 changes: 4 additions & 24 deletions test/jdk/tools/jlink/runtimeImage/ModifiedFilesWarningTest.java
Original file line number Diff line number Diff line change
@@ -27,10 +27,10 @@
import tests.Helper;

/*
* @test id=linkable_runtime
* @test
* @summary Verify warnings are being produced when linking from the run-time
* image and files have been modified
* @requires (jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @requires (vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
@@ -39,35 +39,15 @@
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g ModifiedFilesWarningTest true
*/

/*
* @test id=default_build
* @summary Verify warnings are being produced when linking from the run-time
* image and files have been modified
* @requires (!jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
* jdk.jlink/jdk.tools.jlink.internal
* jdk.jlink/jdk.tools.jlink.plugin
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g ModifiedFilesWarningTest false
* @run main/othervm -Xmx1g ModifiedFilesWarningTest
*/
public class ModifiedFilesWarningTest extends ModifiedFilesTest {

protected static final String IGNORE_MODIFIED_RUNTIME_OPT = "--ignore-modified-runtime";

public static void main(String[] args) throws Exception {
if (args.length != 1) {
throw new IllegalArgumentException("Wrong number of passed arguments");
}
boolean isLinkableRuntime = Boolean.parseBoolean(args[0]);
ModifiedFilesWarningTest test = new ModifiedFilesWarningTest();
test.run(isLinkableRuntime);
test.run();
}

@Override
26 changes: 4 additions & 22 deletions test/jdk/tools/jlink/runtimeImage/MultiHopTest.java
Original file line number Diff line number Diff line change
@@ -27,25 +27,11 @@
import jdk.test.lib.process.OutputAnalyzer;
import tests.Helper;

/*
* @test id=linkable_runtime
* @summary Verify that a jlink using the run-time image cannot include jdk.jlink
* @requires (jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
* jdk.jlink/jdk.tools.jlink.internal
* jdk.jlink/jdk.tools.jlink.plugin
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g MultiHopTest true
*/

/*
* @test id=default_build
* @test
* @summary Verify that a jlink using the run-time image cannot include jdk.jlink
* @requires (!jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @requires (vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
@@ -54,7 +40,7 @@
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g MultiHopTest false
* @run main/othervm -Xmx1g MultiHopTest
*/
public class MultiHopTest extends AbstractLinkableRuntimeTest {

@@ -100,12 +86,8 @@ private Path createJDKJlinkJmodLess(Helper helper, String name, boolean isLinkab
}

public static void main(String[] args) throws Exception {
if (args.length != 1) {
throw new IllegalArgumentException("Wrong number of passed arguments");
}
boolean isLinkableRuntime = Boolean.parseBoolean(args[0]);
MultiHopTest test = new MultiHopTest();
test.run(isLinkableRuntime);
test.run();
}

}
Original file line number Diff line number Diff line change
@@ -35,27 +35,12 @@
import tests.Helper;
import tests.JImageGenerator;

/*
* @test id=linkable_runtime
* @summary Compare packaged-modules jlink with a run-time image based jlink to
* produce the same result
* @requires (jlink.packagedModules & jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
* jdk.jlink/jdk.tools.jlink.internal
* jdk.jlink/jdk.tools.jlink.plugin
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g PackagedModulesVsRuntimeImageLinkTest true
*/

/*
* @test id=default_build
* @test
* @summary Compare packaged-modules jlink with a run-time image based jlink to
* produce the same result
* @requires (jlink.packagedModules & !jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @requires (jlink.packagedModules & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
@@ -64,17 +49,13 @@
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g PackagedModulesVsRuntimeImageLinkTest false
* @run main/othervm -Xmx1g PackagedModulesVsRuntimeImageLinkTest
*/
public class PackagedModulesVsRuntimeImageLinkTest extends AbstractLinkableRuntimeTest {

public static void main(String[] args) throws Exception {
if (args.length != 1) {
throw new IllegalArgumentException("Wrong number of passed arguments");
}
boolean isLinkableRuntime = Boolean.parseBoolean(args[0]);
PackagedModulesVsRuntimeImageLinkTest test = new PackagedModulesVsRuntimeImageLinkTest();
test.run(isLinkableRuntime);
test.run();
}

@Override
27 changes: 4 additions & 23 deletions test/jdk/tools/jlink/runtimeImage/PatchedJDKModuleJlinkTest.java
Original file line number Diff line number Diff line change
@@ -31,9 +31,9 @@


/*
* @test id=linkable_runtime
* @test
* @summary Test run-time link with --patch-module. Expect failure.
* @requires (jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @requires (vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
@@ -42,22 +42,7 @@
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g PatchedJDKModuleJlinkTest true
*/

/*
* @test id=default_build
* @summary Test run-time link with --patch-module. Expect failure.
* @requires (!jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
* jdk.jlink/jdk.tools.jlink.internal
* jdk.jlink/jdk.tools.jlink.plugin
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g PatchedJDKModuleJlinkTest false
* @run main/othervm -Xmx1g PatchedJDKModuleJlinkTest
*/
public class PatchedJDKModuleJlinkTest extends AbstractLinkableRuntimeTest {

@@ -132,12 +117,8 @@ private Path createRuntimeLinkImage(Helper helper, String name, boolean isLinkab
}

public static void main(String[] args) throws Exception {
if (args.length != 1) {
throw new IllegalArgumentException("Wrong number of passed arguments");
}
boolean isLinkableRuntime = Boolean.parseBoolean(args[0]);
PatchedJDKModuleJlinkTest test = new PatchedJDKModuleJlinkTest();
test.run(isLinkableRuntime);
test.run();
}

}
26 changes: 4 additions & 22 deletions test/jdk/tools/jlink/runtimeImage/SystemModulesTest.java
Original file line number Diff line number Diff line change
@@ -28,25 +28,11 @@
import tests.Helper;
import tests.JImageValidator;

/*
* @test id=linkable_runtime
* @summary Test appropriate handling of generated SystemModules* classes in run-time image link mode
* @requires (jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
* jdk.jlink/jdk.tools.jlink.internal
* jdk.jlink/jdk.tools.jlink.plugin
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g SystemModulesTest true
*/

/*
* @test id=default_build
* @test
* @summary Test appropriate handling of generated SystemModules* classes in run-time image link mode
* @requires (!jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @requires (vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
@@ -55,17 +41,13 @@
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g SystemModulesTest false
* @run main/othervm -Xmx1g SystemModulesTest
*/
public class SystemModulesTest extends AbstractLinkableRuntimeTest {

public static void main(String[] args) throws Exception {
if (args.length != 1) {
throw new IllegalArgumentException("Wrong number of passed arguments");
}
boolean isLinkableRuntime = Boolean.parseBoolean(args[0]);
SystemModulesTest test = new SystemModulesTest();
test.run(isLinkableRuntime);
test.run();
}

/*
27 changes: 4 additions & 23 deletions test/jdk/tools/jlink/runtimeImage/SystemModulesTest2.java
Original file line number Diff line number Diff line change
@@ -28,27 +28,12 @@
import tests.Helper;
import tests.JImageValidator;

/*
* @test id=linkable_runtime
* @summary Test disabled SystemModulesPlugin in run-time image link mode. Expect
* generated classes to not be there.
* @requires (jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
* jdk.jlink/jdk.tools.jlink.internal
* jdk.jlink/jdk.tools.jlink.plugin
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g SystemModulesTest2 true
*/

/*
* @test id=default_build
* @test
* @summary Test disabled SystemModulesPlugin in run-time image link mode. Expect
* generated classes to not be there.
* @requires (!jlink.runtime.linkable & vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @requires (vm.compMode != "Xcomp" & os.maxMemory >= 2g)
* @library ../../lib /test/lib
* @enablePreview
* @modules java.base/jdk.internal.jimage
@@ -57,17 +42,13 @@
* jdk.jlink/jdk.tools.jimage
* @build tests.* jdk.test.lib.process.OutputAnalyzer
* jdk.test.lib.process.ProcessTools
* @run main/othervm -Xmx1g SystemModulesTest2 false
* @run main/othervm -Xmx1g SystemModulesTest2
*/
public class SystemModulesTest2 extends AbstractLinkableRuntimeTest {

public static void main(String[] args) throws Exception {
if (args.length != 1) {
throw new IllegalArgumentException("Wrong number of passed arguments");
}
boolean isLinkableRuntime = Boolean.parseBoolean(args[0]);
SystemModulesTest2 test = new SystemModulesTest2();
test.run(isLinkableRuntime);
test.run();
}

@Override
6 changes: 5 additions & 1 deletion test/jdk/tools/lib/tests/Helper.java
Original file line number Diff line number Diff line change
@@ -72,14 +72,18 @@ public static Helper newHelper() throws IOException {
}

public static Helper newHelper(boolean linkableRuntime) throws IOException {
if (!linkableRuntime && !Files.exists(JDK_HOME.resolve("jmods"))) {
if (!linkableRuntime && !jdkHasPackagedModules()) {
// Skip test if the jmods directory is missing (e.g. exploded image)
System.err.println("Test not run, NO jmods directory");
return null;
}
return new Helper(JDK_HOME, linkableRuntime);
}

public static boolean jdkHasPackagedModules() {
return Files.exists(JDK_HOME.resolve("jmods"));
}

private Helper(Path jdkHome, boolean linkableRuntime) throws IOException {
this.linkableRuntime = linkableRuntime;
this.stdjmods = jdkHome.resolve("jmods").normalize();
26 changes: 0 additions & 26 deletions test/jtreg-ext/requires/VMProps.java
Original file line number Diff line number Diff line change
@@ -143,7 +143,6 @@ public Map<String, String> call() {
map.put("jdk.containerized", this::jdkContainerized);
map.put("vm.flagless", this::isFlagless);
map.put("jdk.foreign.linker", this::jdkForeignLinker);
map.put("jlink.runtime.linkable", this::runtimeLinkable);
map.put("jlink.packagedModules", this::packagedModules);
vmGC(map); // vm.gc.X = true/false
vmGCforCDS(map); // may set vm.gc
@@ -737,31 +736,6 @@ private String packagedModules() {
}
}

private String runtimeLinkable() {
// jdk.jlink module has the following resource indicating a runtime-linkable
// image. It's the diff file for runtime linking of the java.base module.
String linkableRuntimeResource = "jdk/tools/jlink/internal/runtimelink/diff_java.base";
try {
ModuleFinder finder = ModuleFinder.ofSystem();
Optional<ModuleReference> ref = finder.find("jdk.jlink");
if (ref.isEmpty()) {
// No jdk.jlink in the current image
return Boolean.FALSE.toString();
}
try (ModuleReader reader = ref.get().open()) {
Optional<InputStream> inOpt = reader.open(linkableRuntimeResource);
if (inOpt.isPresent()) {
inOpt.get().close();
return Boolean.TRUE.toString();
} else {
return Boolean.FALSE.toString();
}
}
} catch (Throwable t) {
return Boolean.FALSE.toString();
}
}

/**
* Checks if we are in <i>almost</i> out-of-box configuration, i.e. the flags
* which JVM is started with don't affect its behavior "significantly".