我想創建一個測試來測試實體框架Add
方法。任何人都可以幫助如何嘲笑DbSet.Add
方法。我嘗試了以下但不工作。我究竟做錯了什麼?C#如何Moq entityframework DbSet添加方法
我得到的結果是null
repository.Insert
後...
test.cs中:
var productToCreate = new Product { Name = "Added", Description = "Added" };
var result = repository.InsertAsync(objToCreate, userContext).Result;
Assert.AreEqual(result.Name, "Added");
Mock.cs
internal static DbSet<T> GetMockedDataSet<T>(IEnumerable<T> data) where T : class
{
// Create a mocked data set that contains the data
var set = new Mock<DbSet<T>>();
set.As<IDbAsyncEnumerable<T>>()
.Setup(m => m.GetAsyncEnumerator())
.Returns(new TestDbAsyncEnumerator<T>(data.GetEnumerator()));
set.As<IQueryable<T>>()
.Setup(m => m.Provider)
.Returns(new TestDbAsyncQueryProvider<T>(data.AsQueryable().Provider));
set.As<IQueryable<T>>().Setup(m => m.Expression).Returns(data.AsQueryable().Expression);
set.As<IQueryable<T>>().Setup(m => m.ElementType).Returns(data.AsQueryable().ElementType);
set.As<IQueryable<T>>().Setup(m => m.GetEnumerator()).Returns(data.GetEnumerator());
set.Setup(x => x.AsNoTracking()).Returns(set.Object);
set.Setup(x => x.Add(It.IsAny<T>())).Callback<T>((s) => data.Concat(new[] { s }));
// Return the mock
return set.Object;
}
庫:
public async Task<Product> InsertAsync(Product input)
{
using (var ctx = .....))
{
var added = ctx.Set<Product>().Add(input);
await ctx.ValidateAndSaveAsync();
return added;
}
}
提供一個能夠再現問題的[mcve]。 – Nkosi
@Nkosi,對不起,我不明白你是什麼意思?我提供了我的代碼塊並解釋了我期待的內容?謝謝 –
這個例子不完整。能夠重新創建問題的因變量太多,測試中的方法與測試中顯示的不同,顯示的設置不完整....需要繼續嗎? – Nkosi