【测试效率对比】深入分析:为何UI自动化测试的投资回报率通常低于接口自动化测试?

简介: 这篇文章深入分析了UI自动化测试与接口自动化测试的投资回报率(ROI)问题,指出UI自动化测试在某些情况下的ROI并不低,反驳了没有实施过UI自动化就轻易下结论的观点,并强调了实践的重要性和自动化测试在项目迭代中的作用。

一、前言

UI自动化测试真的比较难以实施吗?ROI真的比接口自动化测试低吗?从哪里得出如此结论?得出结论的人是否有真正实施过UI自动化测试呢?这些问题的答案可能不是绝对的,但是有一点可以肯定:得出如此结论的人绝对没做过UI自动化测试!为什么题主敢这么说呢,且听题主娓娓道来!

在这里插入图片描述

1.1、UI自动化测试

咱先以实现web自动化为例,这里面涉及的核心工具就是selenium,当然或可有其他工具代替,那么掌握了selenium工具的使用就代表自己会web自动化了吗?我看未必!再说一般人真的会在公司主推UI自动化测试吗?不会,因为单看投入成本、ROI都不可能有效的保障项目质量,一般有实力的公司都会UI+接口自动化实现全覆盖,多一重保障!所以结论是都没有实施过,怎么能说它难?说他ROI低呢?

1.1.1、那么谈谈什么样的项目适合UI自动化?
  1. 项目周期长,表示需要长期维护
  2. 需求相对稳定,代表功能稳定、易测试
  3. 团队成员也要具备一定的测试脚本开发能力

这里可以很负责的说,对于一个新项目不要一上来就实现UI自动化,这有点本末倒置,对于新研发的web系统,应优先保障它的功能正确,适当可以实现接口测试、自动化测试,待他逐渐稳定后再结合实际评估是否可以介入web自动化!否则负责人过来跟你说这个项目就到这了,那你还需要继续实现web自动化吗?题主相信读者心中自然有了答案。

在这里插入图片描述

1.1.2、先思考一个问题:功能测试和接口测试有什么区别?

这里捡重点说,功能测试的侧重点是UI及交互、用户体验,更多关注功能的实现本身是否满足用户需求;反观接口测试呢,更关注程序本身的内部实现(参数校验、逻辑处理、数据交互等等),是否满足业务需求。前者用户体验更直观使用的系统是什么样的、有什么样的功能,后者呢,是一般用户不会去关注的,他可能不懂内部逻辑。

1.1.3、再思考一个问题:为什么从现场(生产)反馈的问题都是前端?

因为用户是通过前端直观反馈的,他并不会去怀疑自身环境或者是程序内部错误,所以说前端才是用户的入口(眼睛),加上那不可揣摩的用户行为,谁也不知道用户会在什么样的环境下操作系统!而前端又是用户接收信息的第一窗口,他不可能会去考虑后台服务怎么了。

1.2、接口自动化测试

这里的接口自动化咱们需要分两种情况来介绍!一是单接口的入参覆盖,也就是一个接口的用例个数是由参数个数、类型、数据限制所决定的,毫不夸张的说:少则几个多则大几十,但是这类自动化测试一般不会投入到生产上去,那是因为它会给服务器造成系统压力,如果不巧还会影响正常用户的使用,这样的无差别攻击是没有必要的;再说以核心业务场景设计的接口自动化测试,无疑减少了投入,也可以高频高效的反复使用,这样一看它的ROI就比较高了。

在这里插入图片描述

接口自动化测试没有项目适不适合的困惑,只是因为它的投入相对低、产出相对较高,这里咱们不考虑它是编码实现自动化测试解决方案,而是引入开源的自动化测试平台,一来就不会对团队成员有编码的要求,二来也易于学习和使用。

1.2.1、再来battle一下UI自动化测试ROI

可以总结前面提到过的经验,比如项目投入周期长(超过1年\长久维护),或者说它已经趋于成熟,然后需求变更稳定(大多会是新增),用户反馈大多是从前端、视觉分析得到的问题,经过分析:有些是因为前端功能失效,有些真的是由于应用服务业务处理失败,但这个并不妨碍实现UI自动化,反而更能直接回归发现问题。

谁告诉你它的ROI比接口自动化测试低了?他都没有实施过,怎么能这样断言?很明显得到这些结论的人都是人云亦云,实践出真知,哪怕UI站在金字塔尖、比重小,也不能忽略它的地位。唯一的诟病就是前端开发的页面元素不够规范,让实现UI元素定位的人苦不堪言。

二、总结

日拱一卒无有尽、功不唐捐终入海!

在没有实践之前,都没有发言权,更不能武断出结论,在一方不能完全保障或覆盖的同时,应该要有更多解决方案来落地实施,这样才能有效的对比出结论,回头再说一句,如果一家公司没有专职转岗来做自动化,那么任何自动化都是需要投入成本,然后再来看ROI其实差距并不大。但是不能否认自动化存在的意义,它主要的目的用来做两件事:冒烟测试、回归测试,保障项目迭代不会影响历史功能。维护旧脚本、开发新脚本都不影响它的价值体现。

相关文章
|
4月前
|
前端开发 测试技术 API
测试金字塔:别再只盯着UI自动化了
测试金字塔:别再只盯着UI自动化了
513 116
|
4月前
|
敏捷开发 测试技术 API
测试金字塔:构建高效自动化测试策略的基石
测试金字塔:构建高效自动化测试策略的基石
386 116
|
4月前
|
人工智能 自然语言处理 测试技术
从人工到AI驱动:天猫测试全流程自动化变革实践
天猫技术质量团队探索AI在测试全流程的落地应用,覆盖需求解析、用例生成、数据构造、执行验证等核心环节。通过AI+自然语言驱动,实现测试自动化、可溯化与可管理化,在用例生成、数据构造和执行校验中显著提效,推动测试体系从人工迈向AI全流程自动化,提升效率40%以上,用例覆盖超70%,并构建行业级知识资产沉淀平台。
从人工到AI驱动:天猫测试全流程自动化变革实践
|
4月前
|
人工智能 自然语言处理 JavaScript
利用MCP Server革新软件测试:更智能、更高效的自动化
MCP Server革新软件测试:通过标准化协议让AI实时感知页面结构,实现自然语言驱动、自适应维护的自动化测试,大幅提升效率,降低脚本开发与维护成本,推动测试左移与持续测试落地。
|
4月前
|
测试技术 API 数据库
测试金字塔:构建高效自动化测试策略的基石
测试金字塔:构建高效自动化测试策略的基石
412 114
|
6月前
|
存储 人工智能 算法
AI测试平台实战:深入解析自动化评分和多模型对比评测
在AI技术迅猛发展的今天,测试工程师面临着如何高效评估大模型性能的全新挑战。本文将深入探讨AI测试平台中自动化评分与多模型对比评测的关键技术与实践方法,为测试工程师提供可落地的解决方案。
|
7月前
|
JSON JavaScript 测试技术
用Postman玩转电商API:一键测试+自动化请求教程
Postman 是电商 API 测试的高效工具,涵盖基础配置、自动化测试、环境管理与请求自动化,助你快速提升开发效率。
|
9月前
|
开发框架 前端开发 JavaScript
【HarmonyOS Next之旅】基于ArkTS开发(二) -> UI开发一
本文介绍了方舟开发框架(ArkUI)及其两种开发范式:基于ArkTS的声明式开发范式和类Web开发范式。ArkUI是用于构建HarmonyOS应用界面的UI框架,提供极简UI语法和基础设施。声明式开发范式使用ArkTS语言,以组件、动画和状态管理为核心,适合复杂团队协作;类Web开发范式采用HML、CSS、JavaScript三段式开发,适用于简单界面应用,贴近Web开发者习惯。文中还概述了两者的架构和基础能力,帮助开发者选择合适的范式进行高效开发。
308 15
|
9月前
|
编解码 前端开发 Java
【HarmonyOS Next之旅】基于ArkTS开发(二) -> UI开发三
本文介绍了基于声明式UI范式的图形绘制与动画效果实现方法,涵盖绘制图形、添加动画效果及常见组件说明三部分内容。在绘制图形部分,详细讲解了如何通过Circle组件为食物成分表添加圆形标签,以及使用Path组件结合SVG命令绘制自定义图形(如应用Logo)。动画效果部分则展示了如何利用animateTo实现闪屏动画,包括渐出、放大效果,并设置页面跳转;同时介绍了页面间共享元素转场动画的实现方式。最后,文章列举了声明式开发范式中的各类组件及其功能,帮助开发者快速上手构建复杂交互页面。
345 11
|
5月前
|
存储 开发者 容器
鸿蒙 HarmonyOS NEXT星河版APP应用开发-ArkTS面向对象及组件化UI开发使用实例
本文介绍了ArkTS语言中的Class类、泛型、接口、模块化、自定义组件及状态管理等核心概念,并结合代码示例讲解了对象属性、构造方法、继承、静态成员、访问修饰符等内容,同时涵盖了路由管理、生命周期和Stage模型等应用开发关键知识点。
460 1
鸿蒙 HarmonyOS NEXT星河版APP应用开发-ArkTS面向对象及组件化UI开发使用实例

热门文章

最新文章