This is an automated email from the ASF dual-hosted git repository.

albumenj pushed a commit to branch 3.2
in repository https://gitbox.apache.org/repos/asf/dubbo.git


The following commit(s) were added to refs/heads/3.2 by this push:
     new 35a6365d3f Fix ClassCastException caused by 2.x's filter in some 
condition (#12286)
35a6365d3f is described below

commit 35a6365d3f773a4452560458cef82a7dfdd4802d
Author: Xiang Wei Zhang <[email protected]>
AuthorDate: Wed May 17 14:25:09 2023 +0800

    Fix ClassCastException caused by 2.x's filter in some condition (#12286)
    
    * fix ClassCastException caused by 2.x's filter in some condition
    
    * compatible of RpcResult in dubbo version 2.x
    
    * extends AppResponse to make code better
    
    Co-authored-by: Albumen Kevin <[email protected]>
    
    * Add whenCompleteWithContext empty implement to compatible of 
FilterChainBuilder's invoke
    
    * Add license
    
    * Update compact
    
    * Fix 2.6's Filter return RpcResult handle as AsyncRpcResult
    
    When DubboProtocol.CompletableFuture running result.thenApply and  
FilterChainBuilder.CallbackRegistrationInvoker running 
asyncResult.whenCompleteWithContext. All Result handle as AsyncRpcResult, so 
RpcResult add some methods implements seems like AsyncRpcResult does.
    
    * revert last commit
    
    ---------
    
    Co-authored-by: Albumen Kevin <[email protected]>
---
 .../main/java/com/alibaba/dubbo/rpc/Filter.java    | 18 +++++++--
 .../main/java/com/alibaba/dubbo/rpc/Invoker.java   | 17 +++++++-
 .../main/java/com/alibaba/dubbo/rpc/Result.java    | 45 ++++++++--------------
 .../dubbo/rpc/{Filter.java => RpcResult.java}      | 22 ++++++-----
 .../java/org/apache/dubbo/filter/FilterTest.java   | 20 +++++++---
 .../org/apache/dubbo/filter/LegacyInvoker.java     |  6 +--
 .../java/org/apache/dubbo/filter/MyFilter.java     |  5 +++
 7 files changed, 81 insertions(+), 52 deletions(-)

diff --git a/dubbo-compatible/src/main/java/com/alibaba/dubbo/rpc/Filter.java 
b/dubbo-compatible/src/main/java/com/alibaba/dubbo/rpc/Filter.java
index 4ccde294e3..fa7b3e40a3 100644
--- a/dubbo-compatible/src/main/java/com/alibaba/dubbo/rpc/Filter.java
+++ b/dubbo-compatible/src/main/java/com/alibaba/dubbo/rpc/Filter.java
@@ -17,6 +17,8 @@
 
 package com.alibaba.dubbo.rpc;
 
+import org.apache.dubbo.rpc.AsyncRpcResult;
+
 @Deprecated
 public interface Filter extends org.apache.dubbo.rpc.Filter {
 
@@ -26,8 +28,18 @@ public interface Filter extends org.apache.dubbo.rpc.Filter {
     default org.apache.dubbo.rpc.Result invoke(org.apache.dubbo.rpc.Invoker<?> 
invoker,
                                                org.apache.dubbo.rpc.Invocation 
invocation)
             throws org.apache.dubbo.rpc.RpcException {
-        Result.CompatibleResult result = (Result.CompatibleResult) invoke(new 
Invoker.CompatibleInvoker<>(invoker),
-                new Invocation.CompatibleInvocation(invocation));
-        return result.getDelegate();
+        Result invokeResult = invoke(new Invoker.CompatibleInvoker<>(invoker),
+            new Invocation.CompatibleInvocation(invocation));
+
+        if (invokeResult instanceof Result.CompatibleResult) {
+            return invokeResult;
+        }
+
+        AsyncRpcResult asyncRpcResult = 
AsyncRpcResult.newDefaultAsyncResult(invocation);
+        asyncRpcResult.setValue(invokeResult.getValue());
+        asyncRpcResult.setException(invokeResult.getException());
+        
asyncRpcResult.setObjectAttachments(invokeResult.getObjectAttachments());
+
+        return asyncRpcResult;
     }
 }
diff --git a/dubbo-compatible/src/main/java/com/alibaba/dubbo/rpc/Invoker.java 
b/dubbo-compatible/src/main/java/com/alibaba/dubbo/rpc/Invoker.java
index 124b063de6..fc38498649 100644
--- a/dubbo-compatible/src/main/java/com/alibaba/dubbo/rpc/Invoker.java
+++ b/dubbo-compatible/src/main/java/com/alibaba/dubbo/rpc/Invoker.java
@@ -17,6 +17,8 @@
 
 package com.alibaba.dubbo.rpc;
 
+import org.apache.dubbo.rpc.AsyncRpcResult;
+
 import com.alibaba.dubbo.common.URL;
 
 @Deprecated
@@ -54,9 +56,22 @@ public interface Invoker<T> extends 
org.apache.dubbo.rpc.Invoker<T> {
         public org.apache.dubbo.rpc.Result 
invoke(org.apache.dubbo.rpc.Invocation invocation) throws 
org.apache.dubbo.rpc.RpcException {
             return new Result.CompatibleResult(invoker.invoke(invocation));
         }
-        
+
         @Override
         public Result invoke(Invocation invocation) throws RpcException {
+            if (invoker instanceof Invoker) {
+                Result result = ((Invoker) invoker).invoke(invocation);
+                if (result instanceof Result.CompatibleResult) {
+                    return result;
+                } else {
+                    AsyncRpcResult asyncRpcResult = 
AsyncRpcResult.newDefaultAsyncResult(invocation.getOriginal());
+                    asyncRpcResult.setValue(result.getValue());
+                    asyncRpcResult.setException(result.getException());
+                    
asyncRpcResult.setObjectAttachments(result.getObjectAttachments());
+
+                    return new Result.CompatibleResult(asyncRpcResult);
+                }
+            }
             return new 
Result.CompatibleResult(invoker.invoke(invocation.getOriginal()));
         }
 
diff --git a/dubbo-compatible/src/main/java/com/alibaba/dubbo/rpc/Result.java 
b/dubbo-compatible/src/main/java/com/alibaba/dubbo/rpc/Result.java
index 3a1da951c0..009ee707c2 100644
--- a/dubbo-compatible/src/main/java/com/alibaba/dubbo/rpc/Result.java
+++ b/dubbo-compatible/src/main/java/com/alibaba/dubbo/rpc/Result.java
@@ -64,35 +64,7 @@ public interface Result extends org.apache.dubbo.rpc.Result {
         return null;
     }
 
-    abstract class AbstractResult implements Result {
-
-        @Override
-        public void setValue(Object value) {
-
-        }
-
-        @Override
-        public org.apache.dubbo.rpc.Result 
whenCompleteWithContext(BiConsumer<org.apache.dubbo.rpc.Result, Throwable> fn) {
-            return null;
-        }
-
-        @Override
-        public <U> CompletableFuture<U> 
thenApply(Function<org.apache.dubbo.rpc.Result, ? extends U> fn) {
-            return null;
-        }
-
-        @Override
-        public org.apache.dubbo.rpc.Result get() throws InterruptedException, 
ExecutionException {
-            return null;
-        }
-
-        @Override
-        public org.apache.dubbo.rpc.Result get(long timeout, TimeUnit unit) 
throws InterruptedException, ExecutionException, TimeoutException {
-            return null;
-        }
-    }
-
-    class CompatibleResult extends AbstractResult {
+    class CompatibleResult implements Result {
         private org.apache.dubbo.rpc.Result delegate;
 
         public CompatibleResult(org.apache.dubbo.rpc.Result result) {
@@ -177,5 +149,20 @@ public interface Result extends 
org.apache.dubbo.rpc.Result {
         public void setObjectAttachment(String key, Object value) {
             delegate.setObjectAttachment(key, value);
         }
+
+        @Override
+        public <U> CompletableFuture<U> 
thenApply(Function<org.apache.dubbo.rpc.Result, ? extends U> fn) {
+            return delegate.thenApply(fn);
+        }
+
+        @Override
+        public org.apache.dubbo.rpc.Result get() throws InterruptedException, 
ExecutionException {
+            return delegate.get();
+        }
+
+        @Override
+        public org.apache.dubbo.rpc.Result get(long timeout, TimeUnit unit) 
throws InterruptedException, ExecutionException, TimeoutException {
+            return delegate.get(timeout, unit);
+        }
     }
 }
diff --git a/dubbo-compatible/src/main/java/com/alibaba/dubbo/rpc/Filter.java 
b/dubbo-compatible/src/main/java/com/alibaba/dubbo/rpc/RpcResult.java
similarity index 58%
copy from dubbo-compatible/src/main/java/com/alibaba/dubbo/rpc/Filter.java
copy to dubbo-compatible/src/main/java/com/alibaba/dubbo/rpc/RpcResult.java
index 4ccde294e3..d62eb09418 100644
--- a/dubbo-compatible/src/main/java/com/alibaba/dubbo/rpc/Filter.java
+++ b/dubbo-compatible/src/main/java/com/alibaba/dubbo/rpc/RpcResult.java
@@ -14,20 +14,22 @@
  * See the License for the specific language governing permissions and
  * limitations under the License.
  */
-
 package com.alibaba.dubbo.rpc;
 
+import org.apache.dubbo.rpc.AppResponse;
+
 @Deprecated
-public interface Filter extends org.apache.dubbo.rpc.Filter {
+public class RpcResult extends AppResponse implements 
com.alibaba.dubbo.rpc.Result {
+
+    public RpcResult() {
+    }
 
-    Result invoke(Invoker<?> invoker, Invocation invocation) throws 
RpcException;
+    public RpcResult(Object result) {
+        super(result);
+    }
 
-    @Override
-    default org.apache.dubbo.rpc.Result invoke(org.apache.dubbo.rpc.Invoker<?> 
invoker,
-                                               org.apache.dubbo.rpc.Invocation 
invocation)
-            throws org.apache.dubbo.rpc.RpcException {
-        Result.CompatibleResult result = (Result.CompatibleResult) invoke(new 
Invoker.CompatibleInvoker<>(invoker),
-                new Invocation.CompatibleInvocation(invocation));
-        return result.getDelegate();
+    public RpcResult(Throwable exception) {
+        super(exception);
     }
+
 }
diff --git 
a/dubbo-compatible/src/test/java/org/apache/dubbo/filter/FilterTest.java 
b/dubbo-compatible/src/test/java/org/apache/dubbo/filter/FilterTest.java
index e50d67d650..24996c2c32 100644
--- a/dubbo-compatible/src/test/java/org/apache/dubbo/filter/FilterTest.java
+++ b/dubbo-compatible/src/test/java/org/apache/dubbo/filter/FilterTest.java
@@ -18,11 +18,11 @@
 package org.apache.dubbo.filter;
 
 import org.apache.dubbo.rpc.RpcException;
+import org.apache.dubbo.rpc.RpcInvocation;
 
 import com.alibaba.dubbo.rpc.Filter;
 import com.alibaba.dubbo.rpc.Invocation;
 import com.alibaba.dubbo.rpc.Invoker;
-import com.alibaba.dubbo.rpc.Result;
 import org.junit.jupiter.api.AfterAll;
 import org.junit.jupiter.api.Assertions;
 import org.junit.jupiter.api.Test;
@@ -46,15 +46,23 @@ class FilterTest {
     }
 
     @Test
-    void testDefault() {
+    void testDefault() throws Throwable {
         Invoker<FilterTest> invoker = new LegacyInvoker<FilterTest>(null);
-        Invocation invocation = new LegacyInvocation("bbb");
-        Result res = myFilter.invoke(invoker, invocation);
-        System.out.println(res);
+        org.apache.dubbo.rpc.Invocation invocation = new RpcInvocation(null, 
"echo", "DemoService", "DemoService", new Class[]{String.class}, new 
Object[]{"bbb"});
+        org.apache.dubbo.rpc.Result res = myFilter.invoke(invoker, invocation);
+        Assertions.assertEquals("alibaba", res.recreate());
+    }
+
+    @Test
+    void testRecreate() throws Throwable {
+        Invoker<FilterTest> invoker = new LegacyInvoker<FilterTest>(null);
+        org.apache.dubbo.rpc.Invocation invocation = new RpcInvocation(null, 
"echo", "DemoService", "DemoService", new Class[]{String.class}, new 
Object[]{"cc"});
+        org.apache.dubbo.rpc.Result res = myFilter.invoke(invoker, invocation);
+        Assertions.assertEquals("123test", res.recreate());
     }
 
     @AfterAll
     public static void tear() {
-        Assertions.assertEquals(2, MyFilter.count);
+        Assertions.assertEquals(3, MyFilter.count);
     }
 }
diff --git 
a/dubbo-compatible/src/test/java/org/apache/dubbo/filter/LegacyInvoker.java 
b/dubbo-compatible/src/test/java/org/apache/dubbo/filter/LegacyInvoker.java
index b1d19b57c3..328b842321 100644
--- a/dubbo-compatible/src/test/java/org/apache/dubbo/filter/LegacyInvoker.java
+++ b/dubbo-compatible/src/test/java/org/apache/dubbo/filter/LegacyInvoker.java
@@ -17,7 +17,6 @@
 package org.apache.dubbo.filter;
 
 
-import org.apache.dubbo.rpc.AppResponse;
 import org.apache.dubbo.service.DemoService;
 
 import com.alibaba.dubbo.common.URL;
@@ -25,6 +24,7 @@ import com.alibaba.dubbo.rpc.Invocation;
 import com.alibaba.dubbo.rpc.Invoker;
 import com.alibaba.dubbo.rpc.Result;
 import com.alibaba.dubbo.rpc.RpcException;
+import com.alibaba.dubbo.rpc.RpcResult;
 
 public class LegacyInvoker<T> implements Invoker<T> {
 
@@ -58,13 +58,13 @@ public class LegacyInvoker<T> implements Invoker<T> {
     }
 
     public Result invoke(Invocation invocation) throws RpcException {
-        AppResponse result = new AppResponse();
+        RpcResult result = new RpcResult();
         if (!hasException) {
             result.setValue("alibaba");
         } else {
             result.setException(new RuntimeException("mocked exception"));
         }
-        return new Result.CompatibleResult(result);
+        return result;
     }
 
     @Override
diff --git 
a/dubbo-compatible/src/test/java/org/apache/dubbo/filter/MyFilter.java 
b/dubbo-compatible/src/test/java/org/apache/dubbo/filter/MyFilter.java
index b7d7e24e70..68c5c8786b 100644
--- a/dubbo-compatible/src/test/java/org/apache/dubbo/filter/MyFilter.java
+++ b/dubbo-compatible/src/test/java/org/apache/dubbo/filter/MyFilter.java
@@ -22,6 +22,7 @@ import com.alibaba.dubbo.rpc.Invocation;
 import com.alibaba.dubbo.rpc.Invoker;
 import com.alibaba.dubbo.rpc.Result;
 import com.alibaba.dubbo.rpc.RpcException;
+import com.alibaba.dubbo.rpc.RpcResult;
 
 
 public class MyFilter implements Filter {
@@ -36,6 +37,10 @@ public class MyFilter implements Filter {
             throw new RpcException(new IllegalArgumentException("arg0 
illegal"));
         }
 
+        if (invocation.getArguments()[0].equals("cc")) {
+            return new RpcResult("123test");
+        }
+
         Result tmp = invoker.invoke(invocation);
         return tmp;
     }

Reply via email to