Commit 9d265a2
authored
Add JPMS ServiceLoader Support with Multi-Release JAR (#500)
* #426 Add JPMS module support with ServiceLoader
**Note:** This is not a complete solution as handling of JDK 8
compatibility is outstanding. Currently, the fix would break
usage of JDK 8.
Enable `exec:java`-goal to execute Java applications using the Java
Platform Module System (JPMS) with proper ServiceLoader support.
Changes:
- Split execution logic into classpath and module-path modes
- Detect module syntax (module/class) in mainClass parameter
- Create ModuleLayer with resolveAndBind() to include service providers
- Use ModuleLayer.Controller to open packages for reflective access
- Set thread context classloader to module's classloader
The plugin now properly handles:
- Module-path execution when `mainClass` uses "module/class" syntax
- ServiceLoader provider discovery and binding in modular applications
- Reflective access to main methods in unexported packages
- Mixed module and classpath dependencies
Integration test mexec-gh-426 validates the ServiceLoader functionality
with a multi-module JPMS application (contract, provider, consumer).
Technical implementation:
- Use Configuration.resolveAndBind() instead of resolve() to include
service providers declared with "uses" in module-info
- Obtain ModuleLayer.Controller to programmatically open packages via
addOpens() for reflective main method invocation
- Load classes through the module layer's ClassLoader to maintain
proper module isolation and visibility
The fix was created in the course of support-and-care/maven-support-and-care#138.
* #426 Fix JSR-512 main method detection
This commit fixes two issues that caused build failures in GitHub:
1. JSR-512 Main Method Detection
Problem: Tests failed with error:
"The specified mainClass doesn't contain a main method with
appropriate signature"
JSR-512 (Java 21+) allows flexible main methods that can be
non-public and instance methods. The original code used
getMethod() which only finds PUBLIC methods, causing it to
fail when searching for package-private main methods.
Solution:
- Changed from getMethod() to getDeclaredMethod() for JSR-512
- Added setAccessible(true) for non-public method invocation
- Created findMethod() helper that searches class hierarchy
- Validates return type is void (JSR-512 requirement)
- Maintains correct priority order:
1. static void main(String[]) - traditional
2. static void main() - JSR-512 static no-args
3. void main(String[]) - JSR-512 instance with args
4. void main() - JSR-512 instance no-args
2. SystemExitException Logging
Problem: Integration tests expected [ERROR] log prefix for
SystemExitException but it was missing.
When SystemExitException was thrown during method invocation,
it got wrapped in InvocationTargetException and bypassed the
logging code.
Solution:
- Added special handling in InvocationTargetException catch
- Detects SystemExitException in the cause chain
- Logs with appropriate level (ERROR for non-zero exit codes)
- Re-throws the exception to maintain expected behavior
* #426 Create Multi-Release Jar
* #426 Move common ExecJava code to base class
* #494 Find classic main method even if private1 parent 1c26293 commit 9d265a2
File tree
16 files changed
+1324
-810
lines changed- src
- it/projects/mexec-gh-426
- consumer
- src/main/java
- org/example/consumer
- contract
- src/main/java
- org/example/api
- provider
- src/main/java
- org/example/provider
- main
- java9/org/codehaus/mojo/exec
- java/org/codehaus/mojo/exec
16 files changed
+1324
-810
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
139 | 139 | | |
140 | 140 | | |
141 | 141 | | |
| 142 | + | |
| 143 | + | |
142 | 144 | | |
143 | 145 | | |
144 | 146 | | |
| |||
287 | 289 | | |
288 | 290 | | |
289 | 291 | | |
290 | | - | |
291 | | - | |
292 | | - | |
293 | | - | |
294 | | - | |
295 | | - | |
296 | | - | |
297 | | - | |
298 | | - | |
299 | | - | |
300 | | - | |
301 | | - | |
302 | 292 | | |
303 | 293 | | |
304 | 294 | | |
305 | 295 | | |
306 | 296 | | |
307 | 297 | | |
| 298 | + | |
308 | 299 | | |
309 | 300 | | |
310 | 301 | | |
| |||
374 | 365 | | |
375 | 366 | | |
376 | 367 | | |
| 368 | + | |
| 369 | + | |
| 370 | + | |
| 371 | + | |
| 372 | + | |
| 373 | + | |
| 374 | + | |
| 375 | + | |
| 376 | + | |
| 377 | + | |
| 378 | + | |
| 379 | + | |
| 380 | + | |
| 381 | + | |
| 382 | + | |
| 383 | + | |
| 384 | + | |
| 385 | + | |
| 386 | + | |
| 387 | + | |
| 388 | + | |
| 389 | + | |
| 390 | + | |
| 391 | + | |
| 392 | + | |
| 393 | + | |
| 394 | + | |
| 395 | + | |
| 396 | + | |
| 397 | + | |
| 398 | + | |
| 399 | + | |
| 400 | + | |
| 401 | + | |
| 402 | + | |
| 403 | + | |
| 404 | + | |
| 405 | + | |
| 406 | + | |
| 407 | + | |
| 408 | + | |
| 409 | + | |
| 410 | + | |
| 411 | + | |
| 412 | + | |
| 413 | + | |
| 414 | + | |
| 415 | + | |
| 416 | + | |
| 417 | + | |
| 418 | + | |
| 419 | + | |
| 420 | + | |
| 421 | + | |
| 422 | + | |
| 423 | + | |
| 424 | + | |
| 425 | + | |
| 426 | + | |
| 427 | + | |
| 428 | + | |
| 429 | + | |
| 430 | + | |
| 431 | + | |
| 432 | + | |
| 433 | + | |
| 434 | + | |
| 435 | + | |
| 436 | + | |
| 437 | + | |
| 438 | + | |
| 439 | + | |
| 440 | + | |
| 441 | + | |
377 | 442 | | |
378 | 443 | | |
379 | 444 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
Lines changed: 4 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
Lines changed: 16 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
Lines changed: 3 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
Lines changed: 5 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
0 commit comments