Har*_*rsh 5 java error-handling logging junit
java.lang.reflect.InaccessibleObjectException: Unable to make field private final java.lang.Object java.util.Optional.value accessible: module java.base does not "opens java.util" to unnamed module @6b26e945
Run Code Online (Sandbox Code Playgroud)
当我运行 JUnit 代码时,出现此错误。以下代码块周围出现错误。
Optional<RolesDTO> roleDTOEmployee = roles.stream()
.filter(r -> r.getName().equals(RolesEnum.valueOf(roleName).getRoleName())).findFirst();
if (logger.isInfoEnabled()) {
logger.info("roleDTOEmployee {}", gson.toJson(roleDTOEmployee));
}
Run Code Online (Sandbox Code Playgroud)
堆栈跟踪:
at java.base/java.lang.reflect.AccessibleObject.checkCanSetAccessible(AccessibleObject.java:354)
at java.base/java.lang.reflect.AccessibleObject.checkCanSetAccessible(AccessibleObject.java:297)
at java.base/java.lang.reflect.Field.checkCanSetAccessible(Field.java:178)
at java.base/java.lang.reflect.Field.setAccessible(Field.java:172)
at com.google.gson.internal.bind.ReflectiveTypeAdapterFactory.getBoundFields(ReflectiveTypeAdapterFactory.java:157)
at com.google.gson.internal.bind.ReflectiveTypeAdapterFactory.create(ReflectiveTypeAdapterFactory.java:100)
at com.google.gson.Gson.getAdapter(Gson.java:423)
at com.google.gson.Gson.toJson(Gson.java:661)
at com.google.gson.Gson.toJson(Gson.java:648)
at com.google.gson.Gson.toJson(Gson.java:603)
at com.google.gson.Gson.toJson(Gson.java:583)
Run Code Online (Sandbox Code Playgroud)
删除 logger.info() 后,JUnit 代码可以完美运行。我想了解这种行为。有没有解决方法,这样我就不必删除记录器。
如果您使用较高的 JDK 版本 (8+) 和模块之一(在本例中com.google.gson.Gson与较低的 JDK 版本兼容),通常会引发此错误。
您能否检查两个 JDK 版本 Gson 版本(如果可能且需要的话)降级您的 JDK。这样你的错误可能就会消失。另一种可能性是升级com.google.gson.Gson版本,使其与您的 JDK 兼容。
另一种解决方法(通常不推荐)是传递 VM 参数以避免上述错误:
-Xmx1536M --add-exports=java.base/sun.nio.ch=ALL-UNNAMED --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.lang.reflect=ALL-UNNAMED --add-opens=java.base/java.io=ALL-UNNAMED --add-exports=jdk.unsupported/sun.misc=ALL-UNNAMED
Run Code Online (Sandbox Code Playgroud)