-
Notifications
You must be signed in to change notification settings - Fork 245
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
FST doesn't work on Java 16 #312
Comments
Temporary workaround: add |
It seems like this workaround will no longer be possible with Java 17:
|
Judging by the comments in projectlombok/lombok#2681 (especially the ones by @pron) granting (instrusive) access to internal classes and properties of JDK classes is to be explicitly white-listed by developers in the future. So issues like these probably won't magically disappear. However, the JVM seems to officially support granting these access rights via the I managed to solve the above issue with the following maven config (we use FST during testing): <plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<configuration>
<argLine>--add-opens=java.base/java.lang=ALL-UNNAMED
--add-opens=java.base/java.math=ALL-UNNAMED
--add-opens=java.base/java.util=ALL-UNNAMED
--add-opens=java.base/java.util.concurrent=ALL-UNNAMED
--add-opens=java.base/java.net=ALL-UNNAMED
--add-opens=java.base/java.text=ALL-UNNAMED
--add-opens=java.sql/java.sql=ALL-UNNAMED</argLine>
</configuration>
</plugin> I wasn't able to check this with Java 17, but maybe this proves useful for somebody else as well. |
It can be solved without any JVM parameter with Burningwave Core reflection components that thanks to a special driver work on all JDKs from 8. In this case you can also simply call the method |
I would strongly advise against breaking strong encapsulation and going against what is mainstream Java orientation. |
Will there be a solution to the problem out of the box or is the project abandoned? |
Strong Encapsulation in the JDK Java 17 LTS It is a funtamental change for security reasons and probably will stay for ever. This probably means that "--add-opens=...." will follow all upgraded projects to 17 LTS. |
This solution works on Java 17 ! |
Is there any plan to fix this as part of library update instead of adding maven configuration options? |
Take a look at how to export all modules to all modules at runtime |
In maven central I can see the below version. https://mvnrepository.com/artifact/de.ruedigermoeller/fst/3.0.4-jdk17 Does |
The name points that it does, only after using the necessary"--add-opens" settings. Changes from the old version: master...jdk17 |
@JJBRT Note that any remaining loophole in strong encapsulation, including JNI, will eventually also require an explicit command-line permission similar to add-opens -- just as SecurityManager required such permission -- as strong encapsulation gradually becomes the foundation of the JDK's security. |
The following exception is always thrown:
This is probably related to the implementation of JEP-396...
The text was updated successfully, but these errors were encountered: