我有一个类 A 作为
Class A{
private static final String ANON_DIR = "/webapps/worldlingo/data/anonymizer/";
private static final String NO_ANON = "noanonymize";
public String first(String text, String srclang, Map dictTokens) {
Set<String> noAnonymize = new HashSet<String>();
second(noAnonymize,ANON_DIR + NO_ANON, "tmpLang","name");
String value;
if(noAnonymize.contains("test")){
value = "test1";
}
else {
value = "test";
}
return value;
}
其中ANON_DIR和NO_ANON是静态最终值。此类首先具有函数,其次具有函数。第一个函数中有一个调用方法,用于调用第二个函数。第二个函数是 void 函数,它将静态字段作为参数。
第二个函数只是文件读取函数,其路径为
public void second (Set<String> hashSet, String path, String lang , String type) {
FileReader fr = null;
BufferedReader br = null;
try {
fr = new FileReader(path);
br = new BufferedReader(fr);
String Line;
while ((Line = br.readLine()) != null) {
hashSet.add(Line);
}
} catch (IOException e) {
log.error("Anonymizer: Unable to load file.", e);
} finally {
try {
if (fr != null) {
fr.close();
}
if (br != null) {
br.close();
}
} catch (IOException e) {
log.error("Anonymizer : An error occured while closing a resource.", e);
}
}
}
}
现在我尝试首先使用 mockito 测试该功能。我正在尝试更新传递的第一个参数(列表参数),即第二个参数中的noAnonymize(noAnonymize,ANON_DIR + NO_ANON,"tmpLang","name");
public void testfirst() throws Exception {
Anonymizer mock = PowerMockito.mock(Anonymizer.class);
doAnswer(new Answer() {
public Object answer(InvocationOnMock invocation) {
List<String> args = invocation.getArgumentAt(0,List.class);
args.add("a");
args.add("b");
return null; // void method, so return null
}
}).when(mock).readNoAnonymizeFile(Mockito.anySet(),Mockito.anyString(),Mockito.anyString(),Mockito.anyString());
Method anonymizeNames = anon.getClass().getDeclaredMethod("anonymizeNames_test", String.class, String.class, Map.class);
String srcLang = "MSFT_EN";
Map mapTokens = new HashMap();
String result = (String) anonymizeNames.invoke(anon,"I am David",srcLang,mapTokens);
}
问题: 我无法模拟无效的第二种方法来更新值为 a 和 b 的列表。我怎样才能有模拟测试用例来更新 void 方法中的参数。
对类进行单元测试时,可以通过其公共方法对其进行测试。如果无法通过其公共方法充分测试类,则需要对其进行重构。
在本例中,您尝试对不存在的边缘情况的私有方法进行单元测试。为什么还要提供常量作为参数?为什么不直接在私有方法中引用它并保存传递参数?相反,你可以写:
fr = new FileReader(ANON_DIR + NO_ANON);
编辑
在Laxmi和我进行了讨论之后,我们提出了一个解决方案,使用基于构造函数的依赖注入并更改void
方法以返回Set<String>
。这让我们可以孤立地进行测试并轻松模拟。