summaryrefslogtreecommitdiffstats
path: root/weaver
diff options
context:
space:
mode:
authoraclement <aclement>2006-08-08 11:35:44 +0000
committeraclement <aclement>2006-08-08 11:35:44 +0000
commit282188781fc2c342ad12bd4173aee139befa0da1 (patch)
tree5cef3c696cf6b5b1bd49e4ea610edd89db85bfd1 /weaver
parent387c3ac6f23a39aebbc4044093c793009dfea8f6 (diff)
downloadaspectj-282188781fc2c342ad12bd4173aee139befa0da1.tar.gz
aspectj-282188781fc2c342ad12bd4173aee139befa0da1.zip
inactive test case for Classloader repository sharing
Diffstat (limited to 'weaver')
-rw-r--r--weaver/testsrc/org/aspectj/weaver/bcel/ClassLoaderRepositoryTests.java69
1 files changed, 69 insertions, 0 deletions
diff --git a/weaver/testsrc/org/aspectj/weaver/bcel/ClassLoaderRepositoryTests.java b/weaver/testsrc/org/aspectj/weaver/bcel/ClassLoaderRepositoryTests.java
new file mode 100644
index 000000000..c60f43d57
--- /dev/null
+++ b/weaver/testsrc/org/aspectj/weaver/bcel/ClassLoaderRepositoryTests.java
@@ -0,0 +1,69 @@
+/* *******************************************************************
+ * Copyright (c) 2006 Contributors
+ * All rights reserved.
+ * This program and the accompanying materials are made available
+ * under the terms of the Eclipse Public License v1.0
+ * which accompanies this distribution and is available at
+ * http://www.eclipse.org/legal/epl-v10.html
+ *
+ * Contributors:
+ * Andy Clement initial implementation
+ * ******************************************************************/
+
+
+package org.aspectj.weaver.bcel;
+
+import java.io.File;
+import java.io.IOException;
+import java.net.URL;
+import java.net.URLClassLoader;
+import java.util.Enumeration;
+import java.util.zip.ZipEntry;
+import java.util.zip.ZipFile;
+
+import junit.framework.TestCase;
+
+import org.aspectj.apache.bcel.util.ClassLoaderRepository;
+
+/** NOT YET INCLUDED IN A FULL TEST RUN - WORK IN PROGRESS CHECKING CLASSLOADERREPOSITORY OPTIMIZATIONS */
+public class ClassLoaderRepositoryTests extends TestCase {
+
+ public void testRepositorySharing() throws Exception {
+ ClassLoaderRepository.useSharedCache=false;
+ File f = new File("../lib/aspectj/lib/aspectjtools.jar");
+ ClassLoader cl = Thread.currentThread().getContextClassLoader();
+ ClassLoader cl1 = new URLClassLoader(new URL[]{f.toURL()},cl);
+ ClassLoader cl2 = new URLClassLoader(new URL[]{f.toURL()},cl);
+ ClassLoaderRepository rep1 = new ClassLoaderRepository(cl1);
+ ClassLoaderRepository rep2 = new ClassLoaderRepository(cl2);
+ try {
+ assertTrue("Couldnt find aspectjtools to test. Tried: "+f.getAbsolutePath(),f.exists());
+ ZipFile zf = new ZipFile(f);
+ int i = 0;
+ Enumeration entries = zf.entries();
+ while (entries.hasMoreElements()) {
+ ZipEntry zfe = (ZipEntry)entries.nextElement();
+ String classfileName = zfe.getName();
+ if (classfileName.endsWith(".class")) {
+ String clazzname = classfileName.substring(0,classfileName.length()-6).replace('/','.');
+
+ // twice by each
+ rep1.loadClass(clazzname);
+ rep1.loadClass(clazzname);
+ rep2.loadClass(clazzname);
+ rep2.loadClass(clazzname);
+ i++;
+ }
+ }
+ System.err.println("Successfully compared "+i+" entries!!");
+ } catch (IOException e) {
+ e.printStackTrace();
+ fail(e.getMessage());
+ }
+ System.err.println(rep1.reportAllStatistics());
+ System.err.println(rep2.reportAllStatistics());
+ }
+
+
+
+}