多测师是一家拥有先进的教学理念,强大的师资团队,业内好评甚多的接口自动化测试培训机构!

17727591462

联系电话

您现在所在位置:接口自动化测试培训 > 新闻资讯

自动化测试框架的发展及开发

更新时间:2022-08-08 09:24:17 作者:多测师 浏览:34

  自动化测试框架是自动化测试的核心,在开展自动化测试工作前,需要相应的自动化测试框架。一个好的自动化测试框架不但影响自动化测试的进程,也决定自动化测试的成败。

自动化测试框架的发展及开发

  一、自动化测试框架的发展

  基于界面的软件自动化测试框架经历了四个发展阶段:无框架→数据驱动→关键字驱动→混合模型。

  (1)无框架阶段(即简单的录制/回放)

  在早期,自动化测试并没有框架这一概念,只是简单的录制/回放,由工具录制并记录操作的过程和数据,并形成脚本,通过对脚本的回放重复人工操作的过程。这种模式脚本与数据混合在一起,导致一个测试用例对应着一个脚本,维护成本很高,并且当界面发生变化时,就得重新录制脚本,导致脚本的使用率很低。

  (2)数据驱动(Data Driven)框架阶段

  无框架阶段最大的缺点就是脚本与数据混合在一起,为了解决这一问题,自动化测试框架发展到数据驱动框架阶段,该框架从数据文件中读取数据,通过参数化的方式将数据文件中的数据写入脚本中,由于不同的数据对应着不同的测试用例,将脚本与数据彻底地分离,因此提高了脚本的使用率,大大降低了脚本的维护成本。虽然数据驱动框架解决了脚本与数据的问题,但并没有将被测试对象与操作分离。

  (3)关键字驱动(Keyword Driven)框架阶段

  关键字驱动测试是在数据驱动框架的基础上改进的一种框架模型。它将测试逻辑按照关键字进行分解,形成数据文件与关键字对应封装的业务逻辑。主要关键字包括三类:被测试对象(Item)、操作(Operation)和值(Value)。用面向对象形式将其表现为 Item.Operation(Value)。关键字驱动的主要思想是:脚本与数据分离、界面元素名与测试内部对象名分离、测试描述与具体实现细节分离。

  (4)混合框架(Hybrid Framework)阶段

  关键字驱动框架将自动化测试框架带入了一个新的阶段,自动化测试工具 QuickTest 也很好地使用了这个理念。但在实际开展自动化测试的时候,发现测试工具所带的关键字驱动方式还是无法很好地完成测试任务。该框架虽然将数据与脚本进行了分离,但是如果要更灵活地调用测试用例中的数据或输出测试结果,该框架无法做到;并且需要读取其他文件存储格式中的数据时也是无法很好地解决,这样在自动化测试开始的前期,工程师会开发一个符合实际测试的框架来支持后期的测试工作,这就是通常所说的混合模型自动化测试框架。

  随着自动化测试框架的不断发展,自动化测试脚本类型也在不断地发生变化。自动化测试脚本类型的发展经历了以下几个阶段:

  (1)线性脚本

  通过录制直接产生线性执行脚本。线性脚本无法对其逻辑或顺序进行任何的调整,产生的线性脚本只能按顺序一行一行地执行。该脚本类型对应着自动化测试框架发展中的无框架阶段。

  (2)结构化脚本

  很显然线性脚本无法处理逻辑和业务关系。为了解决该问题,在原来的线性脚本中添加了顺序、循环和分支等结构的脚本,形成结构化脚本。

  (3)共享脚本

  在实际测试过程中,需要将调试的脚本进行共享,供其他工程师调用,这样脚本类型就发展到了可共享的阶段。

  (4)数据驱动脚本

  数据驱动脚本将数据与流程控制进行分离,通过读入数据文件来驱动流程。

  (5)关键字脚本

  脚本、数据、业务分离,数据和关键字在不同的数据表中,通过关键字来驱动测试业务逻辑。

  二、自动化测试框架的开发

  自动化测试框架是由假设、约束以及为自动化测试提供支持的工具的集合。自动化测试框架最大的优点是可以减少测试脚本实现和维护的成本,测试用例只需要修改测试用例文件,而不需要更新脚本驱动程序和引擎驱动程序。自动化测试框架的优劣直接影响到自动化测试的成功与否。

  假设自动化测试框架是形成自动化测试策略的基础,下面是常用的假设条件:

  (1)集成工具套件必须是主要的测试管理、计划、开发和实现的工具。

  (2)工具套件必须用来指导和控制测试的执行并且用来捕获、分析、报告测试结果。

  (3)工具套件必须包括一个可选工具,用于缺陷跟踪及解决。

  (4)工具套件必须包括一个可选的配置管理工具。

  (5)配置管理只能对手工测试和自动化测试产物进行配置管理。

  (6)所有上述工具必须与桌面工具结合,比如 Microsoft Office。

  (7)测试工程师需要的桌面—脚本—开发配置必须被定义并且被实现。

  (8)必须遵循测试标准,并且测试标准以文档形式记录下来。

  约束条件影响着自动化测试是否成功,如果不注意以下约束条件,自动化测试工作将很难成功:

  (1)自动化工具集资源必须独立于任何手工测试集。

  (2)自动化测试小组中是否有足够多的工作人员。

  (3)对于自动化工具的使用,软件开发小组的协调水平和管理水平不能太低。

  (4)在创建可测试应用过程中,需要与开发者协作和信息交流。

  (5)自动化测试的主要版本和自动化测试的发布进度安排有关系。

  一般自动化测试框架应该包括四部分内容:测试管理、数据驱动、结果分析和测试报告。

  (1)测试管理的主要任务是运行控制脚本、负责建立并维护运行队列、控制运行策略和信号灯。在管理端还必须维护一个测试任务的队列,每个测试脚本开始执行的时间可能不同,状态也不一样,测试管理模块应该能很好地处理这些脚本的执行。

  (2)数据驱动的主要任务是将脚本与测试数据分离,这部分是框架的核心,一般测试数据来自于自动化测试用例中的数据输入。通过数据驱动模块可以将测试用例中的数据读取到脚本中,实现同一脚本执行多测试用例的功能。

  (3)结果分析的主要任务是判断实际结果与预期结果是否一致,为输入测试结果做准备,测试过程中判断测试用例执行是否成功不仅仅是界面显示,还包括对数据库、相关文件(日志文件和配置文件等)的检查,结果分析模块主要是封装这些检查的函数和方法。

  (4)测试报告主要是在执行测试完成后,输出一份日志文件和一份测试报告,日志文件主要是便于分析测试结果,判断失败的结果是否是由脚本开发的原因引起的。测试报告主要是用于记录测试结果,至少需要记录每个测试用例执行的结果。

  以上内容为大家介绍了自动化测试框架的发展及开发,本文由多测师亲自撰写,希望对大家有所帮助。了解更多自动化测试相关知识:https://www.aichudan.com/xwzx/

联系电话

17727591462

返回顶部