关于软件工程:软件工程-白盒测试各种覆盖详解

最近在温习软工
明天在这里总结一下白盒测试的各种笼罩~

从覆盖度高到覆盖度低的排序:

1.Path coverage(门路笼罩)
2.Combinatory coverage(多重条件笼罩/组合笼罩)
3.Clause/Branch coverage(条件/判断笼罩)
4.Clause coverage(条件笼罩)
5.Branch coverage(判断笼罩)
6.Statement coverage(语句笼罩)

用一个例子来示范:

门路笼罩-path coverage


对于门路笼罩,要把每一条路的每一种组合都走一遍。
在这里我标记了可能呈现分叉的abcdef几条路,对于门路笼罩应该把以下门路的状况都走一遍:
acef
bcef
acdf
bcdf

多重条件笼罩/组合笼罩 combinatory coverage

每一个判断中的每一个子句的组合都要笼罩

第一个判断:x>3 and z<10

x>3 z<10 x>3 and z<10
1 T T T
2 T F F
3 F T F
4 F F F

第二个判断 x==4 or y>5

x==4 y>5 x==4 or y>5
1 T T T
2 T F F
3 F T F
4 F F F

一组测试用例:(经测验你会发现能够满足全副的下面8个状况)
1) {x=4,y=6,z=5}
2) {x=4,y=3,z=10}
3) {x=3,y=4,z=5}
4) {x=3,y=6,z=11}

条件/判断笼罩
条件笼罩 clause coverage


每一个判断中的每个子句的不同true false都要取一次

对于这里一共有四个子句:x>3 z<10 x==4 y>5
x>3 取true false各一次(以及以上)
z<10取true false各一次(以及以上)
…以此类推 就能够满足条件笼罩

一组测试用例

  1. {x=4, y=5, z=5}
  2. {x=3, y=6, z=15}
判断笼罩 branch coverage


如图上标记,每个判断之后都有T和F的后果。

判断笼罩则是在可能在每个判断取至多一个T和至多一次F的测试用例笼罩。

一组测试用例:

  1. {x=4, y=5, z=5}
  2. {x=2, y=5, z=5}

评论

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理