BUG的跟踪管理

        

目录

一、bug的类型

二、bug的等级

1、致命错误:------blocker

2、严重错误:------critical

3、一般错误:------major

4、细微错误:------minor

5、改进建议:------enhancement

6、bug类型及等级判断

三、bug的生命周期(重点)

1、bug的跟踪管理-流程

2、bug的跟踪管理-状态

3、bug的跟踪管理-缺陷管理工具

4、bug的跟踪管理-如何提交bug

四、禅道的使用(重点)

五、常见笔试面试题

        软件的Bug,狭义概念是指软件程序的漏洞或缺陷,广义概念除此之外还包括测试工程师用户所发现和提出的软件可改进的细节、或与需求文档存在差异的功能实现

        我们的职责就是,发现这些Bug,并提交给开发,让开发去修改。

一、bug的类型

        要确定一个bug的类型,需要对项目(或产品)有比较深的理解。这个划分对于开发定位问题影响很小,但对于问题类型的统计就比较重要了。

        常见的bug类型划分(禅道系统为例,可自定义):

        ·代码功能错误

        ·界面优化

        ·设计缺陷

二、bug的等级

        bug等级,这个划分有分三级或四级,也有分五级的。如果是等级越高,那么可能被修复的等级也会高一些,然后有些公司还会根据你提的bug数量和bug等级来考察你的绩效。很多情况下,我们提交bug大致的等级差不多即可,没有严格区分。

        如何来判断bug的等级(严重程度),一般可以参照下面的判断条件。

1、致命错误:------blocker

  1. 常规操作引起的系统崩溃、死机、死循环、闪退
  2. 造成数据泄漏的安全性问题,比如恶意攻击造成的账户私密信息泄露
  3. 涉及金钱计算
  4. 阻断性测试,所有测试工作进行不下去(冒烟测试)

2、严重错误:------critical

  1. 重要功能不能实现
  2. 错误的波及面广,影响到其它重要功能正常实现
  3. 非常规操作导致的程序崩溃、死机、死循环、闪退
  4. 外观(界面)难以接受的缺陷
  5. 密码明文显示(界面+数据库)
  6. 偶现的致命性bug(备注复现率:复现次数/总测试次数)

3、一般错误:------major

不影响产品的运行、不会成为故障起因,但对产品外观和下道工序影响较大的缺陷

  1. 次要功能不能正常实现
  2. 操作界面错误(包括数据窗口内列名定义、含义不一致)
  3. 查询错误,数据错误显示
  4. 简单的输入限制未放在前端进行控制
  5. 删除操作未给出提示
  6. 偶现的严重性bug

4、细微错误:------minor

程序在一些显示上不美观,不符合用户习惯,或者是一些文字的错误

  1. 界面不规范
  2. 辅助说明描述不清楚
  3. 提示窗口文字未采用行业术语
  4. 界面存在文字错误

5、改进建议:------enhancement

可以提高产品质量的建议,包括新需求和对需求的改进

6、bug类型及等级判断

1.用户输入正确的用户名和密码不能登录网站---分析软件qq致命的 爱奇艺腾讯视频严重错误

2.客户需求要有充值功能,但是网站没有做---重要的功能严重错误

3.网站充值后,出现金额错误---分析延时后正确2 延时还是错误 1

4.在某购物APP上进行商品搜索时,闪退回到手机桌面 ---1

5.在某购物APP上进行商品搜索时,手机卡死----1

6.关闭按钮在弹窗左侧 ----3

7.APP某个图标显示太小或者像素失真----3

8.某个提示语需要改进一下,用户对专业术语不太懂 ----4

9.忘记密码,功能没有实现----次要功能没有实现3

三、bug的生命周期(重点)

        这个是面试/笔试过程中经常会被问道的问题。bug的生命周期,就是一个bug被发现到这个bug被关闭的过程。

        生命周期中一般缺陷状态:新建(提bug)--->指派--->已解决--->待验--->关闭。

                        new--->assigned--->resolved-fixed--->verified/to be verified--->closed

        如果待验的bug在验证时没有解决好,我们需要重新打开(激活)->指派->已解决->待验,循环这个过程。

        中间其他状态:拒绝、延期等。

1、bug的跟踪管理-流程

(1)发现bug,一定要确定bug(环境问题、操作问题),提交bug(缺陷管理工具)----new

(2)指派给开发/开发老大----assigned(指派)

(3)研发确认bug

        1)重复的bug(提交的bug已经有人提交,要求开发重复的bug编号加入备注)

                确认bug是否重复?

                ①是的话 bug关闭(避免提交重复bug,搜索bug)

                ②不是重复的bug 加备注描述不是重复bug原因,重新激活bug

        2)不是缺陷 ---invalid(无效缺陷)

        常见面试题:开发说不是bug,你认为是bug,怎么办?

                ①确认bug

                ②对照需求,站在用户的角度,参考成熟产品,与开发沟通,说服开发

                ③产品/项目经理做最后的确认

                        结果一:要修复bug重新激活,加备注(要修复的保留证据)

                        结果二:不修复保留证据,加备注

        3)无法复现 -----unreproduced

                确认bug是否可以重现

                ①可以重现,帮开发进行重现

                ②自己的环境也不能重现 跟踪3-5个版本,加备注--关闭

                ③不能稳定复现,偶现bug 这种bug一定要提交,写出bug的复现率

                        出现bug次数/总的测试次数

(4)研发解决bug

        1)不予解决 wont fix

                bug优先级(界面bug,建议性)----争议,尝试沟通无果--产品确认 =====加备注,关闭

        2)延期---delay

                ①建议性

                ②优先级低

                ③改动太大,影响太大(分析 1、bug是否影响用户的使用 2、衡量一下时间,bug影响程度 3、产品经理做最后的确认 ===加备注,bug状态为挂起)

(5)研发已解决bug -----resolved-fixed

(6)解决的bug回到测试这边 -----verified 待验 回归测试验证bug

        1)验证通过  bug完美的解决,关闭---closed

        2)验证不通过

                测试版本环境正确,问题依然存在,重新bug指派开发,开发继续修复

                注意:bug验证需要在开发修改的版本里面进行验证

2、bug的跟踪管理-状态

        (1)已经指派的bug-----已经指派给开发的,请大家注意自己bug的走向,随时关注并进行跟踪!如果一直未修复,提醒开发修改,以免开发忘记;如果已经修复等待测试环境更新后进行验证。催着改bug

        (2)已解决的bug-----等待测试环境更新后进行验证,验证通过则关闭;验证不通过则重新打开指派给开发

        (3)重复bug-------先去查看下是否跟开发指定的bug重复?如果确定是重复则关闭如果不重复,说明原因,重新打开指派给开发

        (4)不是缺陷------再次依据需求确认,是否是bug,如果依然觉得是缺陷跟开发沟通列举出来觉得是bug的点,沟通未达一致找产品确认,确认是bug注明情况并再次指派给开发,产品确认不是bug,就不纠结,直接关闭bug,但是,会拿小本本把这个bug记录下来,等到测试任务结束后,再来研究研究

3、bug的跟踪管理-缺陷管理工具

        常见的缺陷管理平台:

        禅道(zentao),我们现在做项目用的就是这个

        bugzila、jira:都还不错,也比较强大。但是搭建起来很困难

        bugfree:

        Readmine

        easybpg:免费开源,在线网站类型的

        Mantis:这个还可以用

        QC(QualityCenter)、TD

        不管是开源还是商业的缺陷管理工具,它们本质都是一样的,用来管理bug的生命周期。掌握其中一款工具,自然就会用其他的,稍微有一点点区别的,别人加以指点,就可以明白了

4、bug的跟踪管理-如何提交bug

        发现bug后,接下来你提交到bug管理平台,提交一个bug包含哪些内容?

        bug标题——标题要清晰简洁,写明bug描述;如果没有选择功能模块,最好在标题中标注功能模块。让查看bug的人员清楚知道你所表达的意思。bug的功能模块+bug的操作+bug的结果

        重现步骤——详细写下发现bug的测试过程。能指导开发重现这个bug。附上测试数据

        实际结果——出现bug的结果,粘贴bug截图日志截图

        预期结果——记得写清楚预期=测试用例的预期结果

        bug类型和严重程度--便于后续测试结果分析,bug的统计

        bug测试环境--例如:什么系统,哪个版本等。兼容性问题、难以重现问题

        附件--日志文件,文件测试数据。图片、崩溃日志文件等

四、禅道的使用(重点)

五、常见笔试面试题

        1、有没有你印象深刻的bug?bug的原因/bug当时怎么解决?

        2、bug的生命周期?(笔试)

        3、当你开了一个bug,但是开发不认为是bug,如何处理?

        4、你在发现bug并确认bug的过程中,对于复现率不高的bug怎么处理?

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

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

相关文章

X86下fftw3库的编译和链接undefined reference to fftwf_malloc

X86下fftw3库的编译和链接 因为缺少ARM板卡,这几天进行了将NENO代码移植到X86的工作,没想到,在FFT这里也卡了半天的时间。比较意外,这里稍作整理 因为现在有了kimi和chatgpt,一些与编译器交互的工作轻松了不少&#…

Spring 框架环境搭建

一、环境要求 JDK版本: JDK1.7及以上版本 Spring版本: Spring5.x版本 二、新建Maven项目 1. 创建 Maven 的普通 Java 项⽬ 2.设置项目坐标 3.设置项目的Maven环境 4.设置项目的名称和存放的工作空间 三、调整项目环境 1.修改JDK版本 properties&g…

使用 BERT 和逻辑回归进行文本分类及示例验证

使用 BERT 和逻辑回归进行文本分类及示例验证 一、引言 在自然语言处理领域中,文本分类是一项至关重要的任务。本文将详细介绍如何结合 BERT 模型与逻辑回归算法来实现文本分类,并通过实际示例进行验证。 二、环境准备 为了运行本文中的代码&#xf…

第8天:数据存储-补充材料——‘User.kt‘和‘UserDao‘解读

下面是对“第8天:数据存储”该文学习的更深层次的补充材料,对 ‘User.kt’和’UserDao’ 文件的理解。 下面对’User.kt’文件中每一行进行详细解释: 这段代码定义了一个数据类User,它用于与Room数据库中的表进行交互。下面是逐句…

网络安全包含哪些方面?如何加强网络安全建设?

系统安全、应用安全、物理安全、管理安全等都属于网络安全。 从大的角度,如系统安全来看,可以理解为在系统生命周期内应用系统安全工程和系统安全管理方法,辨识系统中的隐患,并采取有效的控制措施使其危险性最小。这包括操作系统的…

隐私保护下的数据提取策略

在隐私保护下进行数据提取,需要采取一系列策略来确保个人隐私得到妥善保护,同时满足数据使用的需求。以下是一些关键的策略和方法: 一、数据最小化原则 定义:仅收集和提取必要的数据,避免收集过多的个人信息或不相关…

qt QStackedLayout详解

QStackedLayout类提供了一种布局方式,使得在同一时间内只有一个子部件(或称为页面)是可见的。这些子部件被维护在一个堆栈中,用户可以通过切换来显示不同的子部件,适合用在需要动态显示不同界面的场景,如向…

【Web前端】JavaScript 对象原型与继承机制

JavaScript 是一种动态类型的编程语言,其核心特性之一就是对象和原型链。理解原型及其工作机制对于掌握 JavaScript 的继承和对象关系非常重要。 什么是原型 每个对象都有一个内部属性 ​​[[Prototype]]​​​,这个属性指向创建该对象的构造函数的原型…

请详细介绍python三大神器:迭代器、生成器、装饰器

Python三大神器分别是迭代器、生成器和装饰器,它们都是Python高级特性,可以提高程序的效率和灵活性。 迭代器(Iterators): 迭代器是一个对象,它允许逐个访问容器中的元素,而不需要提前把容器中的…

基于YOLO11/v10/v8/v5深度学习的危险驾驶行为检测识别系统设计与实现【python源码+Pyqt5界面+数据集+训练代码】

《博主简介》 小伙伴们好,我是阿旭。专注于人工智能、AIGC、python、计算机视觉相关分享研究。 ✌更多学习资源,可关注公-仲-hao:【阿旭算法与机器学习】,共同学习交流~ 👍感谢小伙伴们点赞、关注! 《------往期经典推…

python实战(五)——构建自己的大模型助手

一、任务目标 本文将利用大语言模型强大的对话能力,搭建一个PC端问答助手。具体来说,我们将使用API来调用我们想要的大模型,并结合Prompt让大模型根据任务类型生成对应的输出。为了更方便地调用大模型助手,我们将结合python第三方…

FPGA技术优势

在当今数字化时代,现场可编程门阵列(FPGA)因其高灵活性和强大的处理能力而广泛应用于各种行业。FPGA允许用户在单个芯片上实现大量数字逻辑,以相对较高的速度并且无需依赖传统顺序程序。这种独特的能力使得FPGA能够在许多复杂应用中脱颖而出。 FPGA的基本特性 FPGA是一种…

Android OpenGL ES详解——裁剪Scissor

目录 一、概念 二、如何使用 1、开启裁剪测试 2、关闭裁剪测试 3、指定裁剪窗口(位置和大小) 4、裁剪应用举例 三、窗口、视⼝和裁剪区域三者区别 四、源码下载 一、概念 定义1: 裁剪是OpenGL中提⾼渲染的⼀种方式,只刷新…

江协科技STM32学习- P22 实验-ADC单通道/ADC多通道

🚀write in front🚀 🔎大家好,我是黄桃罐头,希望你看完之后,能对你有所帮助,不足请指正!共同学习交流 🎁欢迎各位→点赞👍 收藏⭐️ 留言📝​…

PostgreSQL和MySQL在MVCC

PostgreSQL和MySQL在MVCC(多版本并发控制)机制上的不同主要体现在以下几个方面: MVCC实现方式 : PostgreSQL将数据记录的多个版本保存在数据库中,当这些版本不再需要时,垃圾收集器会回收这些记录。MySQL/…

【数据结构】树-二叉树-堆(下)

🍃 如果觉得本系列文章内容还不错,欢迎订阅🚩 🎊个人主页:小编的个人主页 🎀 🎉欢迎大家点赞👍收藏⭐文章 ✌️ 🤞 🤟 🤘 🤙 👈 &…

D365 FO开发参考

FO数据库表参考 InventTable in Main - Common Data Model - Common Data Model | Microsoft Learn FO编程Query参考 Query.addDataSource Method | Microsoft Learn FO核心Enums查询 BatchStatus Enum (Microsoft.Dynamics.Ax.Xpp) | Microsoft Learn FO Function 开发参…

前端笔面试查漏补缺

面试笔试的知识总结&#xff0c;查漏补缺 一、CSS样式隔离 CSS样式隔离用于确保组件或元素的样式不会与其他组件或元素的样式发生冲突。 1.scoped css -- <style scoped> 构建工具&#xff08;vue-loader&#xff09;会在编译阶段对css特殊处理&#xff0c;给当前组…

-XSS-

链接 https://github.com/do0dl3/xss-labs 搭建过程非常容易的 搭建好之后&#xff0c;就可以点击图片开始闯关了 第一关--JS弹窗函数alert() 显示payload的长度是4 level1.php?nametest level1.php?nametest1 发现只要改变name的值就显示什么在页面上 没有什么过滤的 …

【数据结构与算法】《Java 算法宝典:探秘从排序到回溯的奇妙世界》

目录 标题&#xff1a;《Java 算法宝典&#xff1a;探秘从排序到回溯的奇妙世界》一、排序算法1、冒泡排序2、选择排序3、插入排序4、快速排序5、归并排序 二、查找算法1、线性查找2、二分查找 三、递归算法四、动态规划五、图算法1. 深度优先搜索&#xff08;DFS&#xff09;2…