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 过滤器的作用
    TreeView的绑定
    设计模式(一)工厂模式Factory(创建型)
    【剑指offer】员工年龄排序
    Spring3.0 AOP 具体解释
    IT行业新名词--透明手机/OCR(光学字符识别)/夹背电池
    MYSQL C API 记录
    Hibernate的介绍
    数据绑定(八)使用Binding的RelativeSource
    一、ExtJS下载使用
  • 原文地址:https://www.cnblogs.com/LipeiNet/p/5062464.html
Copyright © 2011-2022 走看看