python 自动化测试_Python 自动化测试全攻略:五种自动化测试模型实战详解

随着移动互联网的发展,软件研发模型逐步完善,软件交付质量越来越受到软件公司的重视,软件测试技术特别是自动化测试技术开始在软件系统研发过程中发挥着越来越重要的作用。

与传统的手工测试技术相比,自动化测试具备了良好的可操作性、可重复性和高效率等特点,能够更加全面、快速地执行测试用例,在保证产品质量的前提下实现软件产品的快速迭代。

75f2d924024d47b43996410a1e9600e7.png

(图片来自于网络)

关于自动化测试的定义,本文不再详细赘述。一般来说,自动化测试是指:从局部或全部代替人工,结合测试工具和测试规范,自动执行测试脚本及提高测试效率的过程。因此,我们可以将自动化测试理解为一个集成体系,在这一体系中包含测试功能的函数库、测试数据源、测试对象标准,以及各种可重用的模块。

自动化测试相对于手工测试而言,其主要进步在于自动化测试模型的引入,自动化测试工具是“死”的,它不具备任何想象力。因此,自动化测试的好坏,完全取决于测试工程师对于测试模型的选择,性能更高的测试模型,会带来更快的测试速度和更高的测量精确度。

自动化测试模型都有哪些?

自动化测试发展至今,先后产生了五种测试模型:线性模型、模块化驱动模型、数据驱动模型、关键字驱动模型和行为驱动模型。

3db2c4437ad24e31ef78f4425ed80dcb.png

线性模型

通过录制或编写脚本,一个脚本完成一个场景(一组完整功能操作),通过对脚本的回放进行自动化测试。

9610a41bc2199e2e3701073196da950c.png

测试脚本如下图所示:

656f02123819675af9ea666440e0a00d.png

从上图可以看出,线性测试模型的优势就是每一个脚本都是独立的,任何一个脚本文件拿出来就能单独运行;当然,其缺点也很明显,就是测试用例的开发与维护成本很高,这种模式下数据和脚本是混在一起的,如果数据发生变化就需要对脚本进行修改,其用例的复用性较差。

模块化驱动模型

将脚本中重复可复用的部分拿出来写成一个公共的模块,需要的时候就调用它,这样可以大幅提高测试人员编写脚本的效率。

4f774cba1a7b9373702ee81b71931d47.png

测试脚本如下图所示:

7de2d493e2d311e6802f47767e05b01e.png

如上图所示,模块化驱动模型是将测试脚本中相同的部分代码独立出来,形成模块或库,这样做有两个好处:

  1. 提高了开发效率和代码复用性,测试人员不用重复的编写相同的脚本,如果提前写好了一个测试模块,后续只需要进行调用即可,不同重复造轮子。
  1. 简化了代码的维护工作,如果测试模块发生了变化,只用修改login.py 文件中相应模块的代码即可,所有调用该模块的脚本不用做任何修改。

即便如此,模块化驱动模型仍未能完全实现将数据和用例分离,对后期的维护工作会产生一定影响。

数据驱动模型

为了解决线性模型和模块化驱动模型的短板,数据驱动模型就此诞生。该模型会根据数据的变化而引起测试结果的改变,这显然是一个非常高级的概念和想法。简单地说,该模型是一种数据的参数化呈现,即通过输入不同的参数来驱动程序执行,输出不同的测试结果。

44ac6345c4dd7484fb3faf72ff2f1ce9.png

测试脚本如下图所示:

df823313bdce7ecdb9ed823b665e1251.png

该模型的最大优点,就是实现了测试数据和测试脚本分离,不管我们读取的是数组、字典、函数,还是csv、txt 等文件,我们都可以通过传递参数,驱动脚本执行,返回不同的测试结果。

关键字驱动模型

这是一种通过关键字的改变而引起测试结果改变的功能自动化测试模型。QTP、robot framework 等都是以关键字驱动为主的自动化测试工具,这类工具典型的特征就是具备一套易用的可视化界面,测试人员需要做的就是将测试脚本按照“填表格”的方式填入,并考虑三个问题就可以了:我要做什么? 对谁做?怎么做?

cc63ffb184a7a42e5e6e211034720ba0.png

本文所使用的Selenium IDE 就是一种关键字驱动的自动化工具,Selenium IDE 的脚本通常包含:命令(command)、对象(target)和值(value)三部分,测试脚本可直接在浏览器中运行,就像真正的用户在操作一样。

285ddf91a9ccdcbdf49c5501889a81ca.png

通过上图的格式去描述不同的测试对象,就可以达到不同的测试结果。关键字驱动模型以对象为出发点,降低了自动化测试用例的编写难度,对于不懂代码的同学非常直观,可视化界面,带来了更高的工作效率和更低的维护门槛。

行为驱动模型

最后,本文将介绍一种在国外非常流行的测试模型——行为驱动模型,这套模型源自于敏捷开发方法:行为驱动开发(Behave Driven Development,简称BDD),即从用户的需求出发强调系统行为。

通过将BDD借鉴到自动化测试中,便产生了行为驱动测试模型,这种模型通过使用自然描述语言确定自动化测试脚本,其优点是可使用自然语言编写测试用例。

8355807092ca99b1e1d02bddaa3849ce.png

测试脚本如下图所示:

8a439219d6cfc1a4f84846a46340f070.png

fab6a7a6e503e9a24dcffbb778179bd3.png

如上图所示,用例的写法基本和功能测试用例的写法类似,这样具有良好协作的益处。行为驱动测试模型使每个人都可以参与到开发测试中,不仅仅是程序员。该模型下每个测试场景都是一个独立的行为,且已有的行为可以被重复使用。

测试报告如下图所示:

44038c2b51d21166e1f8fd469f9063bd.png

扩展知识

  1. 目前在Python中最流行的 BDD 框架是Behave,它与其他基于 Gherkin 的 Cucumber 框架非常相似,当然还有其他BDD框架,比如pytest-bdd和radish等。
  1. 在使用Selenium执行自动化测试时,需要注意以下几点:

- 查找网页元素的时候,注意网页中使用frame的情况,首先要使用browser.switchto.frame("contentFrame")命令进入frame中,才能选中所需的元素。使用之后要记得返回上一级frame,browser.switchto.parent_frame()。Webmtc主要使用id选择和xpath获取元素,webmtc网页中class使用的比较少。

  • 注意页面刷新之后代码也会找不到frame,比如呼叫建立之后页面会刷新,多点会议创建之后页面会刷新,点击设置界面和呼叫界面页面也会刷新。

以上,就是这五种自动化测试模型的基本介绍

最后,小编想说:我是一名python开发工程师,整理了一套最新的python系统学习教程,
想要这些资料的可以关注私信小编“01”即可(免费分享哦)希望能对你有所帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值