hatte ich das gleiche Drama wie @GetFuzzy oben - es, dass, egal schien, was ich mich nicht die Nullreferenceexception vermeiden haben könnte, wenn ein Anruf Include() auf einem Moq DbSet gemacht wurde. Das Github-Beispiel in der anderen Antwort funktionierte leider nicht: Set.Include() gibt immer null zurück.
Nachdem ich eine Weile herumgespielt habe, habe ich mir einen Workaround ausgedacht.
[Test]
public void CanUseIncludeWithMocks()
{
var child = new Child();
var parent = new Parent();
parent.Children.Add(child);
var parents = new List<Parent> { parent };
var children = new List<Child> { child };
var parentsDbSet1 = new FakeDbSet<Parent>();
parentsDbSet1.SetData(parents);
var parentsDbSet2 = new FakeDbSet<Parent>();
parentsDbSet2.SetData(parents);
parentsDbSet1.Setup(x => x.Include(It.IsAny<string>())).Returns(parentsDbSet2.Object);
// Can now test a method that does something like: context.Set<Parent>().Include("Children") etc
}
public class FakeDbSet<T> : Mock<DbSet<T>> where T : class
{
public void SetData(IEnumerable<T> data)
{
var mockDataQueryable = data.AsQueryable();
As<IQueryable<T>>().Setup(x => x.Provider).Returns(mockDataQueryable.Provider);
As<IQueryable<T>>().Setup(x => x.Expression).Returns(mockDataQueryable.Expression);
As<IQueryable<T>>().Setup(x => x.ElementType).Returns(mockDataQueryable.ElementType);
As<IQueryable<T>>().Setup(x => x.GetEnumerator()).Returns(mockDataQueryable.GetEnumerator());
}
}
Ich mag es nicht wirklich die Ungeschicklichkeit von zwei gefälschte DbSets zu haben, die aber aus irgendeinem Grund nicht funktioniert:
parentsDbSet1.Setup(x => x.Include(It.IsAny<string>())).Returns(parentsDbSet1.Object);
jemand dafür eine Erklärung?
welches spöttische Framework? hast du "fakes framework" ausprobiert? – daryal
Entschuldigung. Spott mit Rhino Mocks. –
warten Sie, verspotten Sie den DbContext oder das DbSet? –