自动化测试指软件测试的自动化,在预设状态下运行应用程序或者系统预设条件包括正常和异常,最后评估运行结果。将人为驱动的测试行为转化为机器执行的过程。
Jmeter:性能测试工具,可以进行接口测试 Loadrunner:性能测试工具 soupui,postman:接口测试 appium:APP自动化测试(IOS,Andrio均可) selenium:web的自动化测试工具
自动化测试框架一般可以分为两个层次,上层是管理整个自动化测试的开发,执行以及维护,在比较庞大的项目中,它体现重要的作用,它可以管理整个自动测试,包括自动化测试用例执行的次序、测试脚本的维护、以及集中管理测试用例、测试报告和测试任务等。下层主要是测试脚本的开发,充分的使用相关的测试工具,构建测试驱动,并完成测试业务逻辑。
自动化测试的演变:测试工具----数据驱动----关键字驱动----测试框架----测试平台
降低大型系统的由于变更或者多期开发引起的大量的回归测试的人力投入,这可能是自动化测试最主要的任务,特别是在程序修改比较频繁时,效果是非常明显的,自动化测试前期人力投入较多,但后期进入维护期后,可节省大量人力,而手工测试后期需要增加大量人力用于回归测试
减少重复测试的时间,实现快速回归测试 创建优良可靠的测试过程,减少人为错误 可以运行更多更繁琐的测试 可以执行一些手工测试困难或不可能进行的测试 更好的利用资源 测试具有一致性和重复性 测试脚本的重用性
实施自动化测试的前提条件:需求变动不频繁、项目周期足够长、自动化测试脚本可重复使用
需求变动频繁的项目,自动化脚本不能重复使用,维护成本太大,性价比低 项目周期短,自动化脚本编制完成后使用次数不多,性价比低 交互型较强的项目,需要人工干预的项目,自动化无法实施1、产品型项目。产品型的项目,新版本是在旧版本的基础上进行改进,功能变不大的项目,但项目的新老功能都必须重复的进行回归测试。回归测试是自动化测试的强项,它能够很好的验证你是否引入了新的缺陷,老的缺陷是否修改过来了。在某种程度上可以把自动化测试工具叫做回归测试工具。
2、机械并频繁的测试。每次需要输入相同、大量的一些数据,并且在一个项目中运行的周期比较长。
1、期望值过高。就像管理人员要求完全测试一样,期望100%的测试自动化,也同样是一个不现实的需求。
2、对收益和成本认识不清。抛开工具的开发或者购买成本和培训成本,自动化测试的成本应该还包括两部分(实现成本中还隐含了测试准备成本):成本=实现成本+运行维护成本 自动化测试的收益是由测试脚本的重复运行次数,或自动测试脚本的利用率决定的