【软件测试】测试&开发的一生之敌-BUG

简介: BUG相比大家都知道,程序运行出错或者与预期不符就是BUG.现在我们来用测试人员的角度来看待BUG。

1.前言

BUG相比大家都知道,程序运行出错或者与预期不符就是BUG.现在我们来用测试人员的角度来看待BUG.


2.如何描述/创建一个BUG

测试人员要测试开发人员的代码,找出开发人员可能忽略的问题.然后把这个问题反馈给开发人员.

如何把BUG清晰简洁明了的描述出来,会涉及到很多东西.这并不只是简单说一下遇到BUG的情况.

一个合格BUG的描述分为以下几部分:


发现问题的版本: 大部分软件的版本应该是很多的,测试人员需要知道出现问题对应的版本,才能获取对应版本的代码进而重现故障

问题出现的环境: 环境分为硬件环境和软件环境,如果是WEB项目,还需要描述浏览器的版本,客户机的操作系统等.如果是APP项目,需要描述机型,分辨率,操作系统等.详细的环境描述有利于故障的定位.

错误重现的步骤: 描述问题重现的最小步骤.

预期行为的描述: 以用户的角度指导开发人员怎么样才是正确的.

错误问题的描述: 出现BUG时的场景

描述一个BUG并不意味着只能有以上这些部分,还可以有别的方面的描述,例如:这个BUG是前端问题还是后端问题,BUG的级别等.


能够描述好一个BUG,创建BUG就很容易了.


3.BUG的级别

BUG存在不同的严重级别.BUG的定义每个公司都不一致,在定义级别之前需要查看公司规范。

举个例子:


Blocker(崩溃):阻碍开发或测试工作的问题;造成系统崩溃、死机、死循环,导致数据库数据丢失,与数据库连接错误,主要功能丧失,基本模块缺失等问题。如:代码错误、死循环、数据库发生死锁、重要的一级菜单功能不能使用等(该问题在测试中较少出现,一旦出现应立即中止当前版本测试)。

Critical(严重):系统主要功能部分丧失、数据库保存调用错误、用户数据丢失,一级功能菜单不能使用但是不影响其他功能的测试。功能设计与需求严重不符,模块无法启动或调用,程序重启、自动退出,关联程序间调用冲突,安全问题、稳定性等。如:软件中数据保存后数据库中显示错误,用户所要求的功能缺失,程序接口错误,数值计算统计错误等(该等级问题出现在不影响其他功能测试的情况下可以继续该版本测试)。

Major(一般):功能没有完全实现但是不影响使用,功能菜单存在缺陷但不会影响系统稳定性。如:操作时间长、查询时间长、格式错误、边界条件错误,删除没有确认框、数据库表中字段过多等(该问题实际测试中存在最多)

Minor(次要):界面、性能缺陷,建议类问题,不影响操作功能的执行,可以优化性能的方案等。如:错别字、界面格式不规范,页面显示重叠、不该显示的要隐藏,描述不清楚,提示语丢失,文字排列不整齐,光标位置不正确,用户体验感受不好,可以优化性能的方案等(此类问题在测试初期较多,优先程度较低;在测试后期出现较少,应及时处理)

4.BUG的生命周期

测试人员在执行测试的过程中,如果有对应的BUG,需要在对应的BUG 管理平台来创建BUG.

每个公司、每一个工具对bug生命周期的定义都是不一致的.

举个例子:


New:测试人员创建BUG

Open: 开发人员确认是否是BUG,如果是BUG 状态就会改为Open

Rejected:如果认为不是Bug,则拒绝修改。

Fixed: 开发人员修复完BUG,状态就改为Fixed

Delay: 确认BUG后,BUG的级别不高或开发人员不能立即修复BUG,状态就改为Delay.

Closed: BUG确认修复完成,测试人员将BUG改为Closed

Reopen: 开发人员修复BUG,但BUG并没有修复完成,BUG状态改为Reopen

5.跟开发产生争执怎么办

测试人员毕竟是要想方设法测试开发人员的代码,并提出BUG.如果处理不好,很容易与开发产生争执.如果产生争执怎么办?

针对这个问题: 我们要坚持"对事不对人".


要有"批判性思维",想一想是不是自己描述的BUG不够清晰等.

如果开发人员对BUG的级别不认可,我们要保证BUG的级别有理有据.

提出BUG会增加开发人员的工作量, 小问题可能不想解决.这时可以引导开发人员进行换位思考,“如果你是用户,出现这样的情况你能接受吗?”

不仅要提出BUG,最好也能提出解决方案

如果确实是BUG,此时友好沟通不能解决问题,那么就召开BUG评审.

以上的答案仅供参考,如有更好的想法,也可以加上.


补充:BUG评审需要参加的人员有产品经理,开发代表,测试代表等,讨论内容一般分为两部分:1.如果解决BUG 2.如何避免类似的问题发生.

相关文章
|
8天前
|
人工智能 搜索推荐 数据管理
探索软件测试中的自动化测试框架选择与优化策略
本文深入探讨了在现代软件开发流程中,如何根据项目特性、团队技能和长期维护需求,精准选择合适的自动化测试框架。
50 8
|
17天前
|
测试技术 持续交付
探索软件测试中的自动化测试策略
随着软件开发周期的加速和市场需求的不断增长,传统的手动软件测试方法已难以满足现代软件开发的高效性和准确性要求。本文旨在探讨自动化测试在软件测试中的重要性、实施策略及其对提高软件质量的影响。通过分析自动化测试的优势与挑战,以及提供实用的自动化测试工具和框架选择指南,旨在帮助读者理解并应用自动化测试以提升软件开发效率和产品质量。
|
15天前
|
机器学习/深度学习 人工智能 监控
软件测试中的自动化测试策略与最佳实践##
在当今快速发展的软件行业中,自动化测试已成为确保软件质量和加速产品上市的关键工具。本文将探讨自动化测试的重要性,分析不同类型的自动化测试工具和框架,并深入讨论实施自动化测试的最佳实践。通过案例研究和数据分析,我们将揭示如何有效整合自动化测试到软件开发生命周期中,以及它如何帮助团队提高测试效率和覆盖率。 ##
28 1
|
14天前
|
Java 测试技术 API
探索软件测试中的自动化测试框架
本文深入探讨了自动化测试在软件开发中的重要性,并详细介绍了几种流行的自动化测试框架。通过比较它们的优缺点和适用场景,旨在为读者提供选择合适自动化测试工具的参考依据。
|
14天前
|
数据管理 测试技术 持续交付
软件测试中的自动化测试策略与最佳实践
在当今快速迭代的软件开发环境中,自动化测试已成为确保软件质量和加速产品上市的关键手段。本文旨在探讨软件测试中的自动化测试策略,包括选择合适的自动化测试工具、构建有效的自动化测试框架以及实施持续集成和持续部署(CI/CD)。通过分析自动化测试的最佳实践,本文为软件开发团队提供了一系列实用的指南,以优化测试流程、提高测试效率并减少人为错误。
39 4
|
14天前
|
监控 测试技术 定位技术
探索软件测试中的自动化测试框架选择与实施###
本文不概述传统意义上的摘要内容,而是直接以一段对话形式引入,旨在激发读者兴趣。想象一下,你是一名勇敢的探险家,面前摆满了各式各样的自动化测试工具地图,每张地图都指向未知的宝藏——高效、精准的软件测试领域。我们将一起踏上这段旅程,探讨如何根据项目特性选择合适的自动化测试框架,并分享实施过程中的关键步骤与避坑指南。 ###
27 4
|
15天前
|
测试技术 持续交付 数据安全/隐私保护
软件测试的艺术与科学:探索自动化测试框架
在软件开发的世界中,测试是确保产品质量的关键环节。本文将深入探讨自动化测试框架的重要性和实现方法,旨在为读者揭示如何通过自动化测试提升软件测试效率和准确性。我们将从测试的基本概念出发,逐步引导读者了解自动化测试框架的设计和实施过程,以及如何选择合适的工具来支持测试活动。文章不仅提供理论知识,还将分享实用的代码示例,帮助读者将理论应用于实践。无论你是测试新手还是经验丰富的开发者,这篇文章都将为你打开一扇通往更高效、更可靠软件测试的大门。
18 1
|
1月前
|
JSON Java 测试技术
SpringCloud2023实战之接口服务测试工具SpringBootTest
SpringBootTest同时集成了JUnit Jupiter、AssertJ、Hamcrest测试辅助库,使得更容易编写但愿测试代码。
58 3
|
2月前
|
JSON 算法 数据可视化
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
这篇文章是关于如何通过算法接口返回的目标检测结果来计算性能指标的笔记。它涵盖了任务描述、指标分析(包括TP、FP、FN、TN、精准率和召回率),接口处理,数据集处理,以及如何使用实用工具进行文件操作和数据可视化。文章还提供了一些Python代码示例,用于处理图像文件、转换数据格式以及计算目标检测的性能指标。
73 0
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
|
3月前
|
移动开发 JSON Java
Jmeter实现WebSocket协议的接口测试方法
WebSocket协议是HTML5的一种新协议,实现了浏览器与服务器之间的全双工通信。通过简单的握手动作,双方可直接传输数据。其优势包括极小的头部开销和服务器推送功能。使用JMeter进行WebSocket接口和性能测试时,需安装特定插件并配置相关参数,如服务器地址、端口号等,还可通过CSV文件实现参数化,以满足不同测试需求。
258 7
Jmeter实现WebSocket协议的接口测试方法