白盒测试

逻辑覆盖测试:

逻辑覆盖是以程序内部的逻辑结构为基础的设计测试用例的技术。它属白盒测试。白盒测试的测试方法有代码检查法、静态结构分析法、静态质量度量法、逻辑覆盖法、基本路径测试法、域测试、符号测试、Z路径覆盖、程序变异。白盒测试法的覆盖标准有逻辑覆盖、循环覆盖和基本路径测试。
  • 语句覆盖:语句覆盖又称行覆盖、段覆盖、基本块覆盖,常被称为“最弱的覆盖”,它只覆盖代码中的执行语句,却不考虑各种分支的组合等等。

  • 判定覆盖:设计若干个测试用例,要求每个判断都必须有“是”和“否”的结果,并且每条分支路径都必须至少遍历一次。(较强准则的覆盖)

  • 条件覆盖:条件覆盖是指选择足够的测试用例以确保将一个判断中的每个条件的所有可能的结果至少执行一次,因为,就如同判定覆盖的情况一样,这并不总是能让每条语句都执行到,因此作为对这条准则的补充就是对程序或子程序,包括 ON 单元的每一个入口点都至少调用一次。。(更强准则的覆盖)

  • 判定/条件覆盖:将一个判断中的每个条件的所有可能的结果至少执行一次,将每个判断的每个条件的所有可能的结果至少执行一次,将每个判断的所有可能的结果至少执行一次,将每个入口点都至少调用一次。

  • 多重条件覆盖:该准则要求编写足够多的测试用例,将每个判定中的所有可能的条件结果的组合,以及所有的入口点都至少执行一次。

黑盒测试

等价类划分:

  • 测试时,如果我们将程序的输入范围进行划分,将其划分为有限数量的等价类,这样就可以合理的假设测试每个等价类的代表性数据等同于测试该类的其他任何数据

  • 使用等价划分方法设计测试用例主要有两个步骤:

    (1)确定等价类

    (2)生成测试用例

边界值分析:

  • 考虑了边界条件的测试用例具有更高的测试回报率
  • 所谓边界条件,是指输入和输出等价类中那些恰好处于边界、或超过边界、或在边界以下的状态。

    (看了一下课本P32的例子,似懂非懂)

边界值分析和等价划分的一个弱点是未对输入条件的组合进行分析

因果图:

  • 因果图是一种形式语言,用自然语言描述的规格说明可以转换为因果图。

  • 下面附上一张基本的因果图符号:

      每个结点的值为 0 或为 1,0代表“不存在”状态,1 代表“存在”状态。identity 函数表示如果 a 等于 1,则b 也为 1,否则 b 为 0。not 函数表示如果 a 等于 1, 则 b 为 0,否则 b 为 1。  or 函数表示如果 a 或 b 或 c 等于 1,则 d 为 1,否则 d 为 0。and 函数表示如果 a 和 b 都等于 1,则 c 为 1,否则 c 为 0。 后两个函数(or 和 and)允许存在任意数量的输入。

  • 生成测试用例时采用的过程如下:

      1.将规格说明分解为可执行的片段。这是必须的步骤,因为因果图不善于处理较大的规格说明。
    
      2.确定规格说明中的因果关系。
    
      3.分析规格说明的语义内容,并将其转换为连接因果关系的布尔图。
    
      4.给图加上注解符号,说明由于语法或环境的限制而不能联系起来的“因”和“果”。
    
      5.通过仔细地跟踪图中的状态变化情况,将因果图转换成一个**有限项的判定表**。表中的每一列代表一个测试用例。
    
      6.将判定表中的列转换成测试用例。
    
    (`结合P48页的例子了解因果图,感觉将因果图转化为判定表是比较有难度的部分!)`

测试策略

一组合理的策略如下:

  1. 如果规格说明中包含输入条件组合的情况,应首先使用因果图分析方法。
  2. 在任何情况下都应使用边界值分析方法。应记住,这是对输入和输出边界进行的分析。边界值分析可以产生一系列补充的测试条件,但是,也正如“因果图分析”一节所述,多数甚至全部条件都可以被整合到因果图分析中。
  3. 应为输入和输出确定有效和无效等价类,在必要情况下对上面确认的测试用例进行补充。
  4. 使用错误猜测技术增加更多的测试用例。
  5. 针对上述测试用例集检查程序的逻辑结构。应使用判定覆盖、条件覆盖、判定/条件覆盖或多重条件覆盖准则(最后的一个最为完整)。如果覆盖准则未能被前四个步骤中确定的测试用例所满足,并且满足准则也并非不可能(由于程序的性质限制,某些条件的组合也许是不可能实现的),那么增加足够数量的测试用例,以使覆盖准则得到满足。

体会

本章中,主要还是了解了些概念性的内容。包括白盒测试的语句覆盖、判定覆盖、条件覆盖、判定/条件覆盖、多重条件覆盖;黑盒测试的等价类划分、边界值分析、因果图分析、错误猜测。看书的过程不是很细,包括书上的例子看完后也是似懂非懂的感觉。。。。

《the art of software testing》第四章 测试用例的设计的更多相关文章

  1. 《the art of software testing》 (1-2)章

    软件测试的心理学,重点是要认清: 测试时为发现错误而执行程序的过程 成功的测试:如果在测试某段程序时发现了错误,而且这些错误是可以修复的,就将这次合理设计并得到有效执行的测试称作是"成功的& ...

  2. 《The art of software testing》的一个例子

    这几天一直在看一本书,<The art of software testing>,里面有一个例子挺有感触地,写出来和大家分享一下: [问题] 从输入对话框中读取三个整数值,这三个整数值代表 ...

  3. 《the art of software testing》 第三章 人工测试

    在深入研究较为传统的计算机测试技术之前,要先进行"人工测试". 代码检查与走查是两种主要的人工测试方法. 代码检查与走查是对过去桌面检查过程(在提交测试前由程序员阅读自己程序的过程 ...

  4. 《the art of software testing》第六章

    更高级别的测试 模块测试的目的是发现程序模块与其接口规格说明之间的不一致 功能测试的目的是为了证明程序未能符合其外部规格说明 系统测试目的是为了证明软件产品与其初始目标不一致 功能测试,作者从三个方面 ...

  5. 《the art of software testing》第五章

    构建大型程序测试的第一个步骤:模块测试 测试用例的设计 在为模块测试设计测试用例时,需要两种信息:模块的规格说明和模块源代码: 模块测试总体上面向白盒测试: 模块测试的测试用例设计过程:使用一种或多种 ...

  6. [Python学习笔记][第五章Python函数设计与使用]

    2016/1/29学习内容 第四章 Python函数设计与使用 之前的几页忘记保存了 很伤心 变量作用域 -一个变量已在函数外定义,如果在函数内需要修改这个变量的值,并将这个赋值结果反映到函数之外,可 ...

  7. 软件测试software testing summarize

    软件测试(英语:software testing),描述一种用来促进鉴定软件的正确性.完整性.安全性和质量的过程.软件测试的经典定义是:在规定的条件下对程序进行操作,以发现程序错误,衡量软件质量,并对 ...

  8. Gradle 1.12用户指南翻译——第三十四章. JaCoCo 插件

    本文由CSDN博客万一博主翻译,其他章节的翻译请参见: http://blog.csdn.net/column/details/gradle-translation.html 翻译项目请关注Githu ...

  9. CentOS 7.4 初次手记:第四章 CentOS安全了解

    第四章 CentOS安全了解... 66 第一节 user.group.chmod. 66 I 10位文件属性... 66 II user/group增删改... 67 III user/group配 ...

随机推荐

  1. 7天学会HTML--HTML综述

    一周学会HTML 1.HTML是什么? HTML 指的是超文本标记语言 (Hyper Text Markup Language) 2.HTML发展历程 HTML版本从1.0到4.0不断升级,其版本的规 ...

  2. retful上传文件php的实现

    项目中要使用restful上传文件到服务器,一直不能成功,后生成相关串后在postman中上传成功,利用这个工具生成php curl的代码,后逐步比对产生以下代码. /**     * 上传文件    ...

  3. [转载]交换机STP协议

    注:之前做一个项目,测试部使用2个公司的交换机,H3C和H公司的,H公司的交换机是OEM H3C的交换机,正常来说两者使用没有区别. 但是使用中发现,如果设备的多个对外业务网口连接的交换机的聚合网口, ...

  4. UiAutomator viewer 在tools下启动、资源jar包在platforms下(如android22)

    1.UiAutomator viewer 在tools下启动. 2.资源jar包在platforms下(如android22):android.jar/ uiautomator.jar

  5. Python if-elif-else

    alien_color = ['green','yellow','red']for color in alien_color: if color == 'green': print 'alien_co ...

  6. 转载:利用UDEV服务解决RAC ASM存储设备名

    利用UDEV服务解决RAC ASM存储设备名 本文转载自Maclean Liu :http://www.askmaclean.com/archives/utilize-udev-resolve-11g ...

  7. 笔记:Tid设计思维

    Tid设计思维 2017年7月19日TiD大会创新设计论坛 一.     设计思维实践: 为什么他能觉察你看不到的机会 1.    原因一:[觉察]与[看] 他(们)能“觉察”你“看”不到的机会,他们 ...

  8. Populating Next Right Pointers in Each Node II ?

    void connect(TreeLinkNode *root) { if(root==NULL) return; if(root->left&&root->right) ...

  9. Java多线程-线程的调度(优先级)

    与线程休眠类似,线程的优先级仍然无法保障线程的执行次序.只不过,优先级高的线程获取CPU资源的概率较大,优先级低的并非没机会执行. 线程的优先级用1-10之间的整数表示,数值越大优先级越高,默认的优先 ...

  10. Redis搭建(二):主从复制

    一.引言 Redis有三种集群模式: 第一个就是主从模式 第二种“哨兵”模式,在Redis 2.6版本开始提供,2.8版本稳定 第三种是Cluster集群模式,在Redis 3.x以后的版本才增加进来 ...