我有一个类,它接受一个文件,找到与之相关的文件,然后打开它。一些类似的东西
class DummyFileClass
{
private File fileOne;
private File fileTwo;
public DummyFileClass(File fileOne)
{
this.fileOne = fileOne;
fileTwo = findRelatedFile(fileOne)
}
public void someMethod()
{
// Do something with files one and two
}
}在我的单元测试中,我希望能够测试someMethod(),而不必将物理文件放在某个地方。我可以模拟fileOne,并将其传递给构造函数,但由于fileTwo是在构造函数中计算的,因此我无法控制它。
我可以模拟findRelatedFile()方法--但这是最佳实践吗?在这里寻找最好的设计,而不是实用的变通方法。我对模拟框架还是个新手。
发布于 2013-06-18 16:31:16
在这种情况下,我会使用物理文件来测试组件,而不是依赖模拟框架。正如fge提到的,这可能会更容易,而且你不必担心你可能会对你的模拟做出任何错误的假设。
例如,如果您依赖于File#listFiles(),您可能会让您的模拟返回一个固定的File列表,但是,不能保证它们返回的顺序-这一事实只有当您在不同的平台上运行您的代码时才会发现。
我会考虑使用JUnit的TemporaryFolder规则来帮助您设置测试所需的文件和目录结构,例如:
public class DummyFileClassTest {
@Rule
public TemporaryFolder folder = new TemporaryFolder();
@Test
public void someMethod() {
// given
final File file1 = folder.newFile("myfile1.txt");
final File file2 = folder.newFile("myfile2.txt");
... etc...
}
}当测试完成时,规则应该清理所有创建的文件和目录。
https://stackoverflow.com/questions/17163484
复制相似问题