原文地址:http://www./?26649/action_viewspace_itemid_1224.html 前言: 最近看了不少朋友写的blog文章后,就越显自己的文章比较稚嫩.但我觉得这也是一种学习的方式,现在抱着一种共同学习的态度来探讨一下数据驱动在QTP中运用.很希望看我文章朋友能不吝啬的发表一下自己对这个方面的看法,那真是万分感谢啊. 所谓数据驱动就是用一个数据文件把测试脚本驱动起来,来达到更接近用户化更智能的测试.其目的是把测试人员从维护复杂的脚本程序中解放出来,只需维护好数据文件即可,减少了很多修改脚本的麻烦.下面讲一下通过四种途径来达到数据驱动. 1.datatable QTP本身程序就给我们提供了这么一个数据表,我们可以把测试数据或测试用例填入这个数据表中. 如:设计用例 case1 mercury case2 录制脚本 For i=1 to Datatable.GetRowCount Dialog("Login").WinEdit("Agent Name:").Set DataTable("username", dtGlobalSheet) Next 本例是验证一个登录系统,通过DataTable不同的用例设计,驱动起这段脚本,达到测试的效果.当然上面的例子中还少一个很重要的步骤,那就是结果比较.如果不能进行结果比较的自动化测试不能够称为自动化测试. 当然我们这里主要讲的是数据驱动,所以不在对上面的例子进行补充. 2.文本文件 我们可以把文本文件当成数据文件,通过对文本文件的读写操作,来实现数据驱动. 例:文本文件内的内容 mercury,mercuy 读文件的代码 Function writeorderno(orderno) Dim fso, myfile,username,passwd passwd=tmp(1) myfile.close 写文本文件的代码 Function writeorderno(orderno) Dim fso, myfile Set myfile=fso.openTextFile("C:\result1.txt",8,false) myfile.writeline orderno 3.EXCEL文件 我们可以把EXCEL文件当成数据文件,通过对EXCEL文件的读写操作,来实现数据驱动. 可以把EXCEL文件当作对象的方式来完成写的操作 Dim Excel,ExcelSheet ExcelSheet.ActiveSheet.Cells(1,2).value=2 ExcelSheet.ActiveSheet.Cells(1,3).value=3 Excel.Save "C:\test.xls" Set ExcelSheet=Nothing 用ADO的方式连接EXCEL文件来做读的操作
4.数据库 可以利用设计数据表,把测试数据和测试用例放在数据表里,用ADO或者其他任何可以访问连接数据库的方式连接数据库,来实现数据驱动 Dim res,cmd,sql 以上四种方法都可以帮助我们实现数据驱动,应该说数据驱动在自动化测试中运用的比较的广泛,才有必要拿出来探讨一下. |
|