修正条件判定覆盖

修正条件/判定覆盖 MC/DC --Modified Condition/Decision Coverage:锁定其他的条件不变,改变一项条件,必引起整个表达式变化.

【例】IF(A||B||C)THEN  W=W/X

锁定AB的值不变(FF_) 改变C条件的值 {FFT,FFF}

锁定AC的值不变(F_F) 改变B条件的值 {FTF,FFF}

锁定BC的值不变(_FF) 改变A条件的值 {TFF,FFF}

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先,我们需要确定程序的决策条件和边界条件。通过对程序代码的分析,我们可以得到以下决策条件和边界条件: 决策条件: 1. number != 0 && strcmp(initialword, word) != 0 2. word[a] == alphabet 3. word[a] != alphabet && a == n - 1 边界条件: 1. n = 0 2. n = 1 3. n = 2 4. word = "" 5. word = "a" 6. word = "ab" 7. word = "aa" 8. word = "abc" 9. word = "aaa" 10. word = "bbb" 根据修正条件判定覆盖法,我们需要设计的测试用例如下: 1. 当n=0时,测试number != 0 && strcmp(initialword, word) != 0 2. 当n=1时,测试number != 0 && strcmp(initialword, word) != 0 3. 当n=2时,测试number != 0 && strcmp(initialword, word) != 0 4. 当word=""时,测试number != 0 && strcmp(initialword, word) != 0 5. 当word="a"时,测试number != 0 && strcmp(initialword, word) != 0,word[a] == alphabet,word[a] != alphabet && a == n - 1 6. 当word="ab"时,测试number != 0 && strcmp(initialword, word) != 0,word[a] == alphabet,word[a] != alphabet && a == n - 1 7. 当word="aa"时,测试number != 0 && strcmp(initialword, word) != 0,word[a] == alphabet,word[a] != alphabet && a == n - 1 8. 当word="abc"时,测试number != 0 && strcmp(initialword, word) != 0,word[a] == alphabet,word[a] != alphabet && a == n - 1 9. 当word="aaa"时,测试number != 0 && strcmp(initialword, word) != 0,word[a] == alphabet,word[a] != alphabet && a == n - 1 10. 当word="bbb"时,测试number != 0 && strcmp(initialword, word) != 0,word[a] == alphabet,word[a] != alphabet && a == n - 1 11. 当number=0时,测试strcmp(initialword, word) != 0 12. 当strcmp(initialword, word)=0时,测试strcmp(initialword, word) == 0 以上测试用例可以覆盖所有决策条件和边界条件

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值