12

我有一个类,它接收一个文件,找到与之相关的文件,然后打开它。类似的东西

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() 方法——但这是最佳实践吗?在这里寻找最佳设计而不是实用的解决方法。我对模拟框架相当陌生。

4

1 回答 1

28

在这种情况下,我会使用物理文件来测试组件,而不是依赖于模拟框架。如前所述fge,它可能更容易,而且您不必担心您可能对模拟做出任何不正确的假设。

例如,如果您依赖,File#listFiles()您可能会让您的模拟返回一个固定的Files 列表,但是,不能保证它们返回的顺序 - 您可能只有在不同平台上运行代码时才会发现这一事实。

我会考虑使用 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...
    }
}

测试完成时,该规则应清理所有创建的文件和目录。

于 2013-06-18T08:31:15.707 回答