ASP.NETMVC:如何在数据驱动环境中模拟数据库?
创始人
2024-11-12 05:30:19
0

在ASP.NET MVC中,可以使用Moq库来模拟数据库以进行单元测试。以下是一些示例代码:

首先,创建一个存储库接口,该接口将定义所有您需要模拟的数据库操作:

public interface IProductRepository { IEnumerable GetAllProducts(); Product GetProductById(int productId); void AddProduct(Product product); void UpdateProduct(Product product); void DeleteProduct(int productId); }

然后实现该接口的类:

public class ProductRepository : IProductRepository { private List products = new List() { new Product() {ProductId = 1, ProductName = "iPhone X"}, new Product() {ProductId = 2, ProductName = "Samsung Galaxy S9"}, new Product() {ProductId = 3, ProductName = "Google Pixel 2"} };

public void AddProduct(Product product)
{
    products.Add(product);
}

public void DeleteProduct(int productId)
{
    var product = products.FirstOrDefault(x => x.ProductId == productId);
    if (product != null)
        products.Remove(product);
}

public IEnumerable GetAllProducts()
{
    return products;
}

public Product GetProductById(int productId)
{
    return products.FirstOrDefault(x => x.ProductId == productId);
}

public void UpdateProduct(Product product)
{
    var old_product = products.FirstOrDefault(x => x.ProductId == product.ProductId);
    if (old_product != null)
    {
        products.Remove(old_product);
        products.Add(product);
    }
}

}

这是一个简单的Product模型:

public class Product { public int ProductId { get; set; } public string ProductName { get; set; } }

现在,我们可以使用Moq来模拟这个存储库以进行单元测试:

[TestClass] public class ProductControllerTests { [TestMethod] public void Index_ReturnsAViewResult_WithAListOfProducts() { // Arrange var mockRepo = new Mock(); mockRepo.Setup(repo => repo.GetAllProducts()) .Returns(GetTestProducts()); var controller = new

相关内容

热门资讯

透视关于!wepoker私人局... 透视关于!wepoker私人局怎么玩,wejoker开挂-果然真的有辅助app(哔哩哔哩)1、让任何...
透视专业!wpk辅助哪里买,w... 透视专业!wpk辅助哪里买,wpk软件是真的吗-竟然真的是有辅助方法(哔哩哔哩)进入游戏-大厅左侧-...
透视曝光!wepoker可以透... 透视曝光!wepoker可以透视码,wepoker免费钻石-果然有辅助神器(哔哩哔哩)1、这是跨平台...
透视开挂!wpk俱乐部辅助器,... 透视开挂!wpk俱乐部辅助器,wpk可以作弊吗-果然真的有辅助工具(哔哩哔哩)进入游戏-大厅左侧-新...
透视推荐!wepoker免费透... 透视推荐!wepoker免费透视脚本,wepoker有插件吗-总是一直都是有辅助工具(哔哩哔哩)所有...
透视详情!德普之星的辅助工具介... 透视详情!德普之星的辅助工具介绍,德普之星辅助工具如何设置-其实一直都是有辅助脚本(哔哩哔哩)一、游...
透视曝光!wpk插件辅助,wp... 透视曝光!wpk插件辅助,wpk透视工作室-原来真的是有辅助脚本(哔哩哔哩)1、下载好透视辅助下载之...
透视辅助!wpk免费辅助,wp... 透视辅助!wpk免费辅助,wpk真吗-真是真的是有辅助app(哔哩哔哩)1、下载好透视辅助下载之后点...
透视必备!wpk俱乐部是真的吗... 透视必备!wpk俱乐部是真的吗,wpk透视是真的假的-都是真的是有辅助教程(哔哩哔哩)1、这是跨平台...
透视解密!wpk有作弊吗,wp... 透视解密!wpk有作弊吗,wpk有那种辅助吗-真是有辅助软件(哔哩哔哩)1、让任何用户在无需安装教程...