一个需求在已经进入测试阶段时,还要改需求文档吗?为什么呢?
发布时间:
2024-10-05 11:29
阅读量:
25
进入测试阶段,不代表需求就稳定了。
虽然传统研发流程极力规避需求的不稳定性,但愿望美好,现实残酷,需求变化才是常态。
因此敏捷研发提出拥抱变化,妥协的办法其实是我把研发周期尽可能缩短,在这个周期内还是尽量别改需求了。但说好咱不是排斥这个事,只是要改也不能随意改。
所以说,研发过程中,即便已经到了测试阶段,需求变化,实际上是一个无法规避的问题,这个原因太多了:
- 用户有了新想法,不想要原来的方案了
- 老板有了新点子,有个功能得调整
- 产品经理发现个重要细节没考虑到,要加进来
- 开发人员发现有个严重Bug没法改,要么改需求要么再等3个月
- 安全团队说有个新风险,要考虑到需求中
- 法务团队说有个模块不合规,要补充合规需求
- 合作方对接的模块不稳定,有些接口要重新定义
- .... 等等等等
另外还有很重要的一点,其实就是需求的传递,是有很大衰减效应的,不同的角色听到的,理解的,传递出来的以及最后实现出来的,可能千差万别。比如下图经常用来描述需求传递中的信息错位,非常形象
那这个就没办法了吗?
其实不管是传统研发流程还是敏捷方法,都非常强调对需求的清晰描述和传递到位。敏捷中对Story有INVEST原则的要求,需求精炼会、计划会其实也都是对需求本身理解一致性上的保证。
对于团队来说,其实就是在追求需求的确定性,所以在一定周期内尽可能保证需求的稳定是基本要求。
大家都认可的这个周期间,需求可以变化,但要作为异常处理,变化带来成本,成本要有着落,如此,规则清楚定义好,变化既然不可避免,那么只要成本能承受,就接受变化。
END