2014-02-13 68 views
0

我在我的应用程序下面的代码:为什么JustMock声称我的嘲弄方法永远不会被调用?

public class DirectoryCrawler 
{ 
    private IPathWrap _path; 
    private IDirectoryWrap _directory; 
    private ITrackedFileStore _trackedFileStore; 
    private IFileWrap _file; 

    public DirectoryCrawler(IPathWrap path, ITrackedFileStore trackedFileStore, IDirectoryWrap directory, IFileWrap file) 
    { 
     _path = path; 
     _trackedFileStore = trackedFileStore; 
     _directory = directory; 
     _file = file; 
    } 

    public void CheckDirectoryContents(string baseDirectory) 
    { 
     var trackedFiles = _trackedFileStore.GetTrackedFilesInPath(baseDirectory); 
    } 
} 

我单位通过测试它:

[TestClass] 
public class DirectoryCrawlerTests 
{ 
    private MockingContainer<DirectoryCrawler> _mockContainer; 

    [TestInitialize] 
    public void Setup() 
    { 
     _mockContainer = new MockingContainer<DirectoryCrawler>(); 
    } 

    [TestMethod] 
    public void Requests_Tracked_Files_In_Path() 
    { 
     var instance = _mockContainer.Instance; 
     instance.CheckDirectoryContents("C:\\Test"); 

     _mockContainer.Assert<ITrackedFileStore>(x => x.GetTrackedFilesInPath(Arg.IsAny<string>()), Occurs.Once()); 
    } 
} 

但是,断言失败自称Result Message: Occurrence expectation failed. Expected exactly 1 call. Calls so far: 0

为什么JustMock未检测发生是否正确?这是最新的JustMock Lite Nuget包(2014.1.1317.4)

+0

我假设'_trackedFileStore'是一个注入的依赖项?我们可以看到你的'_mockContainer'设置吗? –

+0

对不起,我添加了完整的测试类和实现类。 – KallDrexx

+0

你永远不会把'ITrackedFileStore'的模拟传递给'DirectoryCrawler'模拟。因此,模拟不能验证它是否被调用。这也可能与你嘲笑一个具体对象有关,我们通常不这样做(我也更熟悉Moq)。 –

回答

0

正如评论中所述,使用AutoMocking时,呼叫验证会有所不同。

您必须Arrange将被调用的automocked依赖关系方法并将其指定为MustBeCalled()

相关问题