aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--loadtime/testsrc/org/aspectj/weaver/loadtime/ClassLoaderWeavingAdaptorTest.java612
1 files changed, 306 insertions, 306 deletions
diff --git a/loadtime/testsrc/org/aspectj/weaver/loadtime/ClassLoaderWeavingAdaptorTest.java b/loadtime/testsrc/org/aspectj/weaver/loadtime/ClassLoaderWeavingAdaptorTest.java
index 2cdb5312b..3a4909898 100644
--- a/loadtime/testsrc/org/aspectj/weaver/loadtime/ClassLoaderWeavingAdaptorTest.java
+++ b/loadtime/testsrc/org/aspectj/weaver/loadtime/ClassLoaderWeavingAdaptorTest.java
@@ -66,312 +66,312 @@ 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());
+// }
+//
+// /**
+// * 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 ---