自动化测试对录制和编辑好的测试步骤进行回放,这种是线性的自动化测试方式,其缺点是明显的,就是其测试覆盖面比较低。测试回放的只是录制时做出的界面操作,以及输入的测试数据,或者是脚本编辑时指定的界面操作和测试数据。

如何让测试脚本执行时,不仅仅局限于测试录制或者编辑时的测试数据呢?数据驱动的测试方式是解决这个问题的最佳方案。数据驱动测试把测试脚本中的测试数据提取出来,存储到外部文件或数据库中,在测试过程中,从文件动态读入测试数据。

在QTP中,可以通过把测试脚本中固定的值替换成参数的方式来扩展测试脚本,这个过程也叫参数化测试。对于QTP可以使用多种方式来对测试脚本进行参数化,数据表参数化,环境变量参数化,随机数参数化等等。

一.数据驱动测试的一般步骤

1.参数化测试步骤的数据,绑定到数据表格中的某个字段;

2.编辑数据表格,在表格中编辑多行测试数据(取决于测试用例以及测试覆盖率的需要);

3.设置迭代次数,选择数据行,运行测试脚本每次迭代从中选择一行数据;

二.数据表参数化

比如,我录制了一段打开QTP自带的“Flight”程序的脚本,包含登陆步骤和查询航班信息步骤:

上面的脚本仅能检测特定的航班订票记录,现在我希望测试脚本对多个航班都进行查询,那么我们就需要进行参数化。

下面以“Fly From”的测试步骤的参数化过程为例,介绍如何在关键字视图中对测试脚本进行参数化。

(1)选择“Fly From:”所在的测试步骤行,单击“value”列所在的单元格,单击单元格旁边的“<#>”按钮,或者按快捷键“CTRL+F11”,则会出现下面的界面:

(2)选择第二个选项“Parameter”,默认是“Data Table”,“name”中输入参数化数据所在列的名字,最好自己编辑,不要使用默认值,方便在多个数据参数化后辨认。

在“Location in Data Table”中科院选择“Global sheet”,或者是“Current action sheet(local)”,区别仅仅是参数存储位置的不同。

点击OK按钮之后,在关键字视图中可看到,“value”值已经被参数化,替换成了“Data Table("<fly_from>")”。同时在Data Table(选择菜单“View|Data Table”打开)中可以看到刚刚“fly from”的默认值被自动写入表格中,继续编辑输入其他数据,得到如下图所示的界面:

(3)运行

由于刚刚的例子中还包含了登陆的操作,如果就这样执行遍历data table中的数据,登陆操作也会被重复执行3次的。所以我们要先把登陆操作删除掉,再来运行需要遍历的操作。

我尝试了点击查询操作,再选择“run from step”,但是这样就不能实现参数化的操作了,只能执行一遍。有没有其他不需要删除login操作的办法来实现参数化呢?请各位大神指教。

删除login操作之后,我们来正式运行。这个运行之前需要先设置2个地方:

1)点击菜单栏的“File”,再选择“settings....”,打开如下的界面,选择Run:

可以看到Data Table iterations下有三个设置,可以选择“Run on all rows”(data table里的数据全部执行),或者是选择“Run from row x

to row xx”(仅执行data table里的特定几行数据)。

选择好之后,点击 apply,再点击OK

2)选中action,点击右键,选择“Action Call Properties...”,打开设置界面,

  -----> 

如右上图,需要设置的内容跟刚刚的第一个设置是一样的,需要注意的是这里的设置要跟第一个设置完全一样。

最后,就可以执行运行操作遍历所有参数例子了。

最后可以看看这个文章里关于Globle Sheet和Local Sheet的区别:http://www.cnblogs.com/bangbangjiang/p/3830136.html

参数化测试--sheet表的应用的更多相关文章

  1. MSTest不支持参数化测试的解决方案

    之前的项目中做单元测试一直用的是NUnit,这次做新项目,负责人要求统一用MsTest,理由是MsTest是Visual Studio内置的.用就用吧,我没什么意见.不过用了两天,我就发现一个大问题: ...

  2. 计算某天的下一天:黑盒测试之等价类划分+JUnit参数化测试

    题目要求 测试以下程序:该程序有三个输入变量month.day.year(month.day和year均为整数值,并且满足:1≤month≤12.1≤day≤31和1900≤year≤2050),分别 ...

  3. Easypoi实现excel多sheet表导入导出功能

    Easypoi简化了开发中对文档的导入导出实现,并不像poi那样都要写大段工具类来搞定文档的读写. 第一步引入Easypoi依赖 <!-- 导出文件工具 EasyPoi实现Excel读写管理测试 ...

  4. JUnit5学习之六:参数化测试(Parameterized Tests)基础

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  5. Google C++单元测试框架GoogleTest---值参数化测试

    值参数化测试允许您使用不同的参数测试代码,而无需编写同一测试的多个副本. 假设您为代码编写测试,然后意识到您的代码受到布尔参数的影响. TEST(MyCodeTest, TestFoo) { // A ...

  6. JMeter学习-026-JMeter 分布式(远程)参数化测试实例

    以前文所述对文章详情的HTTP请求进行性能测试为例.日常实际场景中,不可能所有的人都在同时访问一篇文章,而是多人访问不同的文章,因而需要对文章编号进行参数化,以更好的模拟日常的性能测试场景.同时,因文 ...

  7. c# applibrary实现一个Sheet表中存放多张DataTable数据

    1.工具类(applibrary.dll) public class ExcelHelper { /// <summary> /// 文件名 /// </summary> pu ...

  8. Junit4参数化测试实现程序与用例数据分离

    http://touchfu.iteye.com/blog/732930 现状:你是不是还在为自己的TestCase代码杂乱无章而苦恼,咎其根本还在于针对不同的用例,输入参数和mock信息的组装全部作 ...

  9. 同时使用Junit4的@Parameterized参数化测试和Spring容器

    转载:http://www.jianshu.com/p/d191fe54915f 整合Spring容器 @SpringApplicationConfiguration(classes = Applic ...

随机推荐

  1. Swift - 可选类型说明

    可选类型是Swift的一个特色.它表示一个变量有可能有值,也可能没有值(nil). 声明的方式是“数据类型+问号”. 而当要使用一个可选类型的变量是,要在后面加感叹号“!”. 1 2 3 4 5 6 ...

  2. MSYS2 环境搭建(在Qt Creator可以设置环境变量来进行引用这些库)

    本机环境:Windows XP 32位MSYS2地址:http://sourceforge.net/projects/msys2/ 下载32位版本,地址:http://sourceforge.net/ ...

  3. Android 特殊符号的转码大全

    项目中要在string.xml 中显示特殊符号,如@号冒号等,直接写肯定不行啦..只能考虑使用ASCII码进行显示: @号 @ :号 : 空格   以下为常见的ASCII十进制交换编码: --> ...

  4. UVa 11371 - Number Theory for Newbies

    題目:給你一個數字n.將裡面每位的數又一次組合形成a,b.使得a-b最大且是9的倍數. 分析:數論. 題目要求a,b和n的位數同样,不能有前導0. 定理1:交換一個數字中的某兩個位的數,形成的新數組和 ...

  5. Swift - 工具条(UIToolbar)的用法

    1,UIBarButtonItem是工具条按钮,有如下5种init初始化方法: (1)初始化为普通图片按钮 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 1 ...

  6. Delphi读写UTF-8、Unicode格式文本文件

    // UTF-8文件写入函数procedure SaveUTFFile(const FileName: string; S: string; WriteHeader: Boolean = True); ...

  7. 利用PHP SOAP扩展实现简单Web Services

    原文:利用PHP SOAP扩展实现简单Web Services WebServices能干什么? WebServices 可以将应用程序转换为网络应用程序. 通过使用 WebServices,您的应用 ...

  8. Android显示GIF图片

    今天我们研究一下怎样在Android手机上显示GIF动态图片 首先须要在src文件夹下新建一个自己定义的View.代码例如以下: </pre><pre name="code ...

  9. cocos2dx--两个场景切换各函数调用顺序

    场景A切换到场景B,有切换特效 调用顺序例如以下:(AAABABABA) A:构造函数 A:onEnter A:onEnterTransitionDidFinish B:构造函数 A:onExitTr ...

  10. poj3468 A Simple Problem with Integers(线段树模板 功能:区间增减,区间求和)

    转载请注明出处:http://blog.csdn.net/u012860063 Description You have N integers, A1, A2, ... , AN. You need ...