• 接口自动化测试工程实践分享


    本文作者:欧海锋,碧桂园服务高级测试工程师,致力于研究测试技术。

    一、前言

    接口自动化测试是一种软件测试技术,它通过模拟用户系统操作来对系统的接口进行自动化测试。接口自动化测试的目的是为了提高测试效率和准确性,同时降低测试成本和周期。以下是为什么需要进行接口自动化测试的一些原因:

    1、提高测试效率:接口自动化测试可以通过自动化测试工具自动执行测试用例,避免了手工测试中需要大量时间和人力进行测试的问题,提高了测试效率;

    2、准确度高:接口自动化测试是直接对系统的接口进行测试,可以更准确地模拟用户操作,避免了手工测试中可能出现的错误和遗漏;

    3、降低测试成本:接口自动化测试可以避免手工测试中需要大量人力和时间的问题,从而降低了测试成本;

    4、快速反馈:接口自动化测试可以快速反馈测试结果,帮助开发人员快速定位和修复问题,缩短了开发周期;

    5、保障产品质量:接口自动化测试可以对系统的各个接口进行全面的测试,确保系统的稳定性和性能,从而保障产品质量;

    6、标准化和可重复性:接口自动化测试可以使用统一的测试脚本和测试工具,保证测试的标准化和可重复性,使得测试结果更加可靠;

    7、避免人为因素干扰:手工测试中可能会受到测试人员的主观因素干扰,而接口自动化测试则可以避免这种情况,保证测试的客观性和准确性。

    综上,接口自动化测试可以提高测试效率和准确性,降低测试成本和周期,保障产品质量,是现代软件测试中不可或缺的一部分。

    二、主流的接口自动化工具对比

    基于上述的工具对比,中心进行凤凰云测的测试引擎研发,以确保该引擎更贴合当前中心项目状况,该引擎优势有:

    不需要写脚本,只需要获取相关的接口请求信息,按照业务流顺序编排,就能实现接口自动化;

    对测试人员的代码能力要求相对较低;

    存量数据保存格式一致,且简单易懂;

    可自动生成详细测试报告,无需人工整理分析;

    系统整体性能优越,并发处理能力强;

    测试断言更加丰富多样。可以跟内部的DevOps系统做数据对接,完成从需求到测试的闭环管理。

    三、凤凰云测核心功能

    1、断言引擎

    断言引擎有着丰富的断言方式,支持文本断言、正则断言、响应码断言、响应时间断言、JsonPath断言及Xpath断言,支持主流测试工具的断言方式。通过直观的界面交互设计,使编写断言更加简单快捷。

    我们结合中心整体测试流程进行测试引擎的开发,以提升测试效率和测试质量。

    引擎实现原理:读取测试套中编排好的测试接口信息,并通过递归方法有序地发起接口请求,以此来实现业务流接口和实现业务场景测试。

    2、数据看板

    丰富的数据统计:支持缺陷密度、缺陷逃逸率、缺陷解决时长及生产缺陷解决平均时间等度量数据统计。这些测试数据有助于项目管理进行项目迭代质量分析以及风险预估分析。

    3、测试任务

    多功能测试任务:多环境执行自动化测试用例、自动生成详细测试报告、自动统计慢接口数据与一键回归全系统测试测试用例。

    支持自定义测试任务,以适配更多的测试场景需求,一键生成详细的测试报告和慢接口数据的自动统计,极大地提升了开发测试流程的效率。

    4、数据整合

    拥有强大的数据整合能力,能够与中心的DevOps平台做产品、应用、迭代及需求等数据整合,形成一个完整的闭环管理。

    三、实践分享

    1、测试流程

    基于中心现状,进行相应测试流程的制定并辅以凤凰云测的测试引擎,将项目的测试流程规范化、数字化。

    测试人员在进行需求分析时输出相应的思维导图,并标识了哪些用例适宜进行接口自动化。这一个过程为评估需求的自动化率提供了初步依据;

    输出相应的测试用例并上传凤凰云测生成相应的测试套;

    测试人员对相应的测试套进行接口自动化的编写编排,实现业务流的接口自动化;

    确认版本测试范围,规划测试任务所覆盖的测试套,形成一个版本的测试任务;

    在版本回归时执行测试任务并生成测试结果与测试报告。

    2、项目实践

    (1)测试度量

    缺陷密度和缺陷逃逸率都是用于评估软件质量的重要指标,但它们各自的定义和用途有所不同。

    缺陷密度:指每千行代码中发现的缺陷数量,主要用于衡量软件的质量和可靠性。缺陷密度是一个相对稳定的指标,不受测试阶段和产品发布的影响。通过计算缺陷密度,可以帮助评估当前已经发现的缺陷总数是否足够多,从而决定是否应该退出测试或发布产品。

    缺陷逃逸率:指软件产品发布后发现的缺陷数量与该软件产品在整个生命周期发现的所有缺陷数量的比率。它主要用于衡量软件开发团队和测试团队对软件质量控制的水平。缺陷逃逸率可以用来评估测试的有效性,确定当前产品发现的缺陷是否被有效修复,并为当前产品的质量是否达到测试质量目标提供最直接的判断依据。

    缺陷密度和缺陷逃逸率是相互关联的两个指标,它们可以帮助开发团队更好地了解软件的质量和可靠性,并采取相应的措施来修复缺陷和提高软件质量。

    (2)业务流程接口自动化

    中心大部分项目都将自动化应用到平常的项目开发活动中,这充分证明了接口自动化为项目带来了有效的帮助。

    中心已成功将大部分系统存量用例实现了自动化,并实现了用例与测试套的自动关联,显著提升了技术人员在研发过程中对原功能进行快速验证的能力,保障了新功能不会对原功能产生不良影响。

    (3)生产点火(回归测试利器)

    实现原理:选用项目中所有不涉及修改或增加数据的测试套,并将它们归集到一个测试任务中,再加上云测测试任务可以选择相对应的环境进行测试,这意味着可以在任何环境中进行相应的点火测试。

    生产环境的验证时间控制大幅缩短,极大地提升了效率。

    作用:快速验证发版后接口响应及功能表现是否正常。发版后能快速定位响应问题,解决问题时效得到极大提升。下图为某项目生产点火测试结果部分截图:

    (4)慢接口分析

    实现原理:将当前任务中的接口响应时间做一次归总统计,将超过响应阈值的接口标识出来。

    作用:方便开发人员尽早地发现响应过慢的接口,并将相应的慢接口场景展示出来,为解决问题提供相应的场景以及数据。

    3、总结

    凤凰云测助力中心项目效果:

    测试回归效率显著提升;

    测试过程数据有迹可循、有踪可查;

    测试用例与接口规整保存;

    基于客观的项目质量数据分析,为项目质量提供了有力保证;

    生成的测试报告全面、规范且详细。

    四、写在最后

    选用适合项目的接口自动化工具,需要考虑以下几个方面:

    1、工具的易用性:选择易于使用的接口自动化测试工具,可以降低测试人员的学习成本,提高测试效率;

    2、工具的功能丰富度:选择功能丰富的接口自动化测试工具,可以满足各种测试需求,如模块化测试、数据驱动测试及并发测试等;

    3、工具的可扩展性与兼容性:选用的自动化测试工具不仅具有良好的可扩展性和兼容性,而且可以与其他测试工具和开发工具集成,实现自动化测试和持续集成;

    4、工具的报告和日志功能:选择能够生成详细的测试报告和日志的接口自动化测试工具,它能帮助测试人员快速且准确地查看测试结果,并有效识别与解决问题;

    5、接口覆盖策略:根据项目的需求,选择能够覆盖全面测试场景的接口自动化测试工具,以及单个接口Response;

    6、自动化程度:选择自动化程度高的接口自动化测试工具,以减少人工干预,提高测试效率和准确性;

    7、社区支持:选择有活跃社区支持的接口自动化测试工具,确保在遇到技术难题时,能够迅速获得协助和解决方案。

    综上所述,在选用适配项目的接口自动化工具时,需要综合考虑包括工具的易用性、功能丰富度、可扩展性与兼容性、报告和日志功能、接口覆盖策略、自动化程度和社区支持等多个因素。建议在选用工具之前,先了解项目的需求和限制,并进行充分的调研和比较,以选择出最适合项目需求的接口自动化测试工具。

  • 相关阅读:
    错误error 和例外Exceptions
    R语言ggplot2可视化:使用ggpubr包的ggviolin函数可视化小提琴图
    Goby 漏洞发布|Revive Adserver 广告管理系统 adxmlrpc.php 文件远程代码执行漏洞(CVE-2019-5434)
    经典/最新计算机视觉论文及代码推荐
    软件开发架构与网络编程
    一个注解干翻所有Controller
    MySQL-FlinkCDC-Hudi实时入湖
    IProgress not found.Please update jupyter and ipywidgets.解决办法
    C#程序发布时,一定要好好地保护,不然你会后悔的
    责任链模式与spring容器的搭配应用
  • 原文地址:https://www.cnblogs.com/bkyfw/p/18141674