diff options
-rw-r--r-- | testing-util/src/org/aspectj/testing/util/TestUtil.java | 56 |
1 files changed, 51 insertions, 5 deletions
diff --git a/testing-util/src/org/aspectj/testing/util/TestUtil.java b/testing-util/src/org/aspectj/testing/util/TestUtil.java index 3095b6e2d..ecd738478 100644 --- a/testing-util/src/org/aspectj/testing/util/TestUtil.java +++ b/testing-util/src/org/aspectj/testing/util/TestUtil.java @@ -63,16 +63,33 @@ import org.aspectj.util.Reflection; * this class. Also, the bytecode weaver is required to compare class files, but * not to compare other files. */ - public final class TestUtil { + private static final boolean JAVA_5_VM; private static final String ASPECTJRT_KEY = "aspectjrt"; private static final String TESTING_CLIENT_KEY = "testing-client"; public static final URL BAD_URL; private static final File LIB_DIR; private static final Properties LIB_RPATHS; private static final Map LIB_ENTRIES; + private static File ASPECTJRT_PATH; static { { + String[] paths = { "sp:aspectjrt.path", "sp:aspectjrt.jar", + "../lib/test/aspectjrt.jar", "../aj-build/jars/aspectj5rt-all.jar", + "../aj-build/jars/runtime.jar", + "../runtime/bin"}; + ASPECTJRT_PATH = FileUtil.getBestFile(paths); + } + { + boolean j5 = false; + try { + Class.forName("java.lang.annotation.Annotation"); + j5 = true; + } catch (Throwable t) { + } + JAVA_5_VM = j5; + } + { URL url = null; try { url = new URL("http://eclipse.org/BADURL"); @@ -133,6 +150,13 @@ public final class TestUtil { super(); } + + public static boolean is15VMOrGreater() { return JAVA_5_VM;} + + public static File aspectjrtPath() { + return ASPECTJRT_PATH; + } + public static URL fileToURL(File file) { try { return file.toURL(); @@ -597,11 +621,33 @@ public final class TestUtil { } + public static String cleanTestName(String name) { + name = name.replace(' ', '_'); + return name; + } + public static Test skipTest(String tests) { + // could printStackTrace to give more context if needed... + System.err.println("skipping tests " + tests); + return testNamed("skipping tests " + tests); + } + + public static Test testNamed(String named) { + final String name = cleanTestName(named); + return new Test() { + public int countTestCases() { + return 1; + } + public void run(TestResult r) { + r.startTest(this); + r.endTest(this); + } + public String toString() { return name; } + }; + } + /** - * TODO move to testing-utils for use by loadtime5, others. - * - * @param sink - * @param sourceName + * @param sink the TestSuite sink to add result to + * @param sourceName the String fully-qualified name of the class with a suite() method to load */ public static void loadTestsReflectively(TestSuite sink, String sourceName, boolean ignoreError) { Throwable thrown = null; |