假设我有一个包含以下测试的遗留JUnit测试套件:
public class AwesomeTest {
public void testBusinessLogic() {
...
[awesome mocking library]
...
}
}
public class AmazingTest {
public void testBusinessProcess() {
...
[amazing xml operation]
...
}
}
现在假设Awesome Mocking库依赖于包含类org.useful.XMLClass
的Awesome BCEL字节码生成库,并且该库具有XMLClass的版本1。
现在假设Amazing Xml操作依赖于包含类org.useful.XMLClass
的Amazing Xml库,并且该库具有XML Class的第2版。
还假设该类的版本2不向后兼容版本1 - 因此哪个版本在类路径中具有更高的优先级 - 它打破了另一个版本的依赖性。
还假设有400个测试依赖于令人敬畏的模拟库 - 所以重写不是一个理想的选择。
还假设一些关键业务功能已经使用了惊人的xml库构建 - 并且强烈建议不要重写它。
你如何解决这个类路径地狱的情况 - 除了运行ant测试(假设你用Ant运行它们)两次,两个不同的手动排序的类路径和手动确定的测试子集? (我对自定义类加载器的想法持开放态度 - 但这似乎与使用ant解决方案的双自定义类路径具有相同的可维护性水平)
答案 0 :(得分:3)
我相信使用java代理和自定义类加载器可以实现一个非常透明的解决方案。这个想法如下:
org.useful.XMLClass
的所有引用替换为intercepted.org.useful.XMLClass
。intercepted.org.useful.XMLClass
。如果是,请加载Mocking Library使用的XMLClass
版本。默认情况下,可以处理所有其他请求。使用自定义类加载器并在运行测试时附加java代理,并且所有内容都应该正确运行,就像没有依赖冲突一样。
答案 1 :(得分:0)
我认为史蒂文的答案很棒 - 为了完整起见,因为这个问题获得了如此多的选票 - 我想分享我们想到的所有替代品(包括不好的选择)
org.useful.XMLClass
的惊人模拟库的自定义版本(结果比我们当前的项目更大)