以下是我想测试的方法。我正在使用TestNG框架进行单元测试。
class Random{
List<String> namesOfLinks;
public List<String> methodIwantToTest(List<String> cktNames) {
Map<String, Graph> maps = DataBaseReader.getGraphs(cktNames);
for (Entry<String, Graph> entry : maps.entrySet()) {
graphList.add(entry.getValue().getName());
}
}
return namesOfLinks;
}
我正在编写上述类中方法“methodIwantToTest”的测试用例。我可以提供一些虚拟的cktNames并获得如下所示的执行方法。
@Test (dataProvider = "dp")
public void test_methodIwantToTest(List<String> cktNames, List<String> expectedLinkNames){
Random rm = new Random();
List<String> actual = rm.methodIwantToTest(cktNames);
Assert.assertEquals(actual,expectedLinkNames);
}
现在出现了问题。当我在'rm'引用上调用实际方法时,它会对另一个API进行静态方法调用。它必须返回一些东西才能使我的“方法”起作用。我搜索了互联网,发现“easymock”作为解决方案。但我无法使用“easyMock”来模拟静态方法(DataBaseReader.getGraphs())。我必须模拟该方法,以便它返回已定义类型的映射。任何建议都会很棒。 谢谢!!
其他问题涉及如何测试静态方法。但我的是在测试实例方法时嘲笑静态方法。
答案 0 :(得分:4)
答案 1 :(得分:1)
我建议将适配器模式与依赖注入技术结合使用。创建一个包含要模拟的所有方法的接口:
public interface IDatabase {
Map<String, Graph> getGraphs(List<String> names);
}
显然,Database
没有实现你刚刚发明的接口(并且方法是static
),但你可以创建一个适配器类:
public class DataBaseReaderAdapter implements IDatabase {
public Map<String, Graph> getGraphs(List<String> names) {
return DataBaseReader.getGraphs(names);
}
}
将此类的实例作为要测试的类中的构造函数参数:
public class Random {
private readonly IDatabase _database;
public Random(IDatabase database) {
_database = database;
}
}
当你想要调用方法时:
Map<String, Graph> maps = _database.getGraphs(cktNames);
在您的测试中,使用任何模拟框架来创建IDatabase
的模拟,并将该模拟传递给Random
。
虽然这种技术最初可能看起来很复杂,但它往往会带来更好的设计,其中类的依赖性更加明显,一切都变得更容易测试。