关于python:Python-自动化测试全攻略五种自动化测试模型实战详解

48次阅读

共计 2699 个字符,预计需要花费 7 分钟才能阅读完成。

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

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

(图片来自于网络)

对于自动化测试的定义,本文不再具体赘述。一般来说,自动化测试是指:从部分或全副代替人工,联合测试工具和测试标准,主动执行测试脚本及进步测试效率的过程。因而,咱们能够将自动化测试了解为一个集成体系,在这一体系中蕴含测试性能的函数库、测试数据源、测试对象规范,以及各种可重用的模块。

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

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

自动化测试倒退至今,先后产生了五种测试模型:线性模型、模块化驱动模型、数据驱动模型、关键字驱动模型和行为驱动模型。为了帮忙初入自动化测试行业的从业者疾速把握这些测试模型的根本应用办法,葡萄城公开课特地邀请到《Python Web 自动化测试入门与实战》的作者——杨定佳学生,为咱们在线解读“Python 自动化测试全攻略”,通过示例代码,详解这五种自动化测试模型的优缺点。欢送各位同学点击此处,报名加入:http://live.vhall.com/756567602。

线性模型

通过录制或编写脚本,一个脚本实现一个场景(一组残缺性能操作),通过对脚本的回放进行自动化测试。

测试脚本如下图所示(公开课后,可下载残缺代码):

从上图能够看出,线性测试模型的劣势就是每一个脚本都是独立的,任何一个脚本文件拿进去就能独自运行;当然,其毛病也很显著,就是测试用例的开发与保护老本很高,这种模式下数据和脚本是混在一起的,如果数据发生变化就须要对脚本进行批改,其用例的复用性较差。

模块化驱动模型

将脚本中反复可复用的局部拿进去写成一个公共的模块,须要的时候就调用它,这样能够大幅提高测试人员编写脚本的效率。

测试脚本如下图所示(公开课后,可下载残缺代码):

如上图所示,模块化驱动模型是将测试脚本中雷同的局部代码独立进去,造成模块或库,这样做有两个益处:

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

即便如此,模块化驱动模型仍未能齐全实现将数据和用例拆散,对前期的保护工作会产生肯定影响。

数据驱动模型

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

测试脚本如下图所示(公开课后,可下载残缺代码):

该模型的最大长处,就是实现了测试数据和测试脚本拆散,不论咱们读取的是数组、字典、函数,还是 csv、txt 等文件,咱们都能够通过传递参数,驱动脚本执行,返回不同的测试后果。

关键字驱动模型

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

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

通过上图的格局去形容不同的测试对象,就能够达到不同的测试后果。关键字驱动模型以对象为出发点,升高了自动化测试用例的编写难度,对于不懂代码的同学十分直观,可视化界面,带来了更高的工作效率和更低的保护门槛。

行为驱动模型

最初,本文将介绍一种在国外十分风行的测试模型——行为驱动模型,这套模型源自于麻利开发方法:行为驱动开发(Behave Driven Development,简称 BDD),即从用户的需要登程强调零碎行为。

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

测试脚本如下图所示(公开课后,可下载残缺代码):

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

测试报告如下图所示:

扩大常识

  1. 目前在 Python 中最风行的 BDD 框架是 Behave,它与其余基于 Gherkin 的 Cucumber 框架十分类似,当然还有其余 BDD 框架,比方 pytest-bdd 和 radish 等。
  2. 在应用 Selenium 执行自动化测试时,须要留神以下几点:

    • 查找网页元素的时候,留神网页中应用 frame 的状况,首先要应用 browser.switch_to.frame(“contentFrame”) 命令进入 frame 中,能力选中所需的元素。应用之后要记得返回上一级 frame,browser.switch_to.parent_frame()。Webmtc 次要应用 id 抉择和 xpath 获取元素,webmtc 网页中 class 应用的比拟少。
  • 留神页面刷新之后代码也会找不到 frame,比方呼叫建设之后页面会刷新,多点会议创立之后页面会刷新,点击设置界面和呼叫界面页面也会刷新。

以上,就是这五种自动化测试模型的根本介绍,在本期公开课上,讲师除了会顺次演示每一种模型的测试代码,还会针对 Web 自动化测试的相干技术(包含从自动化测试的根底到晋升、从实践到实际、从单个知识点到我的项目使用等)进行具体的解读,能够帮忙自动化测试零根底的初学者和心愿进入自动化测试行业的开发者疾速把握自动化测试的基本知识,并且具备肯定的 Web 自动化测试开发能力。欢送各位同学点击此处,报名加入:http://live.vhall.com/756567602。

正文完
 0