2017-04-12 110 views
0

我嘲笑FindAsync通过下面的代码:嘲讽FindAsync方法

var brands = new Mock<DbSet<Brand>>(); 
     ConfigureTheDbSet(brands, brandData); 
     brands.Setup(b => b.FindAsync(It.IsAny<object[]>())) //substitution of the .SelectAsync(id) method 
      .Returns<object[]>(ids => brands.Object.FirstOrDefaultAsync(b => b.BrandId == (int) ids[0])); 

,并一直工作正常,直到我说嘲讽的AsNoTracking上下文:

var mockContext = new Mock<ReportDbContext>(); 
     mockContext.Setup(m => m.Set<Brand>()).Returns(brands.Object); 
     mockContext.Setup(m => m.Set<Brand>().AsNoTracking()).Returns(brands.Object); 

而且FindAsync返回null。为了使它工作,我添加了以下嘲弄:

mockContext.Setup(m => m.Set<Brand>().FindAsync(It.IsAny<object[]>())) 
      .Returns<object[]>(async d => await brands.Object.FindAsync(d)); 

任何人都有一个线索,为什么发生这种情况?

回答

0

IMO,你应该嘲笑接口,例如IBrandRepository。否则,嘲笑什么? - 你可以创建你的类的实例,调用FindAsync()并像往常一样声明结果。

这里是我如何使用Moq的接口,例如repo接口;

// arrange 
var mockRepo = new Mock<IBrandRepository>(); 
mockRepo.Setup(o => o.FindAsync(It.IsAny<string>())).ReturnsAsync(new Brand[] { ... }); 

var someClass = new SomeClass(IBrandRepository); // someClass that use IBrandRepository 

// act 
string search = "brand1 brand2"; // what the user searches for 
var results = someClass.FindBrands(searchText) // internally calls IBrandRepository.FindAsync() 

// assert 
// Assert.AreEqual(results.Count(), ... 
+0

这没有意义,因为我嘲笑传递给服务的上下文,它定义了服务行为 –