测试需要写测试用例吗?(从不同角度下剖析问题)

前言

最近在网上看到关于这样的一个话题“测试需要写测试用例吗?”,引起了很多同学的讨论。这段话是这样的:

测试用例主要作用:有效地评估软件的质量,测试用例质量体现了测试的质量。

下面摘取一部分同学的观点:

  • 评估软件质量应该看测试报告之类的结果;
  • 测试用例主要作用是确定测试范围和测试场景;
  • 这句话没毛病,除非你没按照测试用例好好执行;
  • 评估软件质量最有发言权的应该是用户和软件的实际使用者;

 

他们说的对吗?我个人认为不全对。但他们说错了吗?也不见得。视角不同,出发点不同,观点不同。

这篇文章,我想聊聊我对于测试用例的观点,以及软件的质量到底由什么决定。

如何理解软件的质量

我们都知道,一个软件从无到有要经过需求设计、编码实现、测试验证、部署发布这四个主要环节。

 

需求来源于用户反馈、市场调研或者商业判断。意指在市场行为中,部分人群存在某些诉求或痛点,只要想办法满足这些人群的诉求,且投入产出有差价有利润可赚,就会创造需求。

这些需求经过专业的评估分析和加工设计,就会变成具体的业务需求和对应的产品设计图。然后由专门的研发同学设计实现的技术方案,通过编码来将抽象的业务逻辑变成具体的软件产品功能。

产品功能实现后,交付给测试同学,通过各种方法和手段来验证软件产品具体的功能、性能、安全、交互等特性是否满足产品需求的预期目标。

产品测试验证通过,再交付给专门的运维或者负责线上部署的同学,在生产环境编译打包发布。然后通过产品发布会或者消息推送告知用户,我们提供了什么软件产品,可以满足你们的什么诉求。

这其中的逻辑很简单,服务提供者提供的软件产品,是否满足了用户的需要。通过提供这个软件产品,服务提供者的业务目标是否达成(比如广告投放、平台手续费、增值服务费)。

决定用户使用产品并且不断有更多的用户使用产品的因素,在于用户对产品是否认可,在于用户的量级和留存转化(人越多,成本越容易摊薄,业务场景也越多,商业利润的来源方式就越多)。

这个逻辑就对软件产品本身提出了要求:功能要方便正确,交互要人性化,操作反应要快,信息不能被盗取。与之对应的就是功能的正确性、UI交互的体验、软件的高性能、软件的安全措施。

因此,软件的质量由谁决定呢?由用户使用产品最终导向的业务目标(商业价值)是否达成决定!

测试用例的作用是什么

我们都知道,随着业务复杂性和系统架构复杂性的提升,以及团队人员的变动、需求的迭代和各种配置的变更,软件本身可能会出各种问题,这是一个不断墒增的过程。软件研发交付已经变成了一个特别复杂的团队协作才能完成的巨大工程。

为了控制复杂性不断墒增,为了降低软件可能出问题的风险和影响,为了保证复杂的团队协作可以朝着同一个方向前进,为了保证软件研发交付过程的每个环节都达成预期目标,我们做了哪些事情?

  • kickoff:项目启动会,宣讲项目目标,关键里程碑,各角色职责范围;
  • 流程规范:约定了在项目研发交付过程中,要遵守的原则,即划定边界。让不同职业背景、技术栈不同的各个角色可以不跑偏,始终朝着同一个方向前进;
  • 质量门禁:在软件研发交付的整个过程中,每个环节设定指标。保证从无到有的过程中,每个环节的交付产出物都满足标准(即风险尽可能被降低和接受);
  • 质量度量:通过各种不同维度的数据采集和分析评估,判断最终的交付产出物满足业务预期目标

其中测试用例的作用是什么?写用例是为了验证本次交付范围尽可能覆盖到,不遗漏,交付部分不出问题或者问题已知风险可接受。是一种在有限的已知范围内,尽可能cover风险的手段。

同样,需求设计环节会有大量的讨论和评审,研发编码阶段的code diff、code review、单元测试,也是这个目的。甚至我们常见的产品验收测试、线上灰度发布的作用还是这个。

测试要不要写测试用例

我个人认为,写不写case,做不做质量门禁之类的都是手段。大部分时候,测试做的工作都是测试环境的质量保障,最终发布上线,交付给用户的使用结果和业务目标是否达成,才是真正的质量。

 

只不过人总会失误、遗漏,人的能力参差不齐。所有才要写用例,定规范,用各种手段来保证这件事。你会发现,到最后要解决的,还是人的问题。

如何把不同能力、不同认知的人,用一些手段,让他们的认知、能力、水平保持在某个基线之上,督促这些人完成同一件事,达成同一个目的,这才是关键。

过程可控,测试计划,方案,用例,还有日报,周报这些,其实都是为了达成这个目的。质量保障的各种方法和手段,就是提高团队的交付产出物下限。

举一个不太恰当的例子:团队中的各种角色就像羊群,需要头羊(负责人)带领方向;需要牧羊犬(流程规范)时刻督促保证羊群不跑出既定范围不落队;

需要项目管理的手段(里程碑和deadline)来提醒天亮出圈天黑回圈;也需要公司选择合适的草地(业务范围)和天气(市场时机)放牧。

 感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

 

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!有需要的小伙伴可以点击下方小卡片领取 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/185481.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何理解程序之间的解耦和元注解的应用?

1.如何理解程序之间的解耦? 我的理解是解耦是将有联系的代码或者有依赖的代码之间 通过中间的方式去处理而不是写成固定的方式,而是通过统一的定义的某种方式去结合这些依赖关系,比如使用反射机制 2.解耦是将代码之间的依赖关系降低到最小&…

记录labelImg上手过程

一、安装 Labelimg(目标检测标注工具)安装_labelimg安装_向南不向北的博客-CSDN博客 二、打开 进入anaconda虚拟环境后,cd到labelimg文件夹,然后输入命令 python labelImg.py 三、基础设置 打标工具labelimg安装和使用教程-C…

【知识】稀疏矩阵是否比密集矩阵更高效?

转载请注明出处:小锋学长生活大爆炸[xfxuezhang.cn] 问题提出 有些地方说,稀疏图比密集图的计算效率更高,真的吗? 原因猜想 这里的效率高,应该是有前提的:当使用稀疏矩阵的存储格式(如CSR)时,计…

【2019年数据结构真题】

【2019统考真题】设线性表L (a1,a2,a3,…,an-2,an-1,an)采用带头结点的单链表保存,链表中的结点定义如下: typedef struct node{int data;struct node*next; }NODE;请设计一个空间复…

酷狗音乐app 评论signature

文章目录 声明目标加密参数定位翻页逻辑代码实现 声明 本文章中所有内容仅供学习交流,严禁用于商业用途和非法用途,否则由此产生的一切后果均与作者无关,若有侵权,请私信我立即删除! 目标 复制curl转python # -*- c…

供应链大事记 | 2024第二届中国供应链碳中和峰会来了!

背景 当下,全球气候变化、环境污染、资源紧张问题加剧,世界各国致力于推动碳达峰、碳中和,绿色低碳发展已成为全球共识。我国也于2020年明确提出“3060双碳目标”,经济结构、能源结构、产业结构亟待转型升级,各重点行…

熟悉SVN基本操作-(SVN相关介绍使用以及冲突解决)

一、SVN相关介绍 1、SVN是什么? 代码版本管理工具它能记住你每次的修改查看所有的修改记录恢复到任何历史版本恢复已经删除的文件 2、SVN跟Git比,有什么优势 使用简单,上手快目录级权限控制,企业安全必备子目录checkout,减少…

体脂称方案设计——电子秤方案芯片CS1231

电子秤与我们日常生活息息相关,智能科技化的生活形成万物互联的模式。测量精度领域随着大市场的发展也进入到发展高峰时期,电子秤从开始的弹簧压力测物体重量走向更为智能的测体脂、人体成分等相关的测量。所以在做方案开发中它的功能也在更新和智能化。…

Git——工作区管理

如何管理工作目录,以便用户可以更高效地新建提交。如何在处理工作区和暂存区文件的过程中修复错误,以及如何修复最近一次提交记录中的问题;同时还会了解到如何安全地使用暂存机制和多个工作目录处理工作流中的中断问题。 主要内容有以下几点…

玻色量子研发进展

2023年 2023.8 量子计算突破云渲染资源调度!真机测试完整报告公开! 2023.8 量子计算突破金融信用评分!真机测试完整报告公开! 2023.7 玻色量子“揭秘”之旅行商问题与Ising建模 2023.7 玻色量子“揭秘”之背包问题与Ising建…

Ubuntu 配置打开文件限制

cat /etc/security/limits.conf | grep -Ev "^$|#"量 # ulimit -n 1024000软限制的打开文件数 # ulimit -Sn 1024000硬限制的打开文件数量 # ulimit -Hn 1024000系统打开文件描述符的最大数量 # sysctl fs.nr_open fs.nr_open 1048576系统打开文件的最大数量 #…

采集软件大全-全网免费的采集软件大全

采集软件大揭秘:从排名到任意网站采集的全方位解读 在数字时代,信息是黄金,而采集软件就是那把能够淘金的工具。无论是市场调研、竞品分析还是SEO优化,采集软件都扮演着不可或缺的角色。在这个领域里,有许多选择&…

性能测试线上监控

如果你的产品出现了一个线上问题,你会是怎么样的反应? 也许会跟下面这张图一样。 哇!有一个线上bug,好慌呀!! 咦,问题似乎自动解决了?渐渐冷静。 不对!!&a…

虚拟机系列:Oracle VM VirtualBox安装/更新/卸载出现 无法访问你试图使用的功能所在的网络位置

Oracle VM VirtualBox安装/更新/卸载出现 无法访问你试图使用的功能所在的网络位置 Oracle VM VirtualBox安装/更新/卸载出现 无法访问你试图使用的功能所在的网络位置Oracle VM VirtualBox安装/更新/卸载出现 无法访问你试图使用的功能所在的网络位置 在更新Oracle VM Virtua…

【JavaEE初阶】 详解HTTPS协议加密过程

文章目录 🌴HTTPS协议是什么?🎄运营商劫持事件🎋HTTPS的工作过程🚩对称加密🚩非对称加密🚩引入证书🚩完整流程 🌳HTTPS加密总结⭕总结 🌴HTTPS协议是什么&…

基于SSM校园驿站管理系统的设计与实现

摘 要 互联网发展至今,无论是其理论还是技术都已经成熟,而且它广泛参与在社会中的方方面面。它让信息都可以通过网络传播,搭配信息管理工具可以很好地为人们提供服务。针对校园快递信息管理混乱,出错率高,信息安全性差…

C语言——多种方式打印出1000之内的所有的“水仙花数”

所谓水仙花数,是指一个3位数,其各位数字立方和等于该数本身。水仙花数是指一个三位数&#xff0c;它的每个位上的数字的立方和等于它本身。例如&#xff0c;153是一个水仙花数&#xff0c;因为1^3 5^3 3^3 153。 方法一 #define _CRT_SECURE_NO_WARNINGS 1#include <std…

Java中四个元注解@Retention,@Target,@Inherited,@Documented

在 Java 中&#xff0c;有四个重要的元注解&#xff0c;它们分别是 Retention、Target、Inherited 和 Documented&#xff0c;它们用于对自定义注解进行修饰和说明。 元注解是用于定义注解的注解 Retention&#xff1a;Retention 用于指定注解的保留策略&#xff0c;即注解在代…

Docker自定义镜像

目录 回顾 镜像含义 DockerFile语法 自定义java项目镜像 创建一个空目录&#xff0c;在这个空目录中创建一个文件&#xff0c;命名为 DockerFile&#xff0c;将 java 项目打包成 jar 包&#xff0c;放到这个目录中 ​编辑 编写DockerFile文件信息 使用 docker build 构建…

Cesium 性能优化 - 学习笔记

1. Cesium 性能优化 - 学习笔记 开启FPS显示当前帧率 viewer.scene.debugShowFramesPerSecound true;关闭太阳&#xff0c;月亮&#xff0c;天空盒&#xff0c;雾等相关特效 viewer.scene.moon.show false; viewer.scene.fog.enabled false; viewer.scene.sun.show fals…