summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/test/javassist/JvstTest.java1
-rw-r--r--src/test/test/javassist/proxy/Foo.java16
-rw-r--r--src/test/test/javassist/proxy/JBPAPP9257Test.java65
3 files changed, 82 insertions, 0 deletions
diff --git a/src/test/javassist/JvstTest.java b/src/test/javassist/JvstTest.java
index f646506b..16d91390 100644
--- a/src/test/javassist/JvstTest.java
+++ b/src/test/javassist/JvstTest.java
@@ -1122,6 +1122,7 @@ public class JvstTest extends JvstTestRoot {
suite.addTestSuite(test.javassist.proxy.ProxySerializationTest.class);
suite.addTestSuite(test.javassist.convert.ArrayAccessReplaceTest.class);
suite.addTestSuite(test.javassist.proxy.JASSIST113RegressionTest.class);
+ suite.addTestSuite(test.javassist.proxy.JBPAPP9257Test.class);
//suite.addTestSuite(test.javassist.proxy.ProxyCacheGCTest.class);
suite.addTestSuite(test.javassist.proxy.ProxyFactoryCompatibilityTest.class);
suite.addTestSuite(test.javassist.proxy.ProxySerializationTest.class);
diff --git a/src/test/test/javassist/proxy/Foo.java b/src/test/test/javassist/proxy/Foo.java
new file mode 100644
index 00000000..fd9e6e3b
--- /dev/null
+++ b/src/test/test/javassist/proxy/Foo.java
@@ -0,0 +1,16 @@
+package test.javassist.proxy;
+
+public class Foo {
+ public String doSomething() {
+ return "I'm doing something";
+ }
+
+ public Object getHandler() {
+ return "This is a secret handler";
+ }
+}
+
+class Foo2 {
+ public String doSomething() { return "do something"; }
+ public String getHandler() { return "return a string"; }
+} \ No newline at end of file
diff --git a/src/test/test/javassist/proxy/JBPAPP9257Test.java b/src/test/test/javassist/proxy/JBPAPP9257Test.java
new file mode 100644
index 00000000..0de07298
--- /dev/null
+++ b/src/test/test/javassist/proxy/JBPAPP9257Test.java
@@ -0,0 +1,65 @@
+package test.javassist.proxy;
+
+import java.lang.reflect.Method;
+import javassist.util.proxy.ProxyFactory;
+import javassist.util.proxy.MethodHandler;
+import javassist.util.proxy.MethodFilter;
+import javassist.util.proxy.ProxyObject;
+import javassist.util.proxy.Proxy;
+import junit.framework.TestCase;
+
+public class JBPAPP9257Test extends TestCase {
+ public void testGetHandler() throws Exception {
+ ProxyFactory f = new ProxyFactory();
+ f.setSuperclass(Foo.class);
+ f.setFilter(new MethodFilter() {
+ public boolean isHandled(Method m) {
+ // ignore finalize()
+ return !m.getName().equals("finalize");
+ }
+ });
+ Class c = f.createClass();
+ MethodHandler mi = new MethodHandler() {
+ public Object invoke(Object self, Method m, Method proceed,
+ Object[] args) throws Throwable {
+ System.out.println("Name: " + m.getName());
+ return proceed.invoke(self, args) + "!"; // execute the original
+ // method.
+ }
+ };
+ Foo foo = (Foo) c.newInstance();
+ try {
+ ((ProxyObject)foo).setHandler(mi);
+ fail("foo is a ProxyObject!");
+ } catch (ClassCastException e) {}
+ ((Proxy)foo).setHandler(mi);
+ assertEquals("I'm doing something!", foo.doSomething());
+ }
+
+ public void testGetHandler2() throws Exception {
+ ProxyFactory f = new ProxyFactory();
+ f.setSuperclass(Foo2.class);
+ f.setFilter(new MethodFilter() {
+ public boolean isHandled(Method m) {
+ // ignore finalize()
+ return !m.getName().equals("finalize");
+ }
+ });
+ Class c = f.createClass();
+ MethodHandler mi = new MethodHandler() {
+ public Object invoke(Object self, Method m, Method proceed,
+ Object[] args) throws Throwable {
+ System.out.println("Name: " + m.getName());
+ return proceed.invoke(self, args) + "!"; // execute the original
+ // method.
+ }
+ };
+ Foo2 foo = (Foo2)c.newInstance();
+ try {
+ ((ProxyObject)foo).setHandler(mi);
+ fail("foo is a ProxyObject!");
+ } catch (ClassCastException e) {}
+ ((Proxy)foo).setHandler(mi);
+ assertEquals("do something!", foo.doSomething());
+ }
+}