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

   ### Search before asking
   
   - [x] I had searched in the [issues](https://github.com/apache/fory/issues) 
and found no similar issues.
   
   
   ### Version
   
   latest
   
   ### Component(s)
   
   Java
   
   ### Minimal reproduce step
   
   ```java
   @Data
   static class MyExt {
     int id;
   
     public MyExt(int id) {
       this.id = id;
     }
   
     public MyExt() {}
   }
   
   private static class MyExtSerializer extends Serializer<MyExt> {
   
     public MyExtSerializer(Fory fory, Class<MyExt> cls) {
       super(fory, cls);
     }
   
     @Override
     public void write(MemoryBuffer buffer, MyExt value) {
       xwrite(buffer, value);
     }
   
     @Override
     public MyExt read(MemoryBuffer buffer) {
       return xread(buffer);
     }
   
     @Override
     public void xwrite(MemoryBuffer buffer, MyExt value) {
       fory.xwriteRef(buffer, value.id);
     }
   
     @SuppressWarnings("unchecked")
     @Override
     public MyExt xread(MemoryBuffer buffer) {
       MyExt obj = new MyExt();
       fory.getRefResolver().reference(obj);
       obj.id = (int) fory.xreadRef(buffer);
       return obj;
     }
   }
   
   @Data
   static class Wrapper {
     MyExt my_ext;
   }
   
   @Test
   public void testExt() {
     Fory fory =
         Fory.builder()
             .withLanguage(Language.XLANG)
             .withCompatibleMode(CompatibleMode.COMPATIBLE)
             .withCodegen(false)
             .build();
     fory.register(MyExt.class, 103);
     fory.registerSerializer(MyExt.class, MyExtSerializer.class);
     fory.register(Wrapper.class, 104);
     Wrapper wrapper = new Wrapper();
     MyExt myExt = new MyExt(42);
     wrapper.my_ext = myExt;
     byte[] serialize = fory.serialize(wrapper);
     Wrapper newWrapper = (Wrapper) fory.deserialize(serialize);
     Assert.assertEquals(wrapper, newWrapper);
   }
   ```
   
   ### What did you expect to see?
   
   pass test
   
   ### What did you see instead?
   
   ```
   
   org.apache.fory.exception.DeserializationException: Failed to deserialize 
input
   
        at 
org.apache.fory.util.ExceptionUtils.handleReadFailed(ExceptionUtils.java:66)
        at org.apache.fory.Fory.deserialize(Fory.java:889)
        at org.apache.fory.Fory.deserialize(Fory.java:785)
        at org.apache.fory.RustXlangTest.testExt(RustXlangTest.java:739)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at 
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
        at 
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:498)
        at 
org.testng.internal.invokers.MethodInvocationHelper.invokeMethod(MethodInvocationHelper.java:136)
        at 
org.testng.internal.invokers.TestInvoker.invokeMethod(TestInvoker.java:658)
        at 
org.testng.internal.invokers.TestInvoker.invokeTestMethod(TestInvoker.java:219)
        at 
org.testng.internal.invokers.MethodRunner.runInSequence(MethodRunner.java:50)
        at 
org.testng.internal.invokers.TestInvoker$MethodInvocationAgent.invoke(TestInvoker.java:923)
        at 
org.testng.internal.invokers.TestInvoker.invokeTestMethods(TestInvoker.java:192)
        at 
org.testng.internal.invokers.TestMethodWorker.invokeTestMethods(TestMethodWorker.java:146)
        at 
org.testng.internal.invokers.TestMethodWorker.run(TestMethodWorker.java:128)
        at java.util.ArrayList.forEach(ArrayList.java:1259)
        at org.testng.TestRunner.privateRun(TestRunner.java:808)
        at org.testng.TestRunner.run(TestRunner.java:603)
        at org.testng.SuiteRunner.runTest(SuiteRunner.java:429)
        at org.testng.SuiteRunner.runSequentially(SuiteRunner.java:423)
        at org.testng.SuiteRunner.privateRun(SuiteRunner.java:383)
        at org.testng.SuiteRunner.run(SuiteRunner.java:326)
        at org.testng.SuiteRunnerWorker.runSuite(SuiteRunnerWorker.java:52)
        at org.testng.SuiteRunnerWorker.run(SuiteRunnerWorker.java:95)
        at org.testng.TestNG.runSuitesSequentially(TestNG.java:1249)
        at org.testng.TestNG.runSuitesLocally(TestNG.java:1169)
        at org.testng.TestNG.runSuites(TestNG.java:1092)
        at org.testng.TestNG.run(TestNG.java:1060)
        at com.intellij.rt.testng.IDEARemoteTestNG.run(IDEARemoteTestNG.java:65)
        at 
com.intellij.rt.testng.RemoteTestNGStarter.main(RemoteTestNGStarter.java:105)
   Caused by: java.lang.IllegalStateException: Type id 26387 not registered
        at 
org.apache.fory.resolver.XtypeResolver.throwUnexpectTypeIdException(XtypeResolver.java:774)
        at 
org.apache.fory.resolver.XtypeResolver.readClassInfo(XtypeResolver.java:751)
        at org.apache.fory.Fory.xreadNonRef(Fory.java:1086)
        at 
org.apache.fory.serializer.SerializationBinding$XlangSerializationBinding.readNonRef(SerializationBinding.java:390)
        at 
org.apache.fory.serializer.AbstractObjectSerializer.readOtherFieldValue(AbstractObjectSerializer.java:140)
        at 
org.apache.fory.serializer.MetaSharedSerializer.read(MetaSharedSerializer.java:216)
        at 
org.apache.fory.serializer.MetaSharedSerializer.xread(MetaSharedSerializer.java:261)
        at org.apache.fory.Fory.xreadNonRef(Fory.java:1121)
        at org.apache.fory.Fory.xreadRef(Fory.java:1056)
        at org.apache.fory.Fory.deserialize(Fory.java:883)
        ... 29 more
   ```
   
   ### 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