TestComplete的数据驱动测试方法

2024-03-26 07:08

本文主要是介绍TestComplete的数据驱动测试方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

TestComplete 的数据驱动测试方法
陈能技
2007-9-5
自动化测试把记录的或编写的用户操作序列的脚本回放,能覆盖被测软件的一部分特定的区域。为了获取大面积的覆盖,你可以用不同的数据来输入。如果你测试一个窗体的输入,录制完脚本后,你只是获得了录制时输入的数据的脚本。而且通常你录制时指定的数据不会引起程序的错误,但是其他数据可能会。Data-Driven Testing,数据驱动测试让你用不同的数据输入来测试软件,确保软件在各种输入情况下都工作正常。
数据驱动方法
最好的解决方案是把数据从脚本分离开来。数据驱动测试指的是脚本从外部存储点读入数据,例如,从一个文件或数据库,而不是使用硬编码的数据值。这样的分离会使测试逻辑更加简单。硬编码数据值会使脚本维护和修改更加困难。例如,如果你想要更多的输入数据,你就必须修改脚本代码。
数据驱动方法的步骤
通常,外部存储的数据会包括输入数据和验证数据。数据驱动方法的测试步骤包括下面操作的循环执行:
1、 从存储点读入数据
2、 在软件窗体上输入数据
3、 检验结果
4、 用下一项数据继续执行
第一步:读入数据
TC提供很多内建的方法来支持数据驱动,从文本文件、Excel表、数据库等地方读入数据。
GetCSVCount和GetCSVItem用于处理CSV文件存储的数据。TC还提供DDT对象用于数据访问驱动,从Excel表格、数据库和CSV文件获取数据。DDT包括ADODriver、CSVDriver、ExcelDriver。
下面脚本建立一个ExcelDriver从MyFile.xls中读入Sheet1表格,然后用EOF和Next方法遍历整张表格,最后用CloseDriver方法关闭Excel驱动。
procedure TestDriver;
var
  Driver : OleVariant;
begin
   // Creates the driver
  Driver := DDT.ExcelDriver('C:/MyFile.xls', 'Sheet1');
  
   // Iterates through records
  RecNo := 0;
   while not Driver.EOF do
   begin
    ProcessData; // Processes data
    Driver.Next; // Goes to the next record
   end;
  
   // Closing the driver
  DDT.CloseDriver(Driver.Name);
end;
第二步:利用数据
获取数据后,就可以在界面上输入这些数据,可以通过模拟键盘输入,或者给控件的属性赋值,从而模拟用户的数据输入。例如,下面脚本给窗体的Caption属性赋值:
w := p.Window('MainForm', '', 1);
SetValue(w, 'Caption', 'New Caption');
第三步:检查结果
最简单的检查结果是否正确的方式是把要检查的值也和输入数据存储在一起,然后读入检查的值,与真正的输出值进行比较。
如果输出的是文件或图像,可以使用TC提供的文件和图像比较方法来进行比较。参考《TestComplete的Stores对象》。
 

这篇关于TestComplete的数据驱动测试方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/847661

相关文章

详解如何使用Python构建从数据到文档的自动化工作流

《详解如何使用Python构建从数据到文档的自动化工作流》这篇文章将通过真实工作场景拆解,为大家展示如何用Python构建自动化工作流,让工具代替人力完成这些数字苦力活,感兴趣的小伙伴可以跟随小编一起... 目录一、Excel处理:从数据搬运工到智能分析师二、PDF处理:文档工厂的智能生产线三、邮件自动化:

Python数据分析与可视化的全面指南(从数据清洗到图表呈现)

《Python数据分析与可视化的全面指南(从数据清洗到图表呈现)》Python是数据分析与可视化领域中最受欢迎的编程语言之一,凭借其丰富的库和工具,Python能够帮助我们快速处理、分析数据并生成高质... 目录一、数据采集与初步探索二、数据清洗的七种武器1. 缺失值处理策略2. 异常值检测与修正3. 数据

pandas实现数据concat拼接的示例代码

《pandas实现数据concat拼接的示例代码》pandas.concat用于合并DataFrame或Series,本文主要介绍了pandas实现数据concat拼接的示例代码,具有一定的参考价值,... 目录语法示例:使用pandas.concat合并数据默认的concat:参数axis=0,join=

C#代码实现解析WTGPS和BD数据

《C#代码实现解析WTGPS和BD数据》在现代的导航与定位应用中,准确解析GPS和北斗(BD)等卫星定位数据至关重要,本文将使用C#语言实现解析WTGPS和BD数据,需要的可以了解下... 目录一、代码结构概览1. 核心解析方法2. 位置信息解析3. 经纬度转换方法4. 日期和时间戳解析5. 辅助方法二、L

使用Python和Matplotlib实现可视化字体轮廓(从路径数据到矢量图形)

《使用Python和Matplotlib实现可视化字体轮廓(从路径数据到矢量图形)》字体设计和矢量图形处理是编程中一个有趣且实用的领域,通过Python的matplotlib库,我们可以轻松将字体轮廓... 目录背景知识字体轮廓的表示实现步骤1. 安装依赖库2. 准备数据3. 解析路径指令4. 绘制图形关键

解决mysql插入数据锁等待超时报错:Lock wait timeout exceeded;try restarting transaction

《解决mysql插入数据锁等待超时报错:Lockwaittimeoutexceeded;tryrestartingtransaction》:本文主要介绍解决mysql插入数据锁等待超时报... 目录报错信息解决办法1、数据库中执行如下sql2、再到 INNODB_TRX 事务表中查看总结报错信息Lock

使用C#删除Excel表格中的重复行数据的代码详解

《使用C#删除Excel表格中的重复行数据的代码详解》重复行是指在Excel表格中完全相同的多行数据,删除这些重复行至关重要,因为它们不仅会干扰数据分析,还可能导致错误的决策和结论,所以本文给大家介绍... 目录简介使用工具C# 删除Excel工作表中的重复行语法工作原理实现代码C# 删除指定Excel单元

Linux lvm实例之如何创建一个专用于MySQL数据存储的LVM卷组

《Linuxlvm实例之如何创建一个专用于MySQL数据存储的LVM卷组》:本文主要介绍使用Linux创建一个专用于MySQL数据存储的LVM卷组的实例,具有很好的参考价值,希望对大家有所帮助,... 目录在Centos 7上创建卷China编程组并配置mysql数据目录1. 检查现有磁盘2. 创建物理卷3. 创

Nacos日志与Raft的数据清理指南

《Nacos日志与Raft的数据清理指南》随着运行时间的增长,Nacos的日志文件(logs/)和Raft持久化数据(data/protocol/raft/)可能会占用大量磁盘空间,影响系统稳定性,本... 目录引言1. Nacos 日志文件(logs/ 目录)清理1.1 日志文件的作用1.2 是否可以删除

使用Python获取JS加载的数据的多种实现方法

《使用Python获取JS加载的数据的多种实现方法》在当今的互联网时代,网页数据的动态加载已经成为一种常见的技术手段,许多现代网站通过JavaScript(JS)动态加载内容,这使得传统的静态网页爬取... 目录引言一、动态 网页与js加载数据的原理二、python爬取JS加载数据的方法(一)分析网络请求1