解决 Ant Junit Testcase Failed 自动检测类名

今天过去写的testcase在ant执行时failed,但是在源文件中直接以application方式运行却没有错。

原因在于下面两句话:

public static Set<Class<? extends XXX>> getPluginsInSameDir(Class<?> clazz) {
        String dirPath = clazz.getPackage().getName().replace(".", "/");
        System.out.println(dirPath);
        URL path = clazz.getClassLoader().getResource(dirPath);
        System.out.println(path.toExternalForm());
.....
}

第一句是要得到那个类所在的包路径,第二句是要得到那个包所在的具体路径。

以application方式运行得到的结果是:

\\ aa/bb/cc
file:/D:/works/project/bin/aa/bb/cc **
以ant方式执行Junit testcase得到的结果是:

** aa/bb/cc
file:/D:/works/project/build/classes/aa/bb/cc **
这两个结果差别还是蛮大的。关键问题是classLoader()那个家伙的查找资源的方式。这里解决问题的最简单方式:

就是那个testcase中传入的Class<?&rt;clazz的包路径不要在testcase代码中出现(可以在src代码路径中出现),那么ant执行testca
se时,就又会找到原来的/bin目录。

例如工程结果是:

src/java
            | aa     
                  | bb
                        | cc
                             |YourClass.java
src/test
            | aa
                  | bb
                        | cc
                             | TestYourClass.java

你这里就不应该将YourClass.class作为参数传入进刚才的函数中。不应该像这样

getPluginsInSameDir(YourClass.class); 

最简单的做法是:

src/java
            | aa     
                  | bb
                        | cc
                             |YourClass.java
src/test
            | aa
                  | bb
                        | ccs
                             | TestYourClass.java

这是非常的土的方法。

你当然可以尝试修改一下getClassLoader().getResource()这句话。

这个问题产生的原因是:

ant执行JUnit时,执行TestYourClass, 这时加载的classLoader()是junit的classLoader(),
这个会首先在自己的包路径中查找是否有该路径,如果存在就返回了。

另外一种解决方法是:

        ProtectionDomain pd = clazz.getProtectionDomain();
        CodeSource cs = pd.getCodeSource();
        String location = cs.getLocation().getFile();

这样就能真正的通过那个类找到那个类 编译为class文件所在的目录。