精华内容
下载资源
问答
  • 为以下流程图所示的程序段设计一组测试用例,要求分别满足语句覆盖、判定覆盖、条件覆盖、判定/条件覆盖、组合覆盖和路径覆盖。 语句覆盖:每条语句至少执行一次,即每个可执行语句都执行一次。 判定覆盖:每个...

    记录一次作业,有关白盒测试的知识点。
    详细讲解可看这篇博文
    https://www.cnblogs.com/virus1102/p/4953099.html

    用逻辑覆盖法为流程图设计测试用例

    为以下流程图所示的程序段设计一组测试用例,要求分别满足语句覆盖、判定覆盖、条件覆盖、判定/条件覆盖、组合覆盖和路径覆盖。

    • 语句覆盖:每条语句至少执行一次,即每个可执行语句都执行一次。

    • 判定覆盖:每个判定的每个分支至少执行一次。即图中的条件判定必须覆盖Y/N的情况。

    • 条件覆盖:每个判定的每个条件应取到各种可能的值。

    • 判定/条件覆盖:同时满足判定覆盖条件覆盖。

    • 条件组合覆盖:判定中各条件的每一种组合至少出现一次。如X<4 and Y>8 那么即有4种

    • 路径覆盖:使程序中每一条可能的路径至少执行一次。
      在这里插入图片描述
      测试用例:

    • 语句覆盖

    X=10,Y=11
    X=-1,Y=1
    X=-1,Y=-1

    • 判定覆盖

    X=10,Y=11
    X=10,Y=10
    X=-1,Y=1
    X=-1,Y=-1

    • 条件覆盖

    X=17 Y=11
    X=-5 Y=-1;

    • 判定/条件覆盖

    X=17,Y=11
    X=10,Y=10
    X=-1,Y=1
    X=-5,Y=-1

    • 组合覆盖

    X=17,Y=11
    X=17,Y=-1;
    X=-5,Y=11;
    X=-5,Y=-1;

    • 路径覆盖

    X=17,Y=11;
    X=10,Y=8;
    X=-1,Y=-1;
    X=-1;Y=1

    展开全文
  • 白盒测试用例设计的一个很重要的评估标准就是对代码的覆盖度。一说到覆盖,大家都感觉非常熟悉,但是常见的覆盖都有哪些?各自有什么优缺点?...白盒测试中常见的覆盖有六种:语句覆盖、判定覆盖、条...

    文章转自:http://www.51testing.com/html/44/n-3713444.html

    白盒测试用例设计的一个很重要的评估标准就是对代码的覆盖度。一说到覆盖,大家都感觉非常熟悉,但是常见的覆盖都有哪些?各自有什么优缺点?在白盒测试的用例设计中我们应该如何自如地运用呢?今天小编就为大家总结了一下几种常见的覆盖以及各自的优缺点。

    白盒测试中常见的覆盖有六种:语句覆盖、判定覆盖、条件覆盖、判定/条件覆盖、组合覆盖和路径覆盖。下面我们就分别看看这几种不同的覆盖究竟是什么鬼。

    一、语句覆盖(Statement Coverage)

    语句覆盖,顾名思义就是针对代码语句的嘛。它的含义是我们设计出来的测试用例要保证程序中的每一个语句至少被执行一次。通常语句覆盖被认为是“最弱的覆盖”,原因是它仅仅考虑对代码中的执行语句进行覆盖而没有考虑各种条件和分支,因此在实际运用中语句覆盖很难发现代码中的问题。举个非常简单的例子:

    public int foo(int a,int b)

    {

    return a/b;

    }

    这是一个求两数之商的函数。如果我们设计如下的测试用例:

    TestCase: a = 2, b = 1

    这时候我们会发现,该函数的代码覆盖率达到了100%,并且设计的case可以顺利通过测试。但是显然该函数有一个很明显的bug:当 b=0 时,会抛出异常。

    二、判定覆盖(Decision Coverage)

    判定覆盖也被成为分支覆盖(Branch Coverage),也就是说设计的测试用例要保证让被测试程序中的每一个分支都至少执行一次。举个例子,有如下流程图:

    针对该图我们想要做到判定覆盖,可以设计如下case:

    TestCase1: a=1, b=1    (路径:ab)

    TestCase2: a=-1, b=-1    (路径:acd)

    TestCase3: a=2, b=-1    (路径:ace)

    判定覆盖比语句覆盖强一些,能发现一些语句覆盖无法发现的问题。但是往往一些判定条件都是由多个逻辑条件组合而成的,进行分支判断时相当于对整个组合的最终结果进行判断,这样就会忽略每个条件的取值情况,导致遗漏部分测试路径。

    三、条件覆盖(Condition Coverage)

    条件覆盖于分支覆盖不同,条件覆盖要求所设计的测试用例能使每个判定中的每一个条件都获得可能的取值,即每个条件至少有一次真值、有一次假值。

    仍然以上面流程图作为例子来说明。上图中涉及到的条件一共有4个:

    a>0, a<0, b>0, b<0

    为了达到条件覆盖的目的,我们设计的用例需要在 a 点有:

    a>0, a≤0, b>0, b≤0,

    这些情况出现,并且在 c 点有:

    a<0, a≥0, b<0, b≥0

    这些情况出现。现在可以设计如下用例:

    TestCase1: a=1, b=1    (路径:ab)

    TestCase1: a=-1, b=-1    (路径:acd)

    TestCase1: a=-1, b=0    (路径:ace)

    TestCase1: a=1, b=-1    (路径:ace)

    通常而言条件覆盖比判定覆盖强,因为条件覆盖使得判定中的每一个条件都取到了不同的结果,这一点判定覆盖则无法保证。但条件覆盖也有缺陷,因为它只能保证每个条件都取到了不同结果,但没有考虑到判定结果,因此有时候条件覆盖并不能保证判定覆盖。

    四、判定条件覆盖(Decision/Condition Coverage)

    判定条件覆盖,说白了就是我们设计的测试用例可以使得判断中每个条件所有的可能取值至少执行一次(条件覆盖),同时每个判断本身所有的结果也要至少执行一次(判定覆盖)。不难发现判定条件覆盖同时满足判定覆盖和条件覆盖,弥补了两者各自的不足,但是判定条件覆盖并未考虑条件的组合情况。

    五、组合覆盖(Branch Condition Combination Coverage)

    组合覆盖也叫做条件组合覆盖。意思是说我们设计的测试用例应该使得每个判定中的各个条件的各种可能组合都至少出现一次。显然,满足条件组合覆盖的测试用例一定是满足判定覆盖、条件覆盖和判定条件覆盖的。

    针对前文提到的流程图,做条件组合覆盖时我们可以设计如下用例:

    TestCase1: a=1, b=1    (路径:ab)

    TestCase1: a=-1, b=-1    (路径:acd)

    TestCase1: a=-1, b=0    (路径:ace)

    TestCase1: a=1, b=-1    (路径:ace)

    条件组合覆盖能够同时满足判定、条件和判定条件覆盖,覆盖度较高,但是组合覆盖的测试用例数量相对来说也是比较多的。

    六、路径覆盖

    路径覆盖,意思是说我们设计的测试用例可以覆盖程序中所有可能的执行路径。这种覆盖方法可以对程序进行彻底的测试用例覆盖,比前面讲的五种方法覆盖度都要高。那么这种方法是不是就一定最好呢?当然不能讲得这么绝对,它的缺点也是显而易见的:由于需要对所有可能的路径全部进行覆盖,那么我们需要设计数量非常巨大的而且较为复杂的测试用例,用例数量将呈现指数级的增长。所以理论上来讲路径覆盖是最彻底的测试用例覆盖,但实际上很多时候路径覆盖的可操作性不强。

    总结

    以上简单描述了几种不用的逻辑覆盖方法的原则和优劣。在实际的操作中,要正确使用白盒测试的代码覆盖方法,就要从代码分析和代码调研入手,根据调研的结果,可以选择上述方法中的某一种,或者好几种方法的结合,设计出高效的测试用例,尽可能全面地覆盖到代码中的每一个逻辑路径。

     

    展开全文
  • if C or D then Action2 语句覆盖最弱,只需要让程序中的语句都执行一遍即可 。上例中只需设计测试用例使得A=true B=true C=true 即可。 分支覆盖又称判定覆盖:使得程序中每个判断的取真分支取假分支至少经历一次...

    举个例子吧
    if A and B then Action1
    if C or D then Action2

    语句覆盖最弱,只需要让程序中的语句都执行一遍即可 。上例中只需设计测试用例使得A=true B=true C=true 即可。

    分支覆盖又称判定覆盖:使得程序中每个判断的取真分支和取假分支至少经历一次,即判断的真假均曾被满足。上例需要设计测试用例使其分别满足下列条件即可(1)A=true,B=true,C=true,D=false(2)A=true,B=false,C=false,D=false。

    条件覆盖:要使得每个判断中的每个条件的可能取值至少满足一次。上例中第一个判断应考虑到A=true,A=false,B=true,B=false第二个判断应考虑到C=true,C=false,D=true,D=false,所以上例中可以设计测试用例满足下列条件(1)A=true,B=true,C=true,D=true(2)A=false,B=false,C=false,D=false。

    路径覆盖:要求覆盖程序中所有可能的路径。所以可以设计测试用例满足下列条件(1)A=true,B=true,C=true,D=true(2)A=false,B=false,C=false,D=false(3)A=true,B=true,C=false,D=false(4)A=false,B=false,C=true,D=true。

    不论那种覆盖方法,都不能保证程序的正确性。

    原文

    语句覆盖是指选择足够的测试用例,使得运行这些测试用例时,被测程序的每一个语句至少执行一次,其覆盖标准无法发现判定中逻辑运算的错误;

    判定覆盖是指选择足够的测试用例,使得运行这些测试用例时,每个判定的所有可能结果至少出现一次,但若程序中的判定是有几个条件联合构成时,它未必能发现每个条件的错误;

    条件覆盖是指选择足够的测试用例,使得运行这些测试用例时,判定中每个条件的所有可能结果至少出现一次,但未必能覆盖全部分支;

    判定/条件覆盖是使判定中每个条件的所有可能结果至少出现一次,并且每个判定本身的所有可能结果也至少出现一次;

    条件组合覆盖是使每个判定中条件结果的所有可能组合至少出现一次,因此判定本身的所有可能解说也至少出现一次,同时也是每个条件的所有可能结果至少出现一次;

    路径覆盖是每条可能执行到的路径至少执行一次;

    其中语句覆盖是一种最弱的覆盖,

    判定覆盖和条件覆盖比语句覆盖强,满足判定/条件覆盖标准的测试用例一定也满足判定覆盖、条件覆盖和语句覆盖,

    路径覆盖也是一种比较强的覆盖,但未必考虑判定条件结果的组合,并不能代替条件覆盖和条件组合覆盖。

    条件组合覆盖是除路径覆盖外最强的

    展开全文
  • 1语句覆盖 每个可执行语句都走一遍即可,即测试用例要覆盖所有的语句(来源:软件开发的技术基础) 2判定覆盖(分支覆盖) 针对判断语句,在设定案例的时候,要设定TrueFalse的两种案例;与语句覆盖不同的是...

    文章转自:https://blog.csdn.net/virus2014/article/details/51217026

    更新时间: 2019.10.22 13:06

    1语句覆盖

    每个可执行语句都走一遍即可,即测试用例要覆盖所有的语句(来源:软件开发的技术基础)

     

    2判定覆盖(分支覆盖)

     针对判断语句,在设定案例的时候,要设定True和False的两种案例;与语句覆盖不同的是增加了False的情况

    3条件覆盖

    针对判断语句里面案例的取值都要去一次,不考虑条件的取值

    另注:条件覆盖保证判断中的每个条件都被覆盖(来源:软件开发的技术基础)

    4判定/条件覆盖

    判定覆盖各条件覆盖交叉,针对于判定中的条件取值 

    5组合覆盖

    判定-条件覆盖的加强版 

    6路径覆盖

     
     

    展开全文
  • 最近在复习软件测试的考试,每次...根据覆盖目标的不同覆盖源程序语句的详尽程度,逻辑覆盖又可分为:语句覆盖,判定覆盖,条件覆盖,条件/判定覆盖,条件组合覆盖,路径覆盖 这里以一个题目引入: if (a&gt;...
  • 语句覆盖:所有的“语句”都要覆盖一遍判定覆盖:包含语句覆盖,每个判断T、F各一次条件覆盖:包含语句覆盖,每个条件T、F各一次判定条件覆盖:包含判定覆盖、条件覆盖条件组合覆盖:每个条件的每种组合路径:所有...
  • 1、语句覆盖是指选择足够的测试用例,使得运行这些测试用例时,被测程序的每一个语句至少执行一次,其覆盖标准无法发现判定中逻辑运算的错误。 2、判定覆盖是指选择足够的测试用例,使得运行这些测试用例时,每个...
  • 白盒测试法的覆盖标准有逻辑覆盖、循环覆盖和基本路径测试。其中逻辑覆盖包括语句覆盖、判定覆盖、条件覆盖、判定/条件覆盖、条件组合覆盖和路径覆盖。六种覆盖标准发现错误的能力呈由弱到强的变化:
  • 举个例子吧 if A and B then Action1 if C or D then Action2 语句覆盖最弱,只需要让程序中的语句都执行一遍即可 。上例中只需设计测试用例使得A=true B=true C=true 即可。 分支覆盖又称判定覆盖:使得程序中每个...
  • #1 语句覆盖 每个可执行语句都走一遍,即测试用例要覆盖所有的语句 大白话:什么都不管,只是单纯的让所有语句都执行一次,不管语句执行几次,不管执行结果,只要他们都执行过。 #2 判定覆盖(分支覆盖) 针对判断...
  • 1语句覆盖 使所有的判断语句都能执行一次的条件案例,例如当判断语句事组合语句的时候,并且用or连接,只满足一个案例即可 2判定覆盖(分支覆盖) 针对判断语句,在设定案例的时候,要设定TrueFalse的两种...
  • 1语句覆盖 每个可执行语句都走一遍即可,即测试用例要覆盖所有的语句 2判定覆盖(分支覆盖) 针对判断语句,在设定案例的时候,要设定TrueFalse的两种案例;与语句覆盖不同的是增加了False的情况 3条件覆盖 ...
  • 判定/条件覆盖:同时满足判定覆盖和条件覆盖。 条件组合覆盖:每个判定中各条件的每一种组合至少出现一次。 路径覆盖:使程序中每一条可能的路径至少执行一次。 '假设有一个待测试的小程序,其Java源代码如下。...
  • 语句覆盖法 PAGE 4 [文档标题 语句覆盖法-说课稿 编号 ...语句覆盖法可以很直观地从源代码得到测试用例无须细分每条判定表达式 不过由于这种测试方法仅仅针对程序逻辑中显式存在的语句对于隐藏的条件和可能到达的隐式逻
  • 目录语句覆盖概念语句覆盖例子根据代码来写语句覆盖分支覆盖(条件覆盖)概念例子方法覆盖概念例子代码 语句覆盖 概念 “语句覆盖”是一个比较弱的测试标准,它的含义是:选择足够的测试用例,使得程序中每个语句...
  • 那么下面来谈谈语句覆盖法、判定覆盖法和条件覆盖法三种白盒测试方法。  1.语句覆盖法  使用语句覆盖法在进行测试时,设计出若干个测试用例,然后运行被测程序,使程序中的每个可执行语句至少执行一次。  有如...
  • 软件测试之逻辑覆盖: 覆盖方法 语句覆盖 判定覆盖(分支覆盖) ...条件覆盖和分支覆盖之间没有包含和被包含关系。 判定条件覆盖:条件覆盖和判定覆盖的混合。使得每一个判定中的子判定所有结果至少
  • 条件判定覆盖的定义: ...满足判定覆盖就一定能够满足语句覆盖,满足条件判定覆盖就一定能够满足判定覆盖,语句覆盖及其条件覆盖,所以,条件判定覆盖是语句覆盖条件覆盖、判定覆盖及条件判定覆盖中最全面的...
  • 详述白盒测试的逻辑覆盖的条件覆盖及其优缺点: ...判定覆盖要求的是满足判定的每个真值假值,而条件覆盖是要求满足每个判定中的每个条件的真值假值。 条件覆盖比判定覆盖增加了对判定中所有条件的测试,对...
  • 显然,满足“条件组合覆盖”的测试用例是一定满足语句覆盖、判定覆盖、条件覆盖和条件判定覆盖的。 条件覆盖率: 条件覆盖率=条件组合至少出现一次的数量/条件组合的总数 eg: 以上为例,案例代码中有判定两个(x>...
  • SQL Server导出建表语句和插入语句,包括当前数据库中已有的数据信息 1、找到要进行操作的表所在的数据库,右键-->任务-->生成脚本 2、首页是简介,可直接点击下一步 3、第二页是选择要生成脚本的...
  • 即Modified Condition/Decision Coverage,缩写为MC/DC。 其中判定是指决定if或者循环语句是否执行的那个逻辑表达式。 基本思路。...MC/DC效果多重条件覆盖效力相同,但是用例数显著减少。 ...
  • 白盒测试覆盖中的六种覆盖(语句覆盖、判定覆盖、条件覆盖、判定/条件覆盖、条件组合路径覆盖) 里面有例子
  • 简介 算法导论第四章介绍过使用分治法求最大子数组问题,其基本思想就是把一个数组分成三部分,a[0:n/2],a[n/2+1:n],a[j:k] (其中0<...白盒测试有语句覆盖、判定覆盖、条件覆盖、判定/条件...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 762
精华内容 304
关键字:

条件覆盖和语句覆盖