我正在建立一个测试项目,以摆弄.net核心,并且我遇到了一些障碍。玩弄的基本思想是将产品添加到上下文中,没有大的权利。错了。因为我是一名优秀的程序员,所以我总是从TDD的方式开始。所以我尝试了以下测试。
[Fact]
public async Task AddProduct_ReturnCreatedWithProduct()
{
Product testProduct = ProductHelpers.GenerateTestProduct();
var mockRepo = new Mock<IRepository<Product>>();
mockRepo.Setup(repo => repo.Get(testProduct.ProductID)).Returns(Task.FromResult(testProduct));
var controller = new ProductController(mockRepo.Object);
var result = await controller.Post(new ProductViewModel() { ProductID = 1, ProductShortDesc = PRODUCT_SHORTDESC, ProductDescription = PRODUCT_DESC });
var okResult = Assert.IsType<OkObjectResult>(result);
var returnProduct = Assert.IsType<Product>(okResult.Value);
Assert.Equal(testProduct.ProductShortDesc, returnProduct.ProductShortDesc);
Assert.Equal(testProduct.ProductDescription, returnProduct.ProductDescription);
}
public static Product GenerateTestProduct()
{
return new Product()
{
ProductID = 1,
ProductShortDesc = "FRI",
ProductDescription = "Fristi"
};
}
哪个应该返回一个不错的OkObjectResult
。嗯,不,它没有。所以我深深地潜入控制器,给了我这个。
[HttpPost]
public async Task<ActionResult> Post([FromBody]ProductViewModel model)
{
if (!ModelState.IsValid)
return BadRequest(ModelState);
else
{
var product = await _productRepository.AddEntity(model.ToEntity());
if (product == null)
return StatusCode(500);
else
return Ok(product);
}
}
public interface IRepository<T>
{
Task<T> Get<TKey>(TKey id);
IQueryable<T> GetAll();
Task<T> AddEntity(T entity);
Task DeleteEntity(T entity);
Task Update(T entity);
}
public class ProductRepository : IRepository<Product>
{
protected readonly DbContext Context;
protected DbSet<Product> DbSet;
public ProductRepository(ApplicationContext context)
{
Context = context;
DbSet = context.Set<Product>();
}
public async Task<Product> AddEntity(Product entity)
{
try
{
await Context.Set<Product>().AddAsync(entity);
await Save();
return await Get(entity.ProductID);
}
catch (System.Exception ex)
{
Debug.WriteLine(ex.Message);
throw ex;
}
}
//Rest left out for shortness off this post
}
[HttpPost]
public async Task<ActionResult> Post([FromBody]ProductViewModel model)
{
if (!ModelState.IsValid)
return BadRequest(ModelState);
else
{
var product = await _productRepository.AddEntity(model.ToEntity());
if (product == null)
return StatusCode(500);
else
return Ok(product);
}
}
所以这也不顺利。我尝试调试代码以找到根本原因,但由于某种原因,它不让我在界面代码中单步执行以找出为什么Add不能在我的单元测试中工作,但确实可以在正常的postman测试中工作。 (只是我的代码被禁用)。希望你们中的一些人可以帮助我解决这个问题
答案 0 :(得分:2)
正在为测试模拟错误的方法。测试中的方法仅与AddEntity
交互,因此应该为此测试模拟依赖项。
mockRepo
.Setup(repo => repo.AddEntity(It.Is<Product>(vm =>
vm.ProductShortDesc == testProduct.ProductShortDesc
&& vm.ProductDescription == testProduct.ProductDescription)
)
)
.ReturnsAsync(testProduct);
其他一切都可以保持不变。