I need to mock EF's DbContext
. I use the approach here and it works well.
// mock a DbSet
var mockDbSet = Substitute.For<DbSet<Foo>, IQueryable<Foo>>();
var data = new List<Foo>().AsQueryable();
((IQueryable<Foo>)mockDbSet).Provider.Returns(data.Provider);
((IQueryable<Foo>)mockDbSet).Expression.Returns(data.Expression);
((IQueryable<Foo>)mockDbSet).ElementType.Returns(data.ElementType);
((IQueryable<Foo>)mockDbSet).GetEnumerator().Returns(data.GetEnumerator());
// now add it to a mock DbContext
var mockContext = Substitute.For<MyDbContextClass>();
mockContext.Set<Foo>().Returns(mockDbSet);
However in some tests I need to be able to call mockContext.Set<Foo>().Add(someFoo)
and mockContext.Set<Foo>().Remove(otherFoo)
, and for the underlying add/remove logic to work.
I tried this:
mockDbSet.When(x => x.Add(Arg.Any<Foo>())).Do(x => data.Add(x.Arg<Foo>()));
but it throws with Collection was modified; enumeration operation may not execute.
So how do I implement add/remove functionality?