• 写给PPT用,可测试性驱动开发导向IOC的过程


    可测试性驱动开发的一个不严谨例子

    一个购物车的例子

    public class Cart
        {
            public Logger logger = new Logger();

            public List<Product> ProductList;

            public Cart()
            {
                ProductList = new List<Product>();
            }
     
            public int GetTotalCount()
            {
                return this.ProductList.Count;
            }

            public void Add(Product product)
            {
                //小记下log
                logger.Log(string.Format("添加了一件商品"));
                //一大段逻辑
                Console.WriteLine("判断是否重复");
                Console.WriteLine("判断商品ID是不是正确"); 

                ProductList.Add(product);
            }
        }

    logger一开始是这样的

    public class Logger
        {
            //插入数据库
            public void Log(string message)
            {
                Console.WriteLine(string.Format("插入数据库:{0}",message));
            }
        }

     测试代码,但是。。。为了测试还要写数据库吗?我只是想测试下购物车的逻辑呃。。。

    [TestMethod()]
            public void AddTest()
            {
                Cart cart = new Cart(); 
    // TODO: Initialize to an appropriate value
                Product product = new Product();
                cart.Add(product);
                Assert.AreEqual<int>(1,cart.GetTotalCount());
            }

     开始可测试性重构

    public interface ILog
        {
            void Log(string message);
        }

        public class Logger:ILog
        {
            //插入数据库
            public void Log(string message)
            {
                Console.WriteLine(string.Format("插入数据库:{0}",message));
            }
        }

     测试代码修改

     public ILog logger;


            public Cart(ILog logger)
            {
                ProductList = new List<Product>();
                this.logger = logger;
            }
     public class MemLog : ILog
        {
            public void Log(string message)
            {
                Console.WriteLine("记内存下就好");
            }
        }

    [TestMethod()]
            public void AddTest()
            {
                Cart cart = new Cart(new MemLog());             Product product = new Product();
                cart.Add(product);
                Assert.AreEqual<int>(1,cart.GetTotalCount());
            }
    这下不用访问数据库,都在内存中进行,为了可测试性的目的,我们通过重构,通过构造函数注入,mock对象等方法,对外部依赖解耦
  • 相关阅读:
    Oracle11g聚合函数
    和为S的连续正数数列,动态规划,C++
    统计一个数组在排序数组中出现的次数,C++,二分查找
    寻找两个链表的第一个公共子节点,C++
    二维数组中的查找
    数组中的逆序对,C++,分治算法
    得到从小到大的第N个丑数的三种方式(C++)一维动态规划
    连续字数组的最大和(Java)一个int数组,求其中的最大的连续数的和
    n个整数,求这中间最小的k个整数(Java)
    两个字符串的最长公共子串求法(C++、动态规划)
  • 原文地址:https://www.cnblogs.com/brightwang/p/2577017.html
Copyright © 2020-2023  润新知