当今激烈的商业竞争中,企业中的服务和产品需要更快速的版本迭代和高质量的软件交付,同时减少完成项目所需的成本和时间,不少企业引入了DevOps概念来提升软件研发交付效率。DevOps是开发和运营的结合,代表着一种文化和实践,强调了软件开发人员(Dev)和信息技术(IT)运营与维护(O&M)专业人员(Ops)的协作和交流。
它旨在建立一种文化和环境,使软件构建,测试和发布可以更加方便,频繁和可靠地进行。DevOps中的测试是自动化的,不同于传统的手工测试,自动化测试通过测试工具或者框架,录制编写测试脚本,对软件功能进行测试,能够快速检测错误并查找可能对用户体验产生负面影响的问题,从而更快的发布高质量产品。
本文通过介绍自动化测试体系概念,带你了解自动化测试在实现高质量产品方面的重要作用。具体内容如下:
什么是自动化测试
为什么要进行自动化测试
手工测试和自动化测试之间的区别
自动化测试如何与DevOps相适应
猪齿鱼Choerodon如何进行自动化测试
1.什么是自动化测试
自动化测试是使用工具、脚本和软件对重复、预定义的操作来执行测试用例的过程。由于自动化测试是通过自动化工具完成的,因此在增加总体测试覆盖率的同时,它在探索性测试中花费的时间更少,在维护测试脚本时花费的时间更多。
自动化测试的基本概念是测试金字塔。它演示了如何解决项目的自动化测试:构成金字塔基础的哪些部分首先要进行测试,以及在金字塔最后阶段剩下什么?
按照测试金字塔的模式,首先是单元测试层,即开发人员在编写代码时经常执行的代码测试。然后是API测试所属的服务器层。稍后,当前端完成时,将进行UI测试。
自动化测试的类型
- 冒烟测试:针对每个版本或每次需求变更后,在正式测试前,对产品或系统的一次简单的验证性测试
- 单元测试:对软件中的最小可测试单元在与程序其他部分相隔离的情况下进行检查和验证的工作
- 集成测试:是组装软件的系统测试技术,按设计要求把通过单元测试的各个模块组装在一起之后,进行综合测试以便发现与接口有关的各种错误
- 功能测试:是黑盒测试的一方面,它检查实际软件的功能是否符合用户的需求,比如说逻辑功能测试,界面测试,易用性测试,安装/卸载测试,兼容性测试等
- 性能测试:通过自动化的测试工具模拟多种正常、峰值以及异常负载条件来对系统的各项性能指标进行测试
- 回归测试:指修改了旧代码后,重新测试以确认修改没有引入新的错误或导致其他代码产生错误
- 数据驱动测试:一种在软件测试过程中使用的方法,用于描述直接测试的输入、可验证输出的条件表,以及测试环境的设置还有控制编码的过程
- 黑盒测试:又称为功能测试、数据驱动测试或基于规格说明书的测试,是一种从用户观点出发的测试主要测到的错误类型有:不正确或遗漏的功能;接口、界面错误;性能错误;数据结构或外部数据访问错误;初始化或终止条件错误等等
2.为什么要进行自动化测试
自动化测试是软件开发生命周期的重要组成部分,主动修复错误需要对基础代码进行的每个小更改都进行测试和重新测试。随着时间的流逝,回归测试的数量将会增加,测试人员将承受很大的压力,而创新和增长的时间会越来越少。此外,至少有四个因素导致测试成本上升:
跨设备、系统和平台进行测试的需求不断增加
将测试范围从例如一个Web浏览器扩展到两个或扩展到包含移动设备会影响工作量。
测试用例的数量不断增加
随着每次产品更新,涵盖更多功能所需的测试用例数量都会增加。新功能会影响需要重新测试的现有功能;常见的回归测试问题。
发布管道的成熟
团队不希望仅进行一次回归测试,而是希望在发布管道的多个阶段运行测试。这有助于为开发人员提供最快的反馈,但同时也需要大量测试。
管理层希望增加发布数量
为了保持其最新产品的市场地位,企业希望确保软件质量并更快速地迭代产品。
面对测试成本的增加,为了改变测试不可持续的局面,团队可以引入自动化测试以减轻测试人员的重复、不可预测、繁琐的任务。、
通过自动化测试可以带来以下好处:
- 提高生产率:可以高精度执行更多测试,产品功能测试的范围更广;
- 快速反馈:在软件开发生命周期(SDLC)中更快,更早地执行测试时,反馈也可以更快地提供给开发人员;
- 加快产品版本迭代:更快的测试执行和连续的反馈循环可以缩短总体SDLC,并提高发布频率;
- 成本效率:优化资源后,可以降低成本;
- 更高的敏捷性和市场响应能力:较短的发布周期使企业可以更好地响应变化并确定资源的优先级;
- 降低人为错误的风险:自动化测试可满足回归测试需求,将人为错误的风险降到最低;
- 提高交付质量:高效测试可最大程度地扩大测试范围,提高产品质量;
- 更高的工作满意度:由于消除了高度重复的任务,测试人员可以体验到更高的工作满意度。
3.手工和自动化测试之间的区别
在快速且连续的产品开发中,手动测试是验证终端用户工作流程的最有效方法。但实际情况是,手工测试并不能完全做到重测每个功能,持续测试工作中需要编写快速且频繁运行的自动化测试,找出生产版本中的缺陷。
通过以下对比,让我们来了解测试工作中手工测试与自动化测试之间的区别。
4.自动化测试如何与DevOps相适应
DevOps中持续测试是软件产品交付管道中执行自动化测试的过程,其目的是获取有关最新构建或预发布的版本中业务风险的快速连续反馈。然后,可以使用此信息来确定软件产品是否已准备好在任何给定时间通过交付管道进行升级。由于测试提早开始并连续执行,因此减少了发现和修复缺陷所需的时间和精力,可以提高交付高质量软件(满足对可接受风险水平的期望的软件)的速度和频率,并减少技术负担。
持续测试包括对功能需求和非功能需求的验证,均与自动化测试有关。
功能测试,持续测试通常涉及单元测试,API测试,集成测试和系统测试。
非功能性测试,涉及诸如静态代码分析,安全性测试,性能测试等实践。