软件测试中的5个为什么

原文:The Five Why's and Testing Software


丰 田车之所以能够在市场上超过美国车,部分原因是因为他们的生产和研发体系。这一体系以其所谓“精益”技术而流行。其中一条原则就是问5个为什么 (Why)。这可不是新闻业中的5个W:Who(谁),What(什么),Why(为什么),Where(何地),和When(何时)。甚至都不是什么具 体的问题。问5个为什么意味着问5次为什么。例如,为什么汽车的产量降低了?因为螺丝不见了。为什么螺丝不见了?因为工作机器人把螺丝都弹出去了。为什么 机器人弹螺丝?因为程序出错了。为什么程序出错了?因为程序员没有考虑公制到英制的转换。为什么程序员不考虑转换呢?因为……

并不是说5这个数字有什么魔力。也可以是4或者6。重要的是要一直问为什么,直到找到并解决问题根源。否则只是缓和一下深层问题。不解决根本问题的话,迟早出现其它问题,浪费更多时间。

这 一原则如何应用于测试呢?这涉及到测试在团队中的核心作用。设想团队成员发现了你软件中的一个bug。你会怎么做?希望测试团队中的某个人把这个bug录 入存档起来,然后测试或是开发找到了问题的根源并修复了。这通常意味着定位并修改出错的代码行。问题解决了。是么?但为什么开始那行代码写错了呢?我们很 少问这个问题。

也许我们应该重新审视我们做为测试的作用,我们应该努力使bug从整个系统中消除,而不是仅仅从源代码里。这样,我们就会 询问可以使用哪些编码技术或早期测试系统来阻止bug进入源代码,或者是当代码还在开发期内就能够发现这些bug(这种情况下或许可以采用更好的单元测试 来做到)。

SteveRowe发表于2008-10-17 星期五
Alex翻译于2008-10-28 星期二
转载请注明作译者

你可能感兴趣的:(软件测试,软件测试,测试,单元测试,testing,工作)