gudzpoz opened a new issue, #2460:
URL: https://github.com/apache/fory/issues/2460

   ### Search before asking
   
   - [x] I had searched in the [issues](https://github.com/apache/fory/issues) 
and found no similar issues.
   
   
   ### Version
   
   OS: ArchLinux (6.15.2-zen1-1-zen)
   Fory: 'org.apache.fory:fory-core:0.11.2'
   Tested on two JDKs:
   JDK 1: GraalVM 23.0.2+7.1 (build 23.0.2+7-jvmci-b01)
   JDK 2: GraalVM CE 24.0.2+11.1 (build 24.0.2+11-jvmci-b01)
   
   ### Component(s)
   
   Java
   
   ### Minimal reproduce step
   
   Clone [the reproducer 
project](https://github.com/gudzpoz/fory-native-image-reproducer)
   
   Reproduce map errors:
   
      ```console
      $ git checkout map-test
      $ ./gradlew nativeCompile
      $ app/build/native/nativeCompile/test
      ```
   
   <details><summary>Error messages</summary>
   ```
   Exception in thread "main" java.lang.RuntimeException: Create sequential 
serializer failed, 
   class: class org.example.App
        at 
org.apache.fory.serializer.CodegenSerializer.loadCodegenSerializer(CodegenSerializer.java:52)
        at 
org.apache.fory.resolver.ClassResolver.lambda$getObjectSerializerClass$2(ClassResolver.java:1132)
        at 
org.apache.fory.builder.JITContext.registerSerializerJITCallback(JITContext.java:121)
        at 
org.apache.fory.resolver.ClassResolver.getObjectSerializerClass(ClassResolver.java:1130)
        at 
org.apache.fory.resolver.ClassResolver.getObjectSerializerClass(ClassResolver.java:1110)
        at 
org.apache.fory.serializer.collection.MapSerializers$DefaultJavaMapSerializer.<init>(MapSerializers.java:391)
        at 
org.graalvm.nativeimage.builder/com.oracle.svm.core.methodhandles.Util_java_lang_invoke_MethodHandle.invokeInternal(Target_java_lang_invoke_MethodHandle.java:241)
        at 
[email protected]/java.lang.invoke.MethodHandle.invokeBasic(MethodHandle.java:102)
        at 
[email protected]/java.lang.invoke.MethodHandle.invokeBasic(MethodHandle.java:0)
        at 
[email protected]/java.lang.invoke.Invokers$Holder.invoke_MT(Invokers$Holder)
        at 
org.apache.fory.serializer.Serializers.newSerializer(Serializers.java:94)
        at 
org.apache.fory.resolver.ClassResolver.createSerializer(ClassResolver.java:1389)
        at 
org.apache.fory.resolver.ClassResolver.getOrUpdateClassInfo(ClassResolver.java:1310)
        at org.apache.fory.Fory.write(Fory.java:401)
        at org.apache.fory.Fory.serialize(Fory.java:325)
        at org.apache.fory.Fory.serialize(Fory.java:279)
        at org.example.App.main(App.java:20)
        at 
[email protected]/java.lang.invoke.LambdaForm$DMH/sa346b79c.invokeStaticInit(LambdaForm$DMH)
   Caused by: java.lang.IllegalArgumentException: class class 
org.apache.fory.Fory doesn't have method getRefResolver
        at 
org.apache.fory.reflect.ReflectionUtils.hasException(ReflectionUtils.java:244)
        at 
org.apache.fory.codegen.Expression$Invoke.<init>(Expression.java:1013)
        at org.apache.fory.codegen.Expression$Invoke.<init>(Expression.java:997)
        at org.apache.fory.codegen.Expression$Invoke.<init>(Expression.java:977)
        at 
org.apache.fory.builder.BaseObjectCodecBuilder.<init>(BaseObjectCodecBuilder.java:169)
        at 
org.apache.fory.builder.ObjectCodecBuilder.<init>(ObjectCodecBuilder.java:88)
        at 
org.apache.fory.builder.CodecUtils.loadOrGenObjectCodecClass(CodecUtils.java:43)
        at 
org.apache.fory.serializer.CodegenSerializer.loadCodegenSerializer(CodegenSerializer.java:49)
        ... 17 more
   ```
   </details>
   
   Reproduce collection errors:
   
      ```console
      $ git checkout collection-test
      $ ./gradlew nativeCompile
      $ app/build/native/nativeCompile/test
      ```
   
   <details><summary>Error messages</summary>
   ```
   Exception in thread "main" java.lang.RuntimeException: Create sequential 
serializer failed, 
   class: class org.example.App
        at 
org.apache.fory.serializer.CodegenSerializer.loadCodegenSerializer(CodegenSerializer.java:52)
        at 
org.apache.fory.resolver.ClassResolver.lambda$getObjectSerializerClass$2(ClassResolver.java:1132)
        at 
org.apache.fory.builder.JITContext.registerSerializerJITCallback(JITContext.java:121)
        at 
org.apache.fory.resolver.ClassResolver.getObjectSerializerClass(ClassResolver.java:1130)
        at 
org.apache.fory.resolver.ClassResolver.getObjectSerializerClass(ClassResolver.java:1110)
        at 
org.apache.fory.serializer.collection.CollectionSerializers$DefaultJavaCollectionSerializer.<init>(CollectionSerializers.java:702)
        at 
org.graalvm.nativeimage.builder/com.oracle.svm.core.methodhandles.Util_java_lang_invoke_MethodHandle.invokeInternal(Target_java_lang_invoke_MethodHandle.java:241)
        at 
[email protected]/java.lang.invoke.MethodHandle.invokeBasic(MethodHandle.java:102)
        at 
[email protected]/java.lang.invoke.MethodHandle.invokeBasic(MethodHandle.java:0)
        at 
[email protected]/java.lang.invoke.Invokers$Holder.invoke_MT(Invokers$Holder)
        at 
org.apache.fory.serializer.Serializers.newSerializer(Serializers.java:94)
        at 
org.apache.fory.resolver.ClassResolver.createSerializer(ClassResolver.java:1389)
        at 
org.apache.fory.resolver.ClassResolver.getOrUpdateClassInfo(ClassResolver.java:1310)
        at org.apache.fory.Fory.write(Fory.java:401)
        at org.apache.fory.Fory.serialize(Fory.java:325)
        at org.apache.fory.Fory.serialize(Fory.java:279)
        at org.example.App.main(App.java:22)
        at 
[email protected]/java.lang.invoke.LambdaForm$DMH/sa346b79c.invokeStaticInit(LambdaForm$DMH)
   Caused by: java.lang.IllegalArgumentException: class class 
org.apache.fory.Fory doesn't have method getRefResolver
        at 
org.apache.fory.reflect.ReflectionUtils.hasException(ReflectionUtils.java:244)
        at 
org.apache.fory.codegen.Expression$Invoke.<init>(Expression.java:1013)
        at org.apache.fory.codegen.Expression$Invoke.<init>(Expression.java:997)
        at org.apache.fory.codegen.Expression$Invoke.<init>(Expression.java:977)
        at 
org.apache.fory.builder.BaseObjectCodecBuilder.<init>(BaseObjectCodecBuilder.java:169)
        at 
org.apache.fory.builder.ObjectCodecBuilder.<init>(ObjectCodecBuilder.java:88)
        at 
org.apache.fory.builder.CodecUtils.loadOrGenObjectCodecClass(CodecUtils.java:43)
        at 
org.apache.fory.serializer.CodegenSerializer.loadCodegenSerializer(CodegenSerializer.java:49)
        ... 17 more
   ```
   </details>
   
   ### What did you expect to see?
   
   When the `Main` class does not extend `AbstractCollection/Map`, the native 
image serialization passes:
   
      ```console
      $ git checkout pass
      $ ./gradlew nativeCompile
      $ app/build/native/nativeCompile/test
      [0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
      ```
   
   And I expect making it extend `Collection/Map` should not lead to failures.
   
   ### What did you see instead?
   
   See the reproducer above for more stack traces and error messages.
   
   ```
   Exception in thread "main" java.lang.RuntimeException: Create sequential 
serializer failed, 
   class: class org.example.App
        at 
org.apache.fory.serializer.CodegenSerializer.loadCodegenSerializer(CodegenSerializer.java:52)
        at 
org.apache.fory.resolver.ClassResolver.lambda$getObjectSerializerClass$2(ClassResolver.java:1132)
        at 
org.apache.fory.builder.JITContext.registerSerializerJITCallback(JITContext.java:121)
        at 
org.apache.fory.resolver.ClassResolver.getObjectSerializerClass(ClassResolver.java:1130)
        at 
org.apache.fory.resolver.ClassResolver.getObjectSerializerClass(ClassResolver.java:1110)
   ```
   
   
   ### Anything Else?
   
   _No response_
   
   ### Are you willing to submit a PR?
   
   - [ ] I'm willing to submit a PR!


-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: [email protected]

For queries about this service, please contact Infrastructure at:
[email protected]


---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to