小明入职已有两年,期间测试能力已不知不觉成长许多,得到了Leader大熊的高度认可。回首这两年间,小明对“Bug总结流程”印象最为深刻,他对这个流程的认识在不断改变着:从最初的好奇,逐步变为反感,最终因为收益良多,重新走向认同。今天我们来介绍下这个流程。

两年前的某天,大熊在思考一件事情:如何能够帮助组员快速提高测试技能

以往的管理经验告诉他,只是安排一些讲座培训无济于事,如果没有实际的实例与测试理论知识贯通,这就如同学校里照本宣科一般无法学以致用;同时没有实际的示例,很多异常测试点总是遭到组员的质疑(例如:有同学就会质疑网络返回超时这种情况不用测试吧)。

“理论”、“实践”、“说服力”、“知行合一”,这些名词在大熊的脑中不断地闪现,最终一根线将这些词汇串联在了一起:基于线上漏测问题的Bug总结流程。

Bug总结思想

  1. 对线上漏测的问题进行收集

  2. 对每一个漏测的问题详细分析Bug机理以及漏测的原因

  3. 基于以上的原因思考如何进行改进,避免漏测问题发生

  4. 将改进方案实施

  5. 重复以上的步骤,通过正向循环推动测试团队的质量改进不断优化

Bug总结流程:

为了便于流程的运转和操作,大熊在Cynthia系统上建立了总结流程和表单:


举例说明:

某天,小明测试的搜狗手机输入法项目在上线后,出现了许多线上统计数据不正确的问题。小明收到这个问题反馈后,第一时间跟进和处理问题,确认问题存在,同时配合开发等人一同追查问题原因,后该问题经过追查,原因是覆盖安装所致,开发随后根据该问题进行了问题修正。

流程演练:

1.大熊收到这个问题后,会让小明将此问题录入Cynthia的总结表单

2.小明根据跟进了解的信息,在Cynthia上分别填写:

a.问题原因(包括开发原因和测试原因)

开发原因:

用户在客户端操作之后的pingback不会立即写进这个文件, 会在几种情况下(输入法崩溃,退出,关机,进入设置界面)保存文件.
文件保存位置/data/data/com.sohu.inputmethod.sogou/files/shared_prefs
/com.sohu.inputmethod.sogou_preferences.xml。旧版本按照旧格式保存文件,开
发在代码中没有考虑兼容旧格式的pingback,所以第一次读取旧版本已经保存的文件时, 会因为格式不兼容而读错位, 又由于错位,
某些本应以字符串方式解析的pingback错误地以整数方式解析, 导致解析过程中断(具体来说, 130为止会中断), 结果就是,
130以前的读错位, 130以后的丢失,所以会影响全部的pingback。新旧格式存储见附件。

测试原因:

1)测试对pingback模板的开发实现了解不够全面深入,导致pingback模块有修改时,还停留在黑盒测试层面;

2)测试设计考虑不足,输入法覆盖安装的case漏测。

b.问题分类(该问题属于什么类型)

示例中的问题由于没有进行开发改动的实现了解,所以问题类型判定为“用例设计不足->设计层面了解不足”和"测试经验,测试发散度不足"

c.开发解决方案

    先判断第一位是否为空,如果不为空(旧格式),将旧格式映射到新格式上,再按照新格式读取;如果为空,直接按照新格式读取

d.测试改进方案(根据问题原因来推导如何进行改进,避免类似问题重复发生)

1)从V8.8版本开始,测试组对每个模块都要绘制开发实现流程图,以进一步深入了解开发实现;

2)在上线前测试checklist中特增加覆盖安装的case,从流程上保证测试质量;

3)在流程上,对代码优化或代码重构等技术需求进行改动内容调研,并产出【影响范围】评估报告。

4)整理pingback测试点形成文档,每次测pingback时都按照该文档进行。若pingback有改动,在此基础上添加测试点。

3.大熊对小明填写的表单各项内容进行审核,各个字段的内容了解深入、填写无误后,大熊置为审核通过,该表单会处于改进方案实施中。

4.后续大熊会督促小明的改进方案实施,如:小明整理pingback测试点文档。

5.当以上改进方案实施完毕后,小明将此表单置为改进完毕交由大熊审核关闭。

正是通过以上流程,小明在这两年期间积累了非常多的经验,测试能力稳步提高,逐渐成为了团队的顶梁柱。

“反省是一面镜子,它能将我们的错误清清楚楚地照出来,使我们有改正的机会。——海涅”

Bug总结流程的更多相关文章

  1. BUG处理流程说明

    一.        BUG处理流程图: 流程描述: 1.  测试人员发现bug提交给开发. 2.  开发人员判断是否是bug. 3.  如果是bug,进行修改,修改完成后更改bug状态为已解决. 4. ...

  2. 软件测试面试必问--bug交互流程

    目前市场主要用的bug管理工具:禅道.jira.QC.bugfree等,当然也有自己公司开发的. 不过不管哪一种工具,核心交互流程都是差不多的,只是字段的名称不一样而已,参考如下两张示意图: 这是前几 ...

  3. 敏捷开发系列学习总结(2)——Bug修改流程

    原则,力求各司其职,简单明了. 1. 测试人员提交bug ⑴ 标题: [ 模块名称 ] 问题描述 ⑵ 内容: 问题重现步骤的描述,最好贴上图片. 因为一图胜万言. ⑶ 指定责任人: 根据bug指定责任 ...

  4. 解决一bug的流程复盘

    听同事说有一个功能不好使了,当时有事,过了一段时间来看看这个bug 解决问题时,看的是老的日志,根据老日志看来看去没有发现问题,觉得很困惑 然后手动执行了一下,发现问题没有重现.与另一个团队的同事沟通 ...

  5. 线上Bug修复流程

  6. bug的处理流程

    又属于一篇普及文,希望自己在被各种技术吸引的同时,能时常来整理和总结软件测试最基本的知识. 从刚工作时接触的第一个缺陷管理工具禅道,到redmine.JIRA.bugzilla ,再到现在的QC,当然 ...

  7. Bug跟踪的流程

    本文以翼发云协同项目管理系统为例子来讲解Bug跟踪的流程,它以工作流为中心的集成式Bug跟踪软件,它广泛地应用于研发行业的产品缺陷管理 与跟踪.事务跟踪.问题跟踪.任务跟踪.查询跟踪.需求管理.变更跟 ...

  8. Git之修复Bug流程

    场景描述 当一个项目已经上线,同时又在原有基础上新增功能模块,于是乎就要在原有代码的基础上进行开发,在新增模块功能的开发的过程中,项目发现了一个紧急Bug,需要修复.应对这种情况,有以下两种解决方案: ...

  9. 流程开发Activiti 与SpringMVC整合实例

    流程(Activiti) 流程是完成一系列有序动作的概述.每一个节点动作的结果将对后面的具体操作步骤产生影响.信息化系统中流程的功能完全等同于纸上办公的层级审批,尤其在oa系统中各类电子流提现较为明显 ...

随机推荐

  1. Spring学习笔记之五----Spring MVC

    Spring MVC通常的执行流程是:当一个Web请求被发送给Spring MVC Application,Dispatcher Servlet接收到这个请求,通过HandlerMapping找到Co ...

  2. C# 隐藏标题栏 调整大小 并且移动窗口

    隐藏标题栏(窗口属性): 1.设置在该窗体的标题栏中是否显示控件框: this.ControlBox = false; 2.设置在该窗体的标题为空: this.Text = string.Empty; ...

  3. SAMSUNG某型号一千短信成功记录!对比其他软件恢复不成功的案列!

    Hello! 大家好欢迎再次来到Dr.wonde的博客, 下面谈一下今天的案列,今年11月26号收到了一客户寄来的三星S4手机恢复里面短信, 如下图所示,用其他软件恢复以后,数据为零,没有恢复,,这下 ...

  4. linux文件基本属性

    在Linux中第一个字符代表这个文件是目录.文件或链接文件等等. 当为[ d ]则是目录 当为[ - ]则是文件: 若是[ l ]则表示为链接文档(link file): 若是[ b ]则表示为装置文 ...

  5. Client Window坐标 RECT相关函数

    GetClientRect(HWND, RECT*) ---得到窗口的客户区大小,left,top总是0,bottom是客户区高度,right是客户区宽度 GetWindowRect(HWND, RE ...

  6. 2017年1月2日 星期一 --出埃及记 Exodus 21:28

    2017年1月2日 星期一 --出埃及记 Exodus 21:28 "If a bull gores a man or a woman to death, the bull must be ...

  7. ZJOI2007矩阵游戏

    题目描述 小Q是一个非常聪明的孩子,除了国际象棋,他还很喜欢玩一个电脑益智游戏――矩阵游戏.矩阵游戏在一个N*N黑白方阵进行(如同国际象棋一般,只是颜色是随意的).每次可以对该矩阵进行两种操作: 行交 ...

  8. 自己动手写Logistic回归算法

    假设一个数据集有n个样本,每个样本有m个特征,样本标签y为{0, 1}. 数据集可表示为: 其中,x(ij)为第i个样本的第j个特征值,y(i)为第i个样本的标签. X矩阵左侧的1相当于回归方程的常数 ...

  9. 基于Apache+php+mysql的许愿墙网站的搭建create database xyq; //创建xyq数据库

    1.准备CentOS7与CentOS5的基础配置 2.在两台虚拟机中配置yum. 3.在CentOS7中安装httpd与php与php-mysql PS:截图时已安装 CentOS7 关闭防火墙与se ...

  10. tomact的work目录

    1.  用tomcat作web服务器的时候,部署的程序在webApps下,这些程序都是编译后的程序(发布到tomcat的项目里含的类,会被编译成.class后才发布过来,源文件没有发布过来,但这里的j ...