Bug改不完,迭代总延期,咋办?
摘要:本文从流程上需要改进的地方进行讨论,分四个方面来分析产生这个问题的原因。
本文分享自华为云社区《Bug改不完,迭代总延期,咋办?》,作者: 华为云PaaS服务小智。
前言
随着互联网的兴起,版本交付越来越频繁,企业开始了敏捷转型、DevOps落地,项目组雄心勃勃,期望产品能按迭代快速交付。然而常见的现象是,到了迭代的最后一天,还有不少Bug来不及修复,迭代无法产生潜在可交付成果,延期成了必然。然后发现连续几个迭代都是这样,团队没有成就感,士气低落。迭代的无法按期交付,让团队及公司领导又觉得敏捷只是形式化,并没有解决问题,久而久之,就干脆放弃了所采用的敏捷框架,回到老路子上了。
迭代总是因为修复不完Bug而延期,该如何解决呢?本文从流程上需要改进的地方进行讨论,对于开发人员能力弱、迭代内需求量过多等人为因素我们不进行讨论。
问题分析
我们主要从下面四个方面来分析产生这个问题的原因。
流程上,在迭代内搞小瀑布开发
很多企业在转型敏捷后,依旧用着以前大瀑布的工作方式,即设计->开发->测试->修Bug,这就是我们常说的:在迭代内玩小瀑布。小瀑布继承了传统模式的一个弊端,就是测试工作放在了整个项目周期的最后一个环节,导致问题集中爆发,同时有的需求Bug也会影响到其他需求,而中间过程没有去检测bug,以至于导致其他需求又出现了新的Bug。到了后期,集中测试的时候,就发现Bug的关联性错综复杂,增加了修复的时间。
更要命的是,由于使用的是迭代开发,假如是一周的迭代,到了周四下午转交给测试人员,期望用两个小时测试通过,然后稍微修补修补小bug,产品就能上生产了。是不是感觉很熟悉?期望XXX结果XXX。按计划周四下午转交给测试,周五上生产,结果却常常是周四发现了太多的Bug,结果周四晚上团队加班修Bug,重新测,周五常常无法部署到生产,延期到下周。
需求上,需求澄清时没有明确的验收标准
这个问题在刚转型敏捷的团队中,出现的更多。敏捷强调的是充分沟通需求,再将讨论一致的点都记下来,特别是验收标准要写明了。但是实际中,大家对敏捷常常有个误区,就是不需要文档,需求也只要头口沟通下就行了,结果就是既没做到充分沟通,又没有最好记录,最重要的验收标准都没讨论清楚。这样,开发人员开发出来的产品到了测试环节,由于测试人员更偏重业务方向,所以对产品的认识和使用提出了一些看法,觉得某些地方的设计不够好,提了不少需求式的Bug,等测试完毕,在产品经理验收的时候,又会出于同样的原因提出一些Bug。这些Bug对于开发人员来说也很委屈,最开始的需求里并没有说明这几点应该做成什么样,现在提的这些Bug相当于额外加的需求,又不得不马上处理掉。
举个例子,需求澄清时,产品经理说想要个灵动的鲸鱼,和团队达成了一定的共识,双方讨论了下鲸鱼大概应该是下面的样子。
图1 需求版:灵动的鲸鱼
然而最后开发出来的结果却是下面这样。
图2 交付版:灵动的鲸鱼
出现这个结果的原因就是,在需求澄清时,没有清晰的验收标准,客户也不是很清楚自己的需求具象化之后什么样,团队和产品负责人以为达成了一致意见,实际上都是脑子中想象的一致,他们对图片的理解是不同的。真正验收的时候,产品负责人必然会要求再次改动。
这些我们可以称为需求变更,也不能说是需求变更,因为在需求澄清的时候,双方没有明确验收标准,在开发一个产品时,产品经理所想的和开发人员想的是不一样的,最后验收时就会提出各种可A可B的选择题,产品经理选的是A,他认为最开始讨论的时候达成的共识就是A,而你开发出来的是B,所以最后时刻提出看似新需求的Bug。
质量上,保证的工作全部交给了测试
传统的质量保证工作,就是在最后一个环节——测试里做到的。开发人员将做好的产品转交给测试人员,期望在这个环节里多多的测出Bug,然后自己很“勤奋”很“努力”的去修复。最终结果就是,大家都加班干活,项目依旧没法按时完成。开发疲于奔命的写(创)代(造)码(Bug)和修Bug,测试拿到开发好的代码后不厌其烦的寻找Bug,这期间并没有从源头上去提高质量。这就陷入了误区-质量是由测试来保证的。测试,只是检测手段,质量本身没有做好提高措施的话,光靠检测,只会事倍功半。
测试上,没有能力做到持续回归测试
新功能测试完毕后,要进行回归测试,这时候发现出现很多已有功能的Bug。已有功能的Bug又是新功能代码间接引入的,查找问题原因,修复Bug,再针对这一次修复进行回归,流程很长,花费时间比修复新功能的Bug要多。由于回归测试常常是放在了测试环节里面的最后一步来做,时间盒已经消耗殆尽,造成迭代延期。
传统项目里,回归测试常常做好几轮。以一个三个月开发周期为例,第四个月开始测试工作,到了月底可能测试+修复的差不多了,进行第一轮回归测试,然后继续修复新发现的Bug。一周后进行第二轮回归测试,再修复新Bug,再3天后进行第三轮回归测试,再修复,这样的流程。
我们都知道做软件开发过程中,会带来很多已有功能的Bug,但是依旧选择将这么重要的回归测试放在了项目的最最最后的那几天,导致集中出现大量的已有功能的Bug。通常这都是由于,做一次回归测试需要的时间太久导致的,团队没有能力做到每次更改代码,都快速的做一遍全量回归测试。
解决措施
针对上面提出的导致因为修复不完Bug而延期的四个方面问题,给出以下建议。
流程上,避免小瀑布陷阱
一定要避免诸如前半周需求,后半周设计,第一周开发第二周测试这样的小瀑布开发模式。
无论迭代里有多少个需求,一个迭代时长是几周,每开发完一个需求,立刻开始测试工作。
理想状态如下:
• 第一个需求开发完毕,测试人员开始测试,开发开始为第二个需求进行编码,期间同时修复第一个需求的Bug。
• 等第二个需求开发完毕,第一个需求的测试及bug修复应该也结束了,然后第三个需求的开发和第二个需求的测试工作应该开始了。
如果团队使用Scrum框架的话,那么在每天的站立会议上,团队在看板上移动需求卡片时,测试人员关注那些已经被开发人员移动到了已解决的卡片,按照实际能力将相应数量的移动到测试中,如下图所示。
图3 合理的任务看板
上图中,进行中和测试中的卡片数量都看上去没那么多,比较合理。如果出现类似下面的情况,开发活动开始了,完成了好多需求,但是测试活动远远落后,就要注意了,你可能掉进了小瀑布陷阱。
图4 不合理的任务看板
按照【图3:合理的任务看板】的卡片流转情况,这样可以尽早的发现需求的缺陷,降低了缺陷在系统中存留的时间,就是降低了它带来的风险。
需求上,澄清需求的时候明确验收标准
在需求澄清的时候,团队和产品负责人要对验收标准达成一致意见,并且记录下来,以辅助开发团队编码时有法可依。下图为示意图,在DevCloud记录用户故事的工作项里,同时记录验收标准,减少最后验收时出现需求式的Bug。
图5 DevCloud用户故事中的验收标准
质量上,通过预防来产生质量
质量管理大师克劳士比的质量管理基本原则里提到,预防产生质量,检验不能产生质量。所以,如果我们能在开发的时候就采取预防措施,做到第一次做正确,这才产生了质量,这也是零缺陷管理的核心。
图6 克劳士比零缺陷管理三要素
根据我们的实践和总结,推荐如下动作:
1. 沟通需求的时候,团队一起了解需求,在用户故事卡片里帮助添加检查点,以便于在编码的时候就会提前考虑这些检查点,进而编写代码的同时就保证了质量。
2. 在讨论需求和设计的时候,团队(一般由架构师或者技术能力强的测试人员来主导)就针对当前的设计和使用的技术提出需要注意的问题和建议,可以让开发人员在编码的时候就规避了潜在质量问题。
通过以上活动,从产品内在提高了质量,可以从本身上大大减少Bug数量。
测试上,加强自动化测试做到持续回归
从迭代里的第一次提交代码开始,任何一次提交代码,都做一次回归测试,这样可以保证第一时间发现对已有功能的影响,尽早修复,而不是在最后一次回归测试的时候发现问题。这个回归测试速度要快,也就是不花费太多时间,同时覆盖的面越广越好。
考虑到开发人员不爱做测试的共性,所以回归测试要做成便于开发人员维护,学习、维护成本低,效果好(如上所述的运行速度快、覆盖面广)的特点,比如说接口自动化测试。如下图所示,以软件开发平台 DevCloud 的接口测试为例,配置必要的信息,即为一个场景下的接口测试用例。
图7 DevCloud的接口测试配置
将所有接口都写好测试用例,然后配置到在流水线里。每次提交新的代码,都让它自动触发流水线,运行自动化测试用例,失败的话,就发邮件通知到该开发人员。
图8 DevCloud的流水线
这样,就可以高效的做了回归测试,最终使得在编码期间,有任何Bug出现,都可以第一时间发现,不会都堆积到项目的最后时刻爆发。
总结
迭代总是因为修复不完Bug而延期,解决方法并不是团队继续加班去工作,而是要找到根本原因,对症下药,通过诸如避免小瀑布陷阱、通过预防来产生质量、增加接口自动化测试、需求澄清时明确验收标准等措施来改善工作流程,才能避免陷入恶性循环,彻底解决这个问题。
Bug改不完,迭代总延期,咋办?的更多相关文章
- Bug 是改不完滴
- vscode vue template 下 style 的样式自动提示 #bug 这个搞完vue语法esLint就又不好使了,ERR
网上都是 "*.vue": "vue",改成"*.vue": "html" 就ok了 "files.ass ...
- 可是把ie67下面的bug改好了,其实很简单,ie67下面取出来的字符串是带有空格的,不知道为什么
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...
- 修改BUG心得
修改BUG心得 分类: 项目管理/CMMI2013-01-14 22:06 845人阅读 评论(0) 收藏 举报 目录(?)[-] 一 二 三 一. 1.写第一版时就杜绝这些的发生. 2.思维要开 ...
- 原创科幻短篇《Bug》
这回不是纯科幻,夹了点玄幻. 以下正文: 大一的时候,李双休谈了个女朋友,俩人学校相距不远,周末约一起看电影.那是李双休第一次自己坐公交,坐反了,绕城一周,电影开始后一个小时才到,就赶上看了个片尾彩蛋 ...
- wpf Popup Win8.0 bug HorizontalOffset 弹出位置偏移
问题描述参考 wpf 客户端[JDAgent桌面助手]开发详解(四) popup控件的win8.0的bug 当开发完程序后,我们在多操作系统测试时候发现:win8.0 系统中 popup 弹出的位置 ...
- 哎呀,我老大写Bug啦——记一次MessageQueue的优化
MessageQueue,顾名思义消息队列,在系统开发中也是用的比较多的一个中间件吧.我们这里主要用它来做日志管理和订单管理的,记得老老大(恩,是的,就是老老大,因为他已经跳槽了)还在的时候,当时也是 ...
- 给JDK提的一个bug(关于AbstractQueuedSynchronizer.ConditionObject)
1. 背景 之前读JUC的AQS源码,读到Condition部分,我当时也写了一篇源码阅读文章--(AbstractQueuedSynchronizer源码解读--续篇之Condition)[http ...
- 一次线上bug引起的反思
今天线上又出现了一个bug,而且代码是我写的.之前这个问题也出现过,不过由于每次情况都不同,改来改去总是改不完.之后领导知道后也很恼火,让测试把每种情况都测试了下,而我也又一次重新检查了下代码.当时确 ...
随机推荐
- 重写并自定义依赖的原生的Bean方法
转载请注明出处: 在项目开发过程中,往往是直接应用很多jar包中依赖且声明好的Bean,拿来即用,但很多场景也需要对这些原生的Bean 进行自定义,定制化封装,这样在项目使用的过程中,可以使用自定义的 ...
- linux 编译式安装apache
apache的安装需要两个组件,APR对于Tomcat最大的作用就是socket调度 组件下载解压完成 ,讲两个组件解压包移动到apache的类库文件夹内 注:如果系统自带了apr和apr-util可 ...
- devops-4:Jenkins基于k8s cloud和docker cloud动态增减节点
Jenkins管理动态节点 上文介绍Jenkins增加静态agent的步骤,除了静态增加外,还有动态管理的功能,两者最大的差异在于动态可以在有job运行时,临时加入一个agent到jenkins ma ...
- MySQL8.0错误日志Error log
GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源. 理论知识 错误日志内容 错误日志包含mysqld启动和关闭的时间信息,还包含诊断消息,如服务器启动和关闭期间以及服务器运行 ...
- Linux 03 用户管理
参考源 https://www.bilibili.com/video/BV187411y7hF?spm_id_from=333.999.0.0 版本 本文章基于 CentOS 7.6 概述 Linux ...
- java-Servlet编码/异常处理
1. Servlet输出中文(1)为什么会有乱码?out.println方法在输出时或者表单提交的时候,浏览器会对表单中的中文参数值进行编码; 注:会使用表单所在的页面打开时使用的编码方式进行编码服务 ...
- 在 C# 中使用 Span<T> 和 Memory<T> 编写高性能代码
目录 在 C# 中使用 Span 和 Memory 编写高性能代码 .NET 中支持的内存类型 .NET Core 2.1 中新增的类型 访问连续内存: Span 和 Memory Span 介绍 C ...
- 洛谷P4135 作诗(不一样的分块)
题面 给定一个长度为 n n n 的整数序列 A A A ,序列中每个数在 [ 1 , c ] [1,c] [1,c] 范围内.有 m m m 次询问,每次询问查询一个区间 [ l , r ] [l, ...
- C#基础_理解类
构造函数主要是用来创建对象时为对象赋初值来初始化对象.总与new运算符一起使用在创建对象的语句中 .A a=new A(); 构造函数具有和类一样的名称:但它是一个函数具有函数的所有特性,同一个类里面 ...
- 【manim】含有add_updater更新函数become的物体移动方法
在manim社区版本中, 一.对于一般的物体,移动的方法分为 (瞬移) 和 (带动画移动) 1.瞬移 #直接对物体操作即可 obj.shift(LEFT) #瞬间移 ...