使用逻辑覆盖测试方法测试以下程序段

1.题目一:使用逻辑覆盖测试方法测试以下程序段

void DoWork (int x,int y,int z)
{
1   int k=0,  j=0;
2   if ( (x>3)&&(z<10))
3   {
4       k=x*y-1;
5       j=sqrt(k);
6    }
7   if((x==4)||(y>5))
8   j=x*y+10;
9   j=j%3;
10 }

说明:程序段中每行开头的数字(1~10)是对每条语句的编号。
(1)画出程序的控制流图(用题中给出的语句编号表示)。
(2)分别以语句覆盖、判定覆盖、条件覆盖、判定/条件覆盖、组合覆盖和路径覆盖方法设计测试用例,并写出每个测试用例的执行路径(用题中给出的语句编号表示)

1、画出程序的控制流图(用题中给出的语句编号表示)

2、分别以语句覆盖、判定覆盖、条件覆盖、判定/条件覆盖、组合覆盖和路径覆盖方法设计测试用例,并写出每个测试用例的执行路径(用题中给出的语句编号表示)。


![在这里插入图片描述](https://i

语句覆盖
序号xyz覆盖语句执行路径
14691、2、3、4、5、6、7、8、9、101->2->3->4->5->6->7->8->9->10
判定覆盖
序号xyz覆盖判定执行路径
1469TT1->2->3->4->5->6->7->8->9->10
2359FF1->2->3->7->9->10
条件覆盖
序号xyz条件覆盖执行路径
1469TT TT1->2->3->4->5->6->7->8->9->10
23510FF FF1->2->3->7->9->10
判定条件覆盖
序号xyz条件覆盖执行路径
1469TT TT1->2->3->4->5->6->7->8->9->10
23510FF FF1->2->3->7->9->10
组合覆盖
序号xyz条件覆盖执行路径
1469TT TT1->2->3->4->5->6->7->8->9->10
24610TF FF1->2->3->7->9->10
3369FT FT1->2->3->7->9->10
43610FF FT1->2->3->7->9->10
5459TT TF1->2->3->4->5->6->7->8->9->10
6569TT FT1->2->3->4->5->6->7->8->9->10
7559TT FF1->2->3->4->5->6->7->9->10
逻辑覆盖测试是一种软件测试方法,用于测试代码中的条件语句和循环语句。它的目的是通过测试所有可能的情况来找出程序中的错误和漏洞,以提高代码质量。 下面是使用逻辑覆盖测试方法测试给定程序段的步骤: 1. 确定程序段中的谓词 谓词是一个布尔表达式,它决定了程序的执行路径。在给定程序段中,存在两个谓词: - (x > 3) && (z < 10) - (x == 4) || (y > 5) 2. 构造真值表 根据程序段中的谓词,我们可以构造两个真值表,分别表示谓词的所有可能的取值情况。真值表如下: | x > 3 | z < 10 | (x > 3) && (z < 10) | |-------|--------|---------------------| | 0 | 0 | 0 | | 0 | 1 | 0 | | 1 | 0 | 0 | | 1 | 1 | 1 | | x == 4 | y > 5 | (x == 4) || (y > 5) | |--------|-------|-----------------------| | 0 | 0 | 0 | | 0 | 1 | 1 | | 1 | 0 | 1 | | 1 | 1 | 1 | 3. 根据真值表构造测试用例 根据真值表中的结果,我们可以构造以下测试用例: - 当 (x > 3) && (z < 10) 为真时,k = x * y - 1,j = sqrt(k) - 测试用例:x = 4, y = 2, z = 5 - 预期结果:k = 7, j = 2 - 当 (x > 3) && (z < 10) 为假,(x == 4) || (y > 5) 为真时,j = x * y + 10,j = j % 3 - 测试用例:x = 4, y = 6, z = 15 - 预期结果:j = 1 - 当 (x > 3) && (z < 10) 和 (x == 4) || (y > 5) 都为假时,程序不会执行任何操作,j 的值未定义 - 测试用例:x = 2, y = 2, z = 15 - 预期结果:无 4. 编写测试用例并进行测试 根据上述步骤,我们可以编写以下测试程序: ```c #include <stdio.h> #include <math.h> void DoWork(int x, int y, int z) { int k = 0, j = 0; if ((x > 3) && (z < 10)) { k = x * y - 1; j = sqrt(k); } if ((x == 4) || (y > 5)) { j = x * y + 10; j = j % 3; } printf("DoWork(%d, %d, %d) = %d\n", x, y, z, j); } int main() { // 测试用例1 DoWork(4, 2, 5); // 预期输出:DoWork(4, 2, 5) = 2 // 测试用例2 DoWork(4, 6, 15); // 预期输出:DoWork(4, 6, 15) = 1 // 测试用例3 DoWork(2, 2, 15); // 预期输出:DoWork(2, 2, 15) = 未定义 return 0; } ``` 运行测试程序,得到预期输出,说明程序段的逻辑是正确的。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

她似晚风般温柔789

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值