测试人如何高效地设计自动化测试框架?

  关于测试框架的好处,例如快速回归以提高测试效率和测试覆盖率,我们在此不做讨论。 这里我们主要讨论自动化框架包括什么以及如何设计一个测试框架。

  什么是自动化测试框架?

  它是由一个或多个自动化测试基础模块、自动化测试管理模块、自动化测试统计模块等组成的工具集合。以常见的前端UI测试为例,一个测试框架大致包括测试对象等模块, 测试组件、基本类和函数、工具类、测试数据、异常处理、测试日志、断言和测试报告。 在设计测试框架时,应尽量将这些模块有机地结合起来,使脚本能够有效地组织和连贯地应用,从而提高测试脚本的可维护性和可读性。

  没有通用的测试框架,但是好的框架可以提高工作效率。

  由于应用系统技术的多样性,几乎没有一个测试框架可以应用于多个项目并体现其应有的价值。 因此,一般情况下,我们需要根据项目本身来定制我们的测试框架。 常用的数据驱动、关键字驱动以及两者的混合。

  数据驱动(DDT)——如果被测系统的业务逻辑是固定的或者变化很小的,我们可以使用数据驱动,通过不同的数据来保证测试覆盖率。 通常数据存储在外部文件或数据库中。 自动获得。 特点是数据和测试脚本分离,基于模块化测试库,一个驱动脚本可以执行多个类似的测试,创建新的测试非常容易。

  关键字驱动 - 将数据与关键字结合起来,描述如何使用数据来执行测试。 这种方法具有数据驱动的优势,同时也使非程序员能够创建新类型的测试。

  

  ​

  添加图片注释,不超过 140 字(可选)

  设计框架思路:

  一个。 高内聚低耦合:高内聚是指各个模块尽可能独立地完成自己的功能,而不依赖于模块外的代码; 低耦合意味着模块和模块之间接口的复杂性,比如在一个类内尽可能减少方法之间的调用,否则一个方法的变化会影响另一个调用它的方法。

  脚本分离:对象、测试数据、业务逻辑相互分离,灵活调用。 前端UI测试可以得到明显的结果。 我们可以使用PageObject设计模式来实现对象和业务逻辑的分离,使用DataProvider来实现数据业务。 逻辑分离。

  用简单的模块化设计,提高脚本的可重用性

  如果时间充裕且项目支持,可以按照以下顺序进行测试:页面对象-功能点-业务逻辑-业务流程。

  在实现上是:首先测试底层页面操作对象,通过调用操作对象和业务逻辑来验证功能点,然后通过调用业务逻辑和组合功能点来实现对业务流程的验证。 不同的业务流程对于底层的操作组件和中间层的功能点功能是完全可以复用的,只是调用的业务逻辑不同,或者测试数据的不同。 这样做的好处是脚本相互独立,代码复用,易于维护。 如果有新的业务流程,可以调用已有的代码进行合并。

  封装的基本方法是:

  对于一些比较通用的方法,可以进行封装,比如log、assert、异常处理、文件读写操作、数据库读写操作、保存页面截图等,需要的时候可以直接在测试用例中调用。

  如何进行自动化测试

  抓好业务测试工作痛点和领导痛点,多交流多沟通,优先解决基层工作痛点。 相信一个好的领导会看到你的责任心和奉献精神;

  在技​​术选择和解决方案的可行性研究上投入更多的时间和精力。 有些人很着急,前期做得很快。 如果一开始方向错了,最终会得不偿失;

  如果是比较复杂的方案,尽量做到前后端分离,保证各个模块的独立、集成、解耦和不解体,灵活可扩展,为下一场大戏做好准备。

  如需了解更多测试技术信息请关注:深圳多测师软件与技术服务有限公司

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

多测师111

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值