看博客,说观点,聊意见,交朋友。 现在已经习惯了用微博客表达自己的观点,因此这里也会微博一下。 --------专写软件测试博客读后感

如何估算剩余bug的数量

上一篇 / 下一篇  2006-12-04 23:27:59 / 天气: 晴朗 / 心情: 高兴

   archonwang在回复我的“也说软件测试中的80-20定律”一文时提到了这样一个问题:

   如何估算剩余的bug数量,曾尝试过用80-20法则进行估算,不过精确度似乎不高,应该怎样计算比较合理?

   以前好像看过这方面的资料,但实际工作中没有尝试过,有点纸上谈兵的意思了,呵呵。下面就胡乱说点吧,希望能有点帮助。

    我们通过测试发现软件中的bug实际上可以看成对软件中存在的所有bug进行采样的一个过程,不同人的人采样出来的bug可能有区别,但所针对的bug群体是相同的。

    单纯从一个测试人员来看,仅根据他的采样是无法去判断到底还剩余多少bug的,要想比较好的估算bug的总数或者剩余的bug数,只能借助于多个测试人员的采样了。这里实际上就是常见的
鱼塘法

   鱼塘法是用来估算鱼塘中鱼的数量的:从鱼塘中捞上来比如100条鱼,为每条鱼都作上标记,表明这些鱼是曾经被捕捉过的,然后把这些鱼放回鱼塘中去,过一段时间后(主要是想让被捕到的鱼尽量均匀的分布到鱼塘中去),再补100条上来,检查有多少条是标记的,比如是50条,那么就可以估算出鱼塘中的鱼的总数为100*100/50=200条了。

    这种思路也可以借鉴到bug的估算中来:让两个测试人员A和B同时独立对同一被测对象进行测试,自己使用自己的思路和方法。测试结束后,A发现了m个bug,而B发现了n个bug,两人相同的bug有k个,那么总的bug数就可以估算成
m*n/k了。

   当然这种思路有其前提条件:
    1、采样要足够多,也就是说发现的bug数不能太少,要和总的bug数具有可比性,否则这种基于采样的思路就行不通了;
    2、测试人员的水平要比较接近,不能相差太大,不然很容易出现,一个人发现的bug是另一个人的子集,那就没意思了;
    3、针对的被测对象一定要完全相同,不能有bug修复的过程,否则两个人所针对的样本空间就不一样了,那样这种思路也就失效了。

    在实际工作中想对所有的测试都进行这种成对的测试是不可能的,因此很多大的公司主要还是采用收集历史数据获得经验参数的方式来进行估算的,比如经过相当长时间数据的收集和整理,可以得到
bug数/KLOC,这样要估算剩余的bug就比较简单了。

    而对于一些没有什么历史数据收集整理的公司,这种鱼塘法就能派上用场了。选择部分代码作为被测试对象,选择两个还算有点经验的测试人员(主要是为了保证采样不会太差),独立对这些代码进行测试,最后能估算出这些代码对应的总的bug数出来,然后除以代码行数,就得到了bug数/KLOC了,那这个参数就可以用于其它代码bug数的估算了。

PS:不知道
archonwang是如何用80-20法则来进行估算的,呵呵。


TAG: 鱼塘法 估算bug数

51test_pp的个人空间 引用 删除 51test_pp   /   2012-12-22 14:30:30
1
allen2000的个人空间 引用 删除 allen2000   /   2011-01-26 17:29:03
请问鱼塘法的理论依据是?
老A 引用 删除 archonwang   /   2008-06-30 09:29:21
实际上,当时提这个问题的时候还不是想得很清楚,80-20法则的适应范围被无限放大了,应该还有更精确、更科学的方法进行估算。之后,读了很多估算方面的书籍,才明白80-20法则还不能适用于这类科学计算方法。感谢skinapi的详细说明!
引用 删除 bjwander   /   2007-01-20 16:24:24
估算bug数首先有两种方式,一种为根据项目规模估算,另外一种为根据已经完成的估算
但这两种都有很大的限制,所以在实际中的运用也一定要分析清楚,是否能够真正有用
根据项目规模估算:首先项目的规模和历史项目要有很大相似的地方,另外测试人员和开发人员的水平也要有较大相似,所以做到这一点很难,做到这一点需要大量项目的积累,另外项目的分类,项目规模的统一性等等,最后建立一个模型
第二种只是简单的估算,但这种估算要考虑人员的能力和变动,所以也是一个模型,不过这个模型也原始脱胎于第一个模型,只是简化分析了内容罢了
 

评分:0

我来说两句

日历

« 2024-04-22  
 123456
78910111213
14151617181920
21222324252627
282930    

数据统计

  • 访问量: 45640
  • 日志数: 8
  • 图片数: 1
  • 书签数: 35
  • 建立时间: 2006-11-22
  • 更新时间: 2010-09-21

RSS订阅

Open Toolbar