我试图使用间谍测试,但它不起作用。下面的类是一个Sut。
public class FileManager {
public int removeFiles(String directory) {
int count = 0;
if(isDirectory(directory)) {
String[] files = findFiles(directory);
for(String file : files) {
deleteFile(file);
count++;
}
}
return count;
}
private boolean isDirectory(String directory) {
return directory.endsWith("/");
}
private String[] findFiles(String directory) {
// read files from disk.
return null;
}
private void deleteFile(String file) {
// delete a file.
return;
}
}然后,我创建了一个如下所示的测试。
class SpyTest extends Specification {
def "Should return the number of files deleted"() {
given:
def fileManager = Spy(FileManager)
1 * fileManager.findFiles("directory/") >> { return ["file1", "file2", "file3", "file4"] }
fileManager.deleteFile(_) >> { println "deleted file."}
when:
def count = fileManager.removeFiles("directory/")
then:
count == 4
}但我找到NullPointerException了。
java.lang.NullPointerException
at example.spock.mock.FileManager.removeFiles(FileManager.java:8)
at net.sf.cglib.proxy.MethodProxy.invokeSuper(MethodProxy.java:228)
at org.spockframework.mock.runtime.CglibRealMethodInvoker.respond(CglibRealMethodInvoker.java:32)
at org.spockframework.mock.runtime.MockInvocation.callRealMethod(MockInvocation.java:60)
at org.spockframework.mock.CallRealMethodResponse.respond(CallRealMethodResponse.java:29)
at org.spockframework.mock.runtime.MockController.handle(MockController.java:49)
at org.spockframework.mock.runtime.JavaMockInterceptor.intercept(JavaMockInterceptor.java:72)
at org.spockframework.mock.runtime.CglibMockInterceptorAdapter.intercept(CglibMockInterceptorAdapter.java:30)
at example.spock.mock.SpyTest.Should return the number of files deleted(SpyTest.groovy:13)这意味着调用的是真正的方法。有没有什么原因导致它不能工作?
发布于 2019-03-12 05:42:59
在Spock中,你不能模拟java类的私有方法。看看你的FileManager,你不明白为什么只有removeFiles是公开的,而其他的是私有的。尽管所有方法都与文件管理相关。可能的解决方案是:
FileManager方法成为公共方法。这样Spock就可以工作了,FileManager实际上将成为一个文件管理器,而不仅仅是文件removerFileManager到不同的组件中。所以你可以单独模拟这些组件,并将它们注入到“文件删除程序”中。基本上,您已经在方法级别对代码进行了分解。但是私有java方法是not mockable in Spock的。而且,类分解可能是一种开销,因为FileManager看起来与它的所有operations失控,从长远来看,它可能会损害整个代码库的可维护性。
https://stackoverflow.com/questions/55097304
复制相似问题