aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--loadtime/testsrc/org/aspectj/weaver/loadtime/ClassLoaderWeavingAdaptorTest.java823
1 files changed, 517 insertions, 306 deletions
diff --git a/loadtime/testsrc/org/aspectj/weaver/loadtime/ClassLoaderWeavingAdaptorTest.java b/loadtime/testsrc/org/aspectj/weaver/loadtime/ClassLoaderWeavingAdaptorTest.java
index 3a4909898..d222d0140 100644
--- a/loadtime/testsrc/org/aspectj/weaver/loadtime/ClassLoaderWeavingAdaptorTest.java
+++ b/loadtime/testsrc/org/aspectj/weaver/loadtime/ClassLoaderWeavingAdaptorTest.java
@@ -66,312 +66,506 @@ public class ClassLoaderWeavingAdaptorTest extends TestCase {
/**
* Testing fast excludes of the pattern "com.foo..*". World should not have any new types in it after rejection.
*/
-// public void testFastExclusionOne() throws Exception {
-// TestClassLoaderWeavingAdaptor adaptor = getAdaptor(null, "testdata..*");
-//
-// String orangesSub = "testdata.sub.Oranges";
-// JavaClass orangesClass = getClassFrom(orangesSub);
-// byte[] orangesBytes = orangesClass.getBytes();
-//
-// boolean accepted = adaptor.accept(orangesSub, orangesBytes);
-// assertFalse("Should not be accepted", accepted);
-// TypeMap map = accessTypeMap(adaptor);
-//
-// // The aspect
-// assertEquals(1, map.getExpendableMap().size());
-//
-// // primitives, void and jlObject
-// assertEquals(10, map.getMainMap().size());
-//
-// // Important thing here is that the rejection of testdata.sub.Oranges did not require it to be loaded into the world at all
-// }
-//
-// /**
-// * Testing fast includes of the pattern "*". World should not have any new types in it after inclusion.
-// */
-// public void testFastInclusionOne() throws Exception {
-// TestClassLoaderWeavingAdaptor adaptor = getAdaptor("*", null);
-//
-// String orangesSub = "testdata.sub.Oranges";
-// JavaClass orangesClass = getClassFrom(orangesSub);
-// byte[] orangesBytes = orangesClass.getBytes();
-//
-// boolean accepted = adaptor.accept(orangesSub, orangesBytes);
-// assertTrue("Should be accepted", accepted);
-// TypeMap map = accessTypeMap(adaptor);
-//
-// // The aspect
-// assertEquals(1, map.getExpendableMap().size());
-//
-// // primitives, void and jlObject
-// assertEquals(10, map.getMainMap().size());
-//
-// // Important thing here is that the rejection of testdata.sub.Oranges did not require it to be loaded into the world at all
-// }
-//
-// /**
-// * Testing fast excludes of the pattern "*Oranges". World should not have any new types in it after rejection.
-// */
-// public void testFastExclusionTwo() throws Exception {
-// TestClassLoaderWeavingAdaptor adaptor = getAdaptor(null, "*Oranges");
-//
-// String oranges = "testdata.Oranges";
-// JavaClass orangesClass = getClassFrom(oranges);
-// byte[] orangesBytes = orangesClass.getBytes();
-//
-// boolean accepted = adaptor.accept(oranges, orangesBytes);
-// assertFalse("Should not be accepted", accepted);
-// TypeMap map = accessTypeMap(adaptor);
-//
-// // The aspect
-// assertEquals(1, map.getExpendableMap().size());
-// // primitives, void and jlObject
-// assertEquals(10, map.getMainMap().size());
-//
-// String orangesSub = "testdata.sub.Oranges";
-//
-// JavaClass orangesSubClass = getClassFrom(orangesSub);
-// byte[] orangesSubBytes = orangesSubClass.getBytes();
-//
-// accepted = adaptor.accept(orangesSub, orangesSubBytes);
-// assertFalse("Should not be accepted", accepted);
-// map = accessTypeMap(adaptor);
-//
-// // The aspect
-// assertEquals(1, map.getExpendableMap().size());
-// // primitives, void and jlObject
-// assertEquals(10, map.getMainMap().size());
-// }
-//
-// /**
-// * Testing fast excludes of the pattern "*..*Oranges*". World should not have any new types in it after rejection.
-// */
-// public void testFastExclusionThree() throws Exception {
-// TestClassLoaderWeavingAdaptor adaptor = getAdaptor(null, "*..*ran*");
-//
-// String oranges = "testdata.Oranges";
-// JavaClass orangesClass = getClassFrom(oranges);
-// byte[] orangesBytes = orangesClass.getBytes();
-//
-// boolean accepted = adaptor.accept(oranges, orangesBytes);
-// assertFalse("Should not be accepted", accepted);
-// TypeMap map = accessTypeMap(adaptor);
-//
-// // The aspect
-// assertEquals(1, map.getExpendableMap().size());
-//
-// // primitives, void and jlObject
-// assertEquals(10, map.getMainMap().size());
-//
-// String orangesSub = "testdata.sub.Oranges";
-// JavaClass orangesSubClass = getClassFrom(orangesSub);
-// byte[] orangesSubBytes = orangesSubClass.getBytes();
-//
-// accepted = adaptor.accept(orangesSub, orangesSubBytes);
-// assertFalse("Should not be accepted", accepted);
-// map = accessTypeMap(adaptor);
-//
-// // The aspect
-// assertEquals(1, map.getExpendableMap().size());
-// // primitives, void and jlObject
-// assertEquals(10, map.getMainMap().size());
-//
-// String apples = "testdata.Apples";
-// JavaClass applesClass = getClassFrom(apples);
-// byte[] applesBytes = applesClass.getBytes();
-//
-// accepted = adaptor.accept(apples, applesBytes);
-// assertTrue("Should be accepted", accepted);
-// map = accessTypeMap(adaptor);
-//
-// // The aspect and the Apples type
-// assertEquals(1, map.getExpendableMap().size());
-// // primitives, void and jlObject
-// assertEquals(10, map.getMainMap().size());
-// }
-//
-// /**
-// * Testing fast inclusion checking of exact include names eg. "testdata.sub.Oranges"
-// */
-// public void testFastInclusionTwo() throws Exception {
-// TestClassLoaderWeavingAdaptor adaptor = getAdaptor("testdata.sub.Oranges", null);
-//
-// String oranges = "testdata.Oranges";
-// JavaClass orangesClass = getClassFrom(oranges);
-// byte[] orangesBytes = orangesClass.getBytes();
-//
-// boolean accepted = adaptor.accept(oranges, orangesBytes);
-// assertFalse("Should not be accepted", accepted);
-// TypeMap map = accessTypeMap(adaptor);
-//
-// // The aspect
-// assertEquals(1, map.getExpendableMap().size());
-//
-// // primitives, void and jlObject
-// assertEquals(10, map.getMainMap().size());
-//
-// String orangesSub = "testdata.sub.Oranges";
-// JavaClass orangesSubClass = getClassFrom(orangesSub);
-// byte[] orangesSubBytes = orangesSubClass.getBytes();
-//
-// accepted = adaptor.accept(orangesSub, orangesSubBytes);
-// assertTrue("Should be accepted", accepted);
-// map = accessTypeMap(adaptor);
-//
-// // The aspect
-// assertEquals(1, map.getExpendableMap().size());
-// // primitives, void and jlObject
-// assertEquals(10, map.getMainMap().size());
-//
-// String apples = "testdata.Apples";
-// JavaClass applesClass = getClassFrom(apples);
-// byte[] applesBytes = applesClass.getBytes();
-//
-// accepted = adaptor.accept(apples, applesBytes);
-// assertFalse("Should not be accepted", accepted);
-// map = accessTypeMap(adaptor);
-//
-// // The aspect and the Apples type
-// assertEquals(1, map.getExpendableMap().size());
-// // primitives, void and jlObject
-// assertEquals(10, map.getMainMap().size());
-// }
-//
-// /**
-// * Testing fast excludes of the pattern groovy related pattern -
-// */
-// // public void testFastExclusionFour() throws Exception {
-// // TestClassLoaderWeavingAdaptor adaptor = getAdaptor("*", "testdata..* && !testdata.sub.Oran*");
-// //
-// // String oranges = "testdata.Oranges";
-// // JavaClass orangesClass = getClassFrom(oranges);
-// // byte[] orangesBytes = orangesClass.getBytes();
-// //
-// // boolean accepted = adaptor.accept(oranges, orangesBytes);
-// // assertFalse("Should not be accepted", accepted);
-// // TypeMap map = accessTypeMap(adaptor);
-// //
-// // // The aspect
-// // assertEquals(1, map.getExpendableMap().size());
-// //
-// // // primitives, void and jlObject
-// // assertEquals(10, map.getMainMap().size());
-// //
-// // String orangesSub = "testdata.sub.Oranges";
-// // JavaClass orangesSubClass = getClassFrom(orangesSub);
-// // byte[] orangesSubBytes = orangesSubClass.getBytes();
-// //
-// // accepted = adaptor.accept(orangesSub, orangesSubBytes);
-// // assertTrue("Should be accepted", accepted);
-// // map = accessTypeMap(adaptor);
-// //
-// // // The aspect
-// // assertEquals(1, map.getExpendableMap().size());
-// // // primitives, void and jlObject
-// // assertEquals(10, map.getMainMap().size());
-// // }
-//
-// public void testAcceptanceSpeedStarDotDotStar() throws Exception {
-// URLClassLoader loader = new URLClassLoader(new URL[] { new File("../loadtime/bin").toURI().toURL() }, null);
-//
-// JavaClass jc = getClassFrom("../loadtime/bin", "org.aspectj.weaver.loadtime.ClassLoaderWeavingAdaptorTest$TestOne");
-// byte[] bs = jc.getBytes();
-// jc = getClassFrom("../loadtime/bin", "org.aspectj.weaver.loadtime.ClassLoaderWeavingAdaptorTest$TestOneCGLIB");
-// byte[] bs2 = jc.getBytes();
-// // InputStream is = loader.getResourceAsStream("org.aspectj.weaver.loadtime.ClassLoaderWeaverAdaptorTests$TestOne");
-// assertNotNull(bs);
-// TestWeavingContext wc = new TestWeavingContext(loader);
-// Definition d = new Definition();
-// d.getExcludePatterns().add("*..*CGLIB*");
-// d.getAspectClassNames().add("org.aspectj.weaver.loadtime.ClassLoaderWeavingAdaptorTest$AnAspect");
-// wc.addDefinition(d);
-// ClassLoaderWeavingAdaptor adaptor = new ClassLoaderWeavingAdaptor();
-// adaptor.initialize(loader, wc);
-// boolean exist = adaptor.generatedClassesExistFor("Junk");
-// assertFalse("There should be no generated classes", exist);
-//
-// // before:
-// // Acceptance 331ms
-// // Rejection 3368ms
-//
-// // after:
-// // Acceptance 343ms
-// // Rejection 80ms
-//
-// long stime = System.currentTimeMillis();
-// for (int i = 0; i < 100000; i++) {
-// boolean b = adaptor.accept("org.aspectj.weaver.loadtime.ClassLoaderWeavingAdaptorTest$TestOne", bs);
-// assertTrue("Should be accepted", b);
-// }
-// long etime = System.currentTimeMillis();
-// System.out.println("Acceptance " + (etime - stime) + "ms");
-// stime = System.currentTimeMillis();
-// for (int i = 0; i < 100000; i++) {
-// adaptor.delegateForCurrentClass = null;
-// boolean b = adaptor.accept("org.aspectj.weaver.loadtime.ClassLoaderWeavingAdaptorTest$TestOneCGLIB", bs2);
-// assertFalse("Should not be accepting CGLIB", b);
-// }
-// etime = System.currentTimeMillis();
-// System.out.println("Rejection " + (etime - stime) + "ms");
-//
-// }
-//
-// // TODO
-// // shouldn't add it to the type patterns if we are going to fast handle it
-// // include for exact name, what does it mean?
-// // excludes="!xxxx" should also be fast matched...
-//
-// public void testAcceptanceSpeedExactName() throws Exception {
-// URLClassLoader loader = new URLClassLoader(new URL[] { new File("../loadtime/bin").toURI().toURL() }, null);
-//
-// JavaClass jc = getClassFrom("../loadtime/bin", "org.aspectj.weaver.loadtime.ClassLoaderWeavingAdaptorTest$TestOne");
-// byte[] bs = jc.getBytes();
-// jc = getClassFrom("../loadtime/bin", "org.aspectj.weaver.loadtime.ClassLoaderWeavingAdaptorTest$TestOneCGLIB");
-// byte[] bs2 = jc.getBytes();
-// // InputStream is = loader.getResourceAsStream("org.aspectj.weaver.loadtime.ClassLoaderWeaverAdaptorTests$TestOne");
-// assertNotNull(bs);
-// TestWeavingContext wc = new TestWeavingContext(loader);
-// Definition d = new Definition();
-// d.getExcludePatterns().add("org.aspectj.weaver.loadtime.ClassLoaderWeavingAdaptorTest.TestOneCGLIB");
-// d.getAspectClassNames().add("org.aspectj.weaver.loadtime.ClassLoaderWeavingAdaptorTest$AnAspect");
-// wc.addDefinition(d);
-// TestClassLoaderWeavingAdaptor adaptor = new TestClassLoaderWeavingAdaptor();
-// adaptor.initialize(loader, wc);
-// boolean exist = adaptor.generatedClassesExistFor("Junk");
-// assertFalse("There should be no generated classes", exist);
-//
-// // before:
-// // Acceptance 331ms
-// // Rejection 3160ms
-//
-// // after:
-// // Acceptance 379ms
-// // Rejection 103ms
-//
-// long stime = System.currentTimeMillis();
-// for (int i = 0; i < 100000; i++) {
-// boolean b = adaptor.accept("org.aspectj.weaver.loadtime.ClassLoaderWeavingAdaptorTest$TestOne", bs);
-// assertTrue("Should be accepted", b);
-// }
-// long etime = System.currentTimeMillis();
-// System.out.println("Acceptance " + (etime - stime) + "ms");
-// stime = System.currentTimeMillis();
-// for (int i = 0; i < 100000; i++) {
-// adaptor.delegateForCurrentClass = null;
-// boolean b = adaptor.accept("org.aspectj.weaver.loadtime.ClassLoaderWeavingAdaptorTest$TestOneCGLIB", bs2);
-// assertFalse("Should not be accepting CGLIB", b);
-// }
-// etime = System.currentTimeMillis();
-// System.out.println("Rejection " + (etime - stime) + "ms");
-// BcelWorld world = adaptor.getWorld();
-// Field f = World.class.getDeclaredField("typeMap");
-// f.setAccessible(true);
-// TypeMap typeMap = (TypeMap) f.get(world);
-// System.out.println(typeMap.getExpendableMap().size());
-// System.out.println(typeMap.getMainMap().size());
-// printExpendableMap(typeMap.getExpendableMap());
-// printMainMap(typeMap.getMainMap());
-// }
+ public void testFastExclusionOne() throws Exception {
+ TestClassLoaderWeavingAdaptor adaptor = getAdaptor(null, "testdata..*");
+
+ String orangesSub = "testdata.sub.Oranges";
+ JavaClass orangesClass = getClassFrom(orangesSub);
+ byte[] orangesBytes = orangesClass.getBytes();
+
+ boolean accepted = adaptor.accept(orangesSub, orangesBytes);
+ assertFalse("Should not be accepted", accepted);
+ TypeMap map = accessTypeMap(adaptor);
+
+ // The aspect
+ assertEquals(1, map.getExpendableMap().size());
+
+ // primitives, void and jlObject
+ assertEquals(10, map.getMainMap().size());
+
+ // Important thing here is that the rejection of testdata.sub.Oranges did not require it to be loaded into the world at all
+ }
+
+ /**
+ * Testing fast includes of the pattern "*". World should not have any new types in it after inclusion.
+ */
+ public void testFastInclusionOne() throws Exception {
+ TestClassLoaderWeavingAdaptor adaptor = getAdaptor("*", null);
+
+ String orangesSub = "testdata.sub.Oranges";
+ JavaClass orangesClass = getClassFrom(orangesSub);
+ byte[] orangesBytes = orangesClass.getBytes();
+
+ boolean accepted = adaptor.accept(orangesSub, orangesBytes);
+ assertTrue("Should be accepted", accepted);
+ TypeMap map = accessTypeMap(adaptor);
+
+ // The aspect
+ assertEquals(1, map.getExpendableMap().size());
+
+ // primitives, void and jlObject
+ assertEquals(10, map.getMainMap().size());
+
+ // Important thing here is that the rejection of testdata.sub.Oranges did not require it to be loaded into the world at all
+ }
+
+ /**
+ * Testing fast excludes of the pattern "*Oranges". World should not have any new types in it after rejection.
+ */
+ public void testFastExclusionTwo() throws Exception {
+ TestClassLoaderWeavingAdaptor adaptor = getAdaptor(null, "*Oranges");
+
+ String oranges = "testdata.Oranges";
+ JavaClass orangesClass = getClassFrom(oranges);
+ byte[] orangesBytes = orangesClass.getBytes();
+
+ boolean accepted = adaptor.accept(oranges, orangesBytes);
+ assertFalse("Should not be accepted", accepted);
+ TypeMap map = accessTypeMap(adaptor);
+
+ // The aspect
+ assertEquals(1, map.getExpendableMap().size());
+ // primitives, void and jlObject
+ assertEquals(10, map.getMainMap().size());
+
+ String orangesSub = "testdata.sub.Oranges";
+
+ JavaClass orangesSubClass = getClassFrom(orangesSub);
+ byte[] orangesSubBytes = orangesSubClass.getBytes();
+
+ accepted = adaptor.accept(orangesSub, orangesSubBytes);
+ assertFalse("Should not be accepted", accepted);
+ map = accessTypeMap(adaptor);
+
+ // The aspect
+ assertEquals(1, map.getExpendableMap().size());
+ // primitives, void and jlObject
+ assertEquals(10, map.getMainMap().size());
+ }
+
+ /**
+ * Testing fast excludes of the pattern "*..*Oranges*". World should not have any new types in it after rejection.
+ */
+ public void testFastExclusionThree() throws Exception {
+ TestClassLoaderWeavingAdaptor adaptor = getAdaptor(null, "*..*ran*");
+
+ String oranges = "testdata.Oranges";
+ JavaClass orangesClass = getClassFrom(oranges);
+ byte[] orangesBytes = orangesClass.getBytes();
+
+ boolean accepted = adaptor.accept(oranges, orangesBytes);
+ assertFalse("Should not be accepted", accepted);
+ TypeMap map = accessTypeMap(adaptor);
+
+ // The aspect
+ assertEquals(1, map.getExpendableMap().size());
+
+ // primitives, void and jlObject
+ assertEquals(10, map.getMainMap().size());
+
+ String orangesSub = "testdata.sub.Oranges";
+ JavaClass orangesSubClass = getClassFrom(orangesSub);
+ byte[] orangesSubBytes = orangesSubClass.getBytes();
+
+ accepted = adaptor.accept(orangesSub, orangesSubBytes);
+ assertFalse("Should not be accepted", accepted);
+ map = accessTypeMap(adaptor);
+
+ // The aspect
+ assertEquals(1, map.getExpendableMap().size());
+ // primitives, void and jlObject
+ assertEquals(10, map.getMainMap().size());
+
+ String apples = "testdata.Apples";
+ JavaClass applesClass = getClassFrom(apples);
+ byte[] applesBytes = applesClass.getBytes();
+
+ accepted = adaptor.accept(apples, applesBytes);
+ assertTrue("Should be accepted", accepted);
+ map = accessTypeMap(adaptor);
+
+ // The aspect and the Apples type
+ assertEquals(1, map.getExpendableMap().size());
+ // primitives, void and jlObject
+ assertEquals(10, map.getMainMap().size());
+ }
+
+ public void testIncludedWhenNonOptimalExclusion() throws Exception {
+ TestClassLoaderWeavingAdaptor adaptor = getAdaptor(new String[] { "*", "FooBar" }, new String[] { "*..*ran*es*" });
+
+ String oranges = "testdata.Oranges";
+ JavaClass orangesClass = getClassFrom(oranges);
+ byte[] orangesBytes = orangesClass.getBytes();
+
+ boolean accepted = false;
+ // adaptor.accept(oranges, orangesBytes);
+ // assertFalse("Should not be accepted", accepted);
+ TypeMap map = accessTypeMap(adaptor);
+
+ // // The aspect
+ // assertEquals(1, map.getExpendableMap().size());
+
+ // primitives, void and jlObject
+ assertEquals(10, map.getMainMap().size());
+
+ String apples = "testdata.Apples";
+ JavaClass applesClass = getClassFrom(apples);
+ byte[] applesBytes = applesClass.getBytes();
+
+ accepted = adaptor.accept(apples, applesBytes);
+ assertTrue("Should be accepted", accepted);
+ map = accessTypeMap(adaptor);
+
+ // // The aspect
+ // assertEquals(1, map.getExpendableMap().size());
+ // // primitives, void and jlObject
+ // assertEquals(10, map.getMainMap().size());
+ //
+ // String apples = "testdata.Apples";
+ // JavaClass applesClass = getClassFrom(apples);
+ // byte[] applesBytes = applesClass.getBytes();
+ //
+ // accepted = adaptor.accept(apples, applesBytes);
+ // assertTrue("Should be accepted", accepted);
+ // map = accessTypeMap(adaptor);
+ //
+ // // The aspect and the Apples type
+ // assertEquals(1, map.getExpendableMap().size());
+ // // primitives, void and jlObject
+ // assertEquals(10, map.getMainMap().size());
+ }
+
+ private void checkAccept(ClassLoaderWeavingAdaptor adaptor, String name) throws Exception {
+ JavaClass clazz = getClassFrom(name);
+ byte[] bytes = clazz.getBytes();
+
+ boolean accepted = adaptor.accept(name, bytes);
+ assertTrue("Should be accepted", accepted);
+ }
+
+ private void checkNotAccept(ClassLoaderWeavingAdaptor adaptor, String name) throws Exception {
+ JavaClass clazz = getClassFrom(name);
+ byte[] bytes = clazz.getBytes();
+
+ boolean accepted = adaptor.accept(name, bytes);
+ assertFalse("Should not be accepted", accepted);
+ }
+
+ /**
+ * Test how multiple definitions are merged. Each Definition represents a different aop.xml file.
+ */
+ public void testIncludedWhenNonOptimalExclusion2() throws Exception {
+ Definition aopOne = new Definition();
+ aopOne.getIncludePatterns().add("*");
+
+ Definition aopTwo = new Definition();
+ aopTwo.getIncludePatterns().add("testdata.Apples+");
+
+ TestClassLoaderWeavingAdaptor adaptor = getAdaptor(aopOne, aopTwo);
+
+ checkAccept(adaptor, "testdata.Oranges");
+ checkAccept(adaptor, "testdata.Apples");
+
+ adaptor = getAdaptor(aopTwo, aopOne);
+
+ checkAccept(adaptor, "testdata.Oranges");
+ checkAccept(adaptor, "testdata.Apples");
+ }
+
+ public void testIncludedWhenNonOptimalExclusion3() throws Exception {
+ Definition aopOne = new Definition();
+ aopOne.getIncludePatterns().add("*");
+
+ Definition aopTwo = new Definition();
+ aopTwo.getIncludePatterns().add("java.sql.Connection+");
+ aopTwo.getIncludePatterns().add("java.sql.Statement+");
+
+ TestClassLoaderWeavingAdaptor adaptor = getAdaptor(aopOne, aopTwo);
+
+ checkAccept(adaptor, "testdata.Apples");
+ checkAccept(adaptor, "testdata.MySqlStatement");
+
+ adaptor = getAdaptor(aopTwo, aopOne);
+
+ checkAccept(adaptor, "testdata.Apples");
+ checkAccept(adaptor, "testdata.MySqlStatement");
+ }
+
+ // Some excludes defined and some includes but importantly a star include
+ public void testIncludedWhenNonOptimalExclusion4() throws Exception {
+ Definition aopOne = new Definition();
+ aopOne.getIncludePatterns().add("*");
+
+ Definition aopTwo = new Definition();
+ aopTwo.getIncludePatterns().add("java.sql.Connection+");
+ aopTwo.getIncludePatterns().add("java.sql.Statement+");
+
+ Definition aopThree = new Definition();
+ aopThree.getExcludePatterns().add("com.jinspired..*");
+ aopThree.getExcludePatterns().add("$com.jinspired..*");
+ aopThree.getExcludePatterns().add("com.jinspired.jxinsight.server..*+");
+
+ TestClassLoaderWeavingAdaptor adaptor = getAdaptor(aopOne, aopTwo, aopThree);
+
+ checkAccept(adaptor, "testdata.Apples");
+ checkAccept(adaptor, "testdata.MySqlStatement");
+
+ adaptor = getAdaptor(aopThree, aopTwo, aopOne);
+
+ checkAccept(adaptor, "testdata.Apples");
+ checkAccept(adaptor, "testdata.MySqlStatement");
+ }
+
+ // Some excludes defined and some includes but importantly an exact includename
+ public void testIncludedWhenNonOptimalExclusion5() throws Exception {
+ Definition aopOne = new Definition();
+ aopOne.getIncludePatterns().add("testdata.Apples");
+
+ Definition aopTwo = new Definition();
+ aopTwo.getIncludePatterns().add("java.sql.Connection+");
+ aopTwo.getIncludePatterns().add("java.sql.Statement+");
+
+ Definition aopThree = new Definition();
+ aopThree.getExcludePatterns().add("com.jinspired..*");
+ aopThree.getExcludePatterns().add("$com.jinspired..*");
+ aopThree.getExcludePatterns().add("com.jinspired.jxinsight.server..*+");
+
+ TestClassLoaderWeavingAdaptor adaptor = getAdaptor(aopOne, aopTwo, aopThree);
+
+ checkAccept(adaptor, "testdata.Apples");
+
+ adaptor = getAdaptor(aopThree, aopTwo, aopOne);
+
+ checkAccept(adaptor, "testdata.Apples");
+ }
+
+ public void testIncludedWhenNonOptimalExclusion7() throws Exception {
+ Definition aopOne = new Definition();
+ aopOne.getIncludePatterns().add("*");
+ aopOne.getExcludePatterns().add("*Fun*ky*");
+
+ // Definition aopTwo = new Definition();
+ // aopTwo.getIncludePatterns().add("java.sql.Connection+");
+ // aopTwo.getIncludePatterns().add("java.sql.Statement+");
+ //
+ // Definition aopThree = new Definition();
+ // aopThree.getExcludePatterns().add("com.jinspired..*");
+ // aopThree.getExcludePatterns().add("$com.jinspired..*");
+ // aopThree.getExcludePatterns().add("com.jinspired.jxinsight.server..*+");
+
+ TestClassLoaderWeavingAdaptor adaptor = getAdaptor(aopOne);
+
+ checkAccept(adaptor, "testdata.Apples");
+
+ // adaptor = getAdaptor(aopThree, aopTwo, aopOne);
+ //
+ // checkAccept(adaptor, "testdata.Apples");
+ }
+
+ public void testIncludedWhenNonOptimalExclusion6() throws Exception {
+ Definition aopOne = new Definition();
+ aopOne.getIncludePatterns().add("testdata..*");
+
+ Definition aopTwo = new Definition();
+ aopTwo.getIncludePatterns().add("java.sql.Connection+");
+ aopTwo.getIncludePatterns().add("java.sql.Statement+");
+
+ Definition aopThree = new Definition();
+ aopThree.getExcludePatterns().add("com.jinspired..*");
+ aopThree.getExcludePatterns().add("$com.jinspired..*");
+ aopThree.getExcludePatterns().add("com.jinspired.jxinsight.server..*+");
+
+ TestClassLoaderWeavingAdaptor adaptor = getAdaptor(aopOne, aopTwo, aopThree);
+
+ checkAccept(adaptor, "testdata.Apples");
+
+ adaptor = getAdaptor(aopThree, aopTwo, aopOne);
+
+ checkAccept(adaptor, "testdata.Apples");
+ }
+
+ /**
+ * Testing fast inclusion checking of exact include names eg. "testdata.sub.Oranges"
+ */
+ public void testFastInclusionTwo() throws Exception {
+ TestClassLoaderWeavingAdaptor adaptor = getAdaptor("testdata.sub.Oranges", null);
+
+ String oranges = "testdata.Oranges";
+ JavaClass orangesClass = getClassFrom(oranges);
+ byte[] orangesBytes = orangesClass.getBytes();
+
+ boolean accepted = adaptor.accept(oranges, orangesBytes);
+ assertFalse("Should not be accepted", accepted);
+ TypeMap map = accessTypeMap(adaptor);
+
+ // The aspect
+ assertEquals(1, map.getExpendableMap().size());
+
+ // primitives, void and jlObject
+ assertEquals(10, map.getMainMap().size());
+
+ String orangesSub = "testdata.sub.Oranges";
+ JavaClass orangesSubClass = getClassFrom(orangesSub);
+ byte[] orangesSubBytes = orangesSubClass.getBytes();
+
+ accepted = adaptor.accept(orangesSub, orangesSubBytes);
+ assertTrue("Should be accepted", accepted);
+ map = accessTypeMap(adaptor);
+
+ // The aspect
+ assertEquals(1, map.getExpendableMap().size());
+ // primitives, void and jlObject
+ assertEquals(10, map.getMainMap().size());
+
+ String apples = "testdata.Apples";
+ JavaClass applesClass = getClassFrom(apples);
+ byte[] applesBytes = applesClass.getBytes();
+
+ accepted = adaptor.accept(apples, applesBytes);
+ assertFalse("Should not be accepted", accepted);
+ map = accessTypeMap(adaptor);
+
+ // The aspect and the Apples type
+ assertEquals(1, map.getExpendableMap().size());
+ // primitives, void and jlObject
+ assertEquals(10, map.getMainMap().size());
+ }
+
+ /**
+ * Testing fast excludes of the pattern groovy related pattern -
+ */
+ // public void testFastExclusionFour() throws Exception {
+ // TestClassLoaderWeavingAdaptor adaptor = getAdaptor("*", "testdata..* && !testdata.sub.Oran*");
+ //
+ // String oranges = "testdata.Oranges";
+ // JavaClass orangesClass = getClassFrom(oranges);
+ // byte[] orangesBytes = orangesClass.getBytes();
+ //
+ // boolean accepted = adaptor.accept(oranges, orangesBytes);
+ // assertFalse("Should not be accepted", accepted);
+ // TypeMap map = accessTypeMap(adaptor);
+ //
+ // // The aspect
+ // assertEquals(1, map.getExpendableMap().size());
+ //
+ // // primitives, void and jlObject
+ // assertEquals(10, map.getMainMap().size());
+ //
+ // String orangesSub = "testdata.sub.Oranges";
+ // JavaClass orangesSubClass = getClassFrom(orangesSub);
+ // byte[] orangesSubBytes = orangesSubClass.getBytes();
+ //
+ // accepted = adaptor.accept(orangesSub, orangesSubBytes);
+ // assertTrue("Should be accepted", accepted);
+ // map = accessTypeMap(adaptor);
+ //
+ // // The aspect
+ // assertEquals(1, map.getExpendableMap().size());
+ // // primitives, void and jlObject
+ // assertEquals(10, map.getMainMap().size());
+ // }
+
+ public void testAcceptanceSpeedStarDotDotStar() throws Exception {
+ URLClassLoader loader = new URLClassLoader(new URL[] { new File("../loadtime/bin").toURI().toURL() }, null);
+
+ JavaClass jc = getClassFrom("../loadtime/bin", "org.aspectj.weaver.loadtime.ClassLoaderWeavingAdaptorTest$TestOne");
+ byte[] bs = jc.getBytes();
+ jc = getClassFrom("../loadtime/bin", "org.aspectj.weaver.loadtime.ClassLoaderWeavingAdaptorTest$TestOneCGLIB");
+ byte[] bs2 = jc.getBytes();
+ // InputStream is = loader.getResourceAsStream("org.aspectj.weaver.loadtime.ClassLoaderWeaverAdaptorTests$TestOne");
+ assertNotNull(bs);
+ TestWeavingContext wc = new TestWeavingContext(loader);
+ Definition d = new Definition();
+ d.getExcludePatterns().add("*..*CGLIB*");
+ d.getAspectClassNames().add("org.aspectj.weaver.loadtime.ClassLoaderWeavingAdaptorTest$AnAspect");
+ wc.addDefinition(d);
+ ClassLoaderWeavingAdaptor adaptor = new ClassLoaderWeavingAdaptor();
+ adaptor.initialize(loader, wc);
+ boolean exist = adaptor.generatedClassesExistFor("Junk");
+ assertFalse("There should be no generated classes", exist);
+
+ // before:
+ // Acceptance 331ms
+ // Rejection 3368ms
+
+ // after:
+ // Acceptance 343ms
+ // Rejection 80ms
+
+ long stime = System.currentTimeMillis();
+ for (int i = 0; i < 100000; i++) {
+ boolean b = adaptor.accept("org.aspectj.weaver.loadtime.ClassLoaderWeavingAdaptorTest$TestOne", bs);
+ assertTrue("Should be accepted", b);
+ }
+ long etime = System.currentTimeMillis();
+ System.out.println("Acceptance " + (etime - stime) + "ms");
+ stime = System.currentTimeMillis();
+ for (int i = 0; i < 100000; i++) {
+ adaptor.delegateForCurrentClass = null;
+ boolean b = adaptor.accept("org.aspectj.weaver.loadtime.ClassLoaderWeavingAdaptorTest$TestOneCGLIB", bs2);
+ assertFalse("Should not be accepting CGLIB", b);
+ }
+ etime = System.currentTimeMillis();
+ System.out.println("Rejection " + (etime - stime) + "ms");
+
+ }
+
+ // TODO
+ // shouldn't add it to the type patterns if we are going to fast handle it
+ // include for exact name, what does it mean?
+ // excludes="!xxxx" should also be fast matched...
+
+ public void testAcceptanceSpeedExactName() throws Exception {
+ URLClassLoader loader = new URLClassLoader(new URL[] { new File("../loadtime/bin").toURI().toURL() }, null);
+
+ JavaClass jc = getClassFrom("../loadtime/bin", "org.aspectj.weaver.loadtime.ClassLoaderWeavingAdaptorTest$TestOne");
+ byte[] bs = jc.getBytes();
+ jc = getClassFrom("../loadtime/bin", "org.aspectj.weaver.loadtime.ClassLoaderWeavingAdaptorTest$TestOneCGLIB");
+ byte[] bs2 = jc.getBytes();
+ // InputStream is = loader.getResourceAsStream("org.aspectj.weaver.loadtime.ClassLoaderWeaverAdaptorTests$TestOne");
+ assertNotNull(bs);
+ TestWeavingContext wc = new TestWeavingContext(loader);
+ Definition d = new Definition();
+ d.getExcludePatterns().add("org.aspectj.weaver.loadtime.ClassLoaderWeavingAdaptorTest.TestOneCGLIB");
+ d.getAspectClassNames().add("org.aspectj.weaver.loadtime.ClassLoaderWeavingAdaptorTest$AnAspect");
+ wc.addDefinition(d);
+ TestClassLoaderWeavingAdaptor adaptor = new TestClassLoaderWeavingAdaptor();
+ adaptor.initialize(loader, wc);
+ boolean exist = adaptor.generatedClassesExistFor("Junk");
+ assertFalse("There should be no generated classes", exist);
+
+ // before:
+ // Acceptance 331ms
+ // Rejection 3160ms
+
+ // after:
+ // Acceptance 379ms
+ // Rejection 103ms
+
+ long stime = System.currentTimeMillis();
+ for (int i = 0; i < 100000; i++) {
+ boolean b = adaptor.accept("org.aspectj.weaver.loadtime.ClassLoaderWeavingAdaptorTest$TestOne", bs);
+ assertTrue("Should be accepted", b);
+ }
+ long etime = System.currentTimeMillis();
+ System.out.println("Acceptance " + (etime - stime) + "ms");
+ stime = System.currentTimeMillis();
+ for (int i = 0; i < 100000; i++) {
+ adaptor.delegateForCurrentClass = null;
+ boolean b = adaptor.accept("org.aspectj.weaver.loadtime.ClassLoaderWeavingAdaptorTest$TestOneCGLIB", bs2);
+ assertFalse("Should not be accepting CGLIB", b);
+ }
+ etime = System.currentTimeMillis();
+ System.out.println("Rejection " + (etime - stime) + "ms");
+ BcelWorld world = adaptor.getWorld();
+ Field f = World.class.getDeclaredField("typeMap");
+ f.setAccessible(true);
+ TypeMap typeMap = (TypeMap) f.get(world);
+ System.out.println(typeMap.getExpendableMap().size());
+ System.out.println(typeMap.getMainMap().size());
+ printExpendableMap(typeMap.getExpendableMap());
+ printMainMap(typeMap.getMainMap());
+ }
// --- infrastructure ---
@@ -384,6 +578,23 @@ public class ClassLoaderWeavingAdaptorTest extends TestCase {
: new String[] { excludePattern });
}
+ public TestClassLoaderWeavingAdaptor getAdaptor(Definition... definitions) {
+ try {
+ URLClassLoader loader = new URLClassLoader(new URL[] { new File("../loadtime/bin").toURI().toURL() }, null);
+ TestWeavingContext wc = new TestWeavingContext(loader);
+ for (Definition definition : definitions) {
+ // need some random aspect or the weaver will shut down!
+ definition.getAspectClassNames().add("org.aspectj.weaver.loadtime.ClassLoaderWeavingAdaptorTest$AnAspect");
+ wc.addDefinition(definition);
+ }
+ TestClassLoaderWeavingAdaptor adaptor = new TestClassLoaderWeavingAdaptor();
+ adaptor.initialize(loader, wc);
+ return adaptor;
+ } catch (Exception e) {
+ throw new RuntimeException(e);
+ }
+ }
+
public TestClassLoaderWeavingAdaptor getAdaptor(String[] includePatterns, String[] excludePatterns) {
try {
URLClassLoader loader = new URLClassLoader(new URL[] { new File("../loadtime/bin").toURI().toURL() }, null);