zoukankan      html  css  js  c++  java
  • 数据库的测试

      如果想保证业务层测试的正确性,那么我们必须要对数据库进行测试。但是目前我还没想到在内存中去进行数据库的测试,只能进行集成测试。那么下面来讲一下关于数据层的测试。

    因为在数据库的内部我们无法控制我们只能通过黑盒测试,给予值然后返回我们想要的预期效果来判断是否成功。但是在测试中我们必须要保证单一性,比喻在测试Add的时候当我们添加一条数据那么数据库可能就会产生一条脏数据,如果每天运行一次那么后果也是可怕的,但是有人说产区添加和删除一起测,我觉得也不合理,因为这样一来你一个测试既有添加又有删除不可取。再说如果是修改呢你怎么办。所以你需要在测试时候采取回滚机制。

    使用TransactionScope回滚数据修改

    下面我们看一个例子

    首先我们定义一个TransactionScope

    private TransactionScope _scope;

    然后在setup中进行初始化

    [SetUp]
            public void SetUp()
            {
                this._scope = new TransactionScope(TransactionScopeOption.Required);
            }

    然后我们就可以测试看下面代码

            [Test]
            public void Create_CreateSuccessful_ReturnsTrue()
            {
                var userInfo = CreateUserInfo();
                var userDal = new UserDal();
                bool result = userDal.Create(userInfo);
                Assert.IsTrue(result);
            }

    最后我们在teardown中释放这个事物

    [TearDown]
            public void TearDown()
            {
                this._scope.Dispose();
            }

    ok这样我们就完成了对数据层的测试。下面我们看测试的结果

    不过有些属于soa的引用我们只需要保证配置正确即可。

  • 相关阅读:
    位运算符的含义与使用
    第三次作业
    软件工程作业二
    大学对于专业的规划
    简要概述java内存模型,以及volatile关键字
    Spring详细教程
    java线程中yield(),sleep(),wait()区别详解
    利用kubeadm快速搭建Kubernetes学习环境
    vue 使用el-time-picker,把数组拆分成单个属性
    Vue+docxtemplater导出到word(包含批量转出图片)!!!
  • 原文地址:https://www.cnblogs.com/LipeiNet/p/5062464.html
Copyright © 2011-2022 走看看