51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 1775|回复: 0
打印 上一主题 下一主题

Visual Studio 2008单元测试(3)_数据库测试

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2018-5-21 16:32:40 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
我们开发一个系统必须与数据库打交道,需要写N个SQL、存储过程、自定义函数、视图等,那么能否使用
Visual Studio 2008进行数据库测试吗?当然是可以的,下面我就以一个简单的为例子,介绍如何利用Visua
l Studio 2008进行数据库单元测试。

       第一步,在Visual 2008里面增加数据库测试,如下图所示:





       这样我们就添加好一个数据库单元测试,下面就是如何设置此单元测试是针对哪个数据库的。

第二步:指定当前测试项目的数据库配置

       当我们新增加一个数据库单元测试,Visual 2008会自动弹出配置界面,供我们设置数据库连接属性,
如下图:


       我们可以选择一个建立好的数据库连接:


       当然也可以新增一个连接,新增数据库连接比较简单,就是设置服务器地址、用户名、密码、数据库名
称等,在此就不介绍了。
       Visual 2008不仅支持我们连接一个已经存在的数据库,还可以运行单元测试前,自动部署一个数据库供测
试,
       连接好数据库后,下面将介绍如何进行单元测试。

       第三步:测试用例

       在Visual 2008数据库单元测试的“设计”界面,首先会有二个下拉框,如下图所示:


       左侧的下拉框即是数据库单元测试的每个“测试方法”,你可以把他当成代码单元测试的函数,系统默认
会有二个:公共脚本和DatabaseTest1,如下图:



公用脚本:在执行此单元测试前运行的SQL脚本,包括“测试初始化”和“测试清理”,即对应的准备数据的
脚本、测试完成后删除数据的脚本,可以保证每次执行单元测试时,数据都是一致的。
测试方法:可以新增、删除、重命名,可以通过增加测试方法来实现不同用例的验证。

第四步:编写测试脚本

       针对每个测试方法可以编写测试SQL脚本,即SQL语句,只要能够在测试数据库中正确执行的SQL语句
都可以,然后针对你编写的SQL语句执行的结果进行验证,如下图:



此段SQL语句是读取成本系统的业务参数,我们可以针对此SQL进行验证其正确性,Visual 2008支持六种测试
条件:


标量值:可以判断第几个结果集的第几行的第几列的值是多少,不相等则验证失败。
非空结果集:判断第几个结果集必须有记录,否则验证失败。
空结果集:判断第几个结果集必须没有记录,否则验证失败。
没有结论:无结论就是测试没有结果,注意当你新增加一个测试方法时,Visual会自动生成一个没有结论的测
试条件,如果你不需要,则手动删除掉。
行数:判断第几个结果集返回的行数,否则验证失败。
l 执行时间:判断执行时间必须少于多少,否则验证失败,用于性能测试。




       那么针对上面的SQL语句,我们可以验证返回的行数,可以通过行数的多少,验证成本系统的业务参数数
量是否正确,如下图:
      

       当返回的行数等于30时,代表数据库中的数量是正确的。当然你也可以增加其它测试条件,如使用标量值
验证参数的名称是否正确等。

       第五步:运行测试

       点击“运行测试”按钮即可得到测试结果,如下图所示:


      测试没有通过,可以查看错误信息:RowCountCondition 条件(rowCountCondition1)失败: 结果集 1: 32 行
与预期的 30 行不匹配。
       分析原因,数据库执行的结果有32行,与测试条件不匹配,修改测试条件,重新运行测试,测试通过,如
下图:


       Visual 2008数据库单元测试通过编写SQL脚本,然后设置不同的测试条件,通过验证测试条件是否匹配还
进行测试,因此你可以写任何SQL语句进行验证,这样就可以验证表记录、视图、存储过程、函数等,基本包
括了所有的数据库对象。
       我们可以通过数据库单元测试来保证我们每次修改数据库对象的正确性,也可以保证我们的SQL语句是否
提交,只要切换一下测试数据库即可,可以防止开发人员提交版本时漏掉提交SQL被测试打回的场景了。

       本篇简单介绍了Visual2008的数据库单元测试功能,下期将介绍如何利用Visual2008单元测试如何实现代码
覆盖率。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?(注-册)加入51Testing

x
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

本版积分规则

关闭

站长推荐上一条 /1 下一条

小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

GMT+8, 2024-11-23 09:16 , Processed in 0.065777 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2024 Comsenz Inc.

快速回复 返回顶部 返回列表