当前位置:  开发笔记 > 后端 > 正文

数据库集成测试

如何解决《数据库集成测试》经验,为你挑选了2个好方法。

当您使用数据访问层或大多数应用程序堆栈进行集成测试时.如果多个测试在同一个数据库上运行,那么阻止多个测试相互冲突的最佳方法是什么?



1> Orion Edward..:

交易.

rails单元测试框架上的ruby是这样的:

Load all fixture data.

For each test:

  BEGIN TRANSACTION

    # Yield control to user code

  ROLLBACK TRANSACTION

End for each

这意味着

    测试对数据库所做的任何更改都不会影响正在进行的其他线程

    下一个测试的数据不会被先前的测试污染

    这比为每次测试手动重新加载数据快了大约数万倍.

我觉得这很酷



2> Free Wildebe..:

对于简单的数据库应用程序,我发现使用SQLite非常有价值.它允许您为每个测试拥有一个独特的独立数据库.

但是它只有在你使用简单的通用SQL功能或者能够轻松隐藏SQLite和类后面的生产数据库系统之间的细微差别时才有效,但是我总是发现在SQL应用程序中我很容易发达.

推荐阅读
喜生-Da
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有