16. 覆盖边界值确保参数边界值均被覆盖. 对于数字, 测试负数, 0, 正数, 最小值, 最大值, NaN (非数字), 无穷大等. 对于字符串, 测试空字符串, 单字符, 非 ASCII 字符串, 多字节字符串等. 对于集合类型, 测试空, 1, 第一个, 最后一个等. 对于日期, 测试 1月1号, 2月29号, 12月31号等. 被测试的类本身也会暗示一些特定情况下的边界值. 基本要点是尽可能彻底的测试这些边界值, 因为它们都是主要 "疑犯".

17. 提供一个随机值生成器当边界值都覆盖了, 另一个能进一步改善测试覆盖率的简单方法就是生成随机参数, 这样每次执行测试都会有不同的输入.想要做到这点, 需要提供一个用来生成基本类型 (如: 浮点数, 整型, 字符串, 日期等) 随机值的工具类. 生成器应该覆盖各种类型的所有取值范围.如果测试时间比较短, 可以考虑再裹上一层循环, 覆盖尽可能多的输入组合. 下面的例子是验证两次转换 little endian 和 big endian 字节序后是否返回原值. 由于测试过程很快, 可以让它跑上个一百万次.void testByteSwapper(){ for (int i = 0; i < 1000000; i++) { double v0 = Random.getDouble(); double v1 = ByteSwapper.swap(v0); double v2 = ByteSwapper.swap(v1); assertEquals(v0, v2); }}

18. 每个特性只测一次在测试模式下, 有时会情不自禁的滥用断言. 这种做法会导致维护更困难, 需要极力避免. 仅对测试方法名指示的特性进行明确测试.因为对于一般性代码而言, 保证测试代码尽可能少是一个重要目标.

19. 使用显式断言应该总是优先使用 assertEquals(a, b) 而不是 assertTrue(a == b), 因为前者会给出为何导致测试失败的更有意义的信息. 在事先不确定输入值的情况下, 这条规则尤为重要, 比如之前使用随机参数值组合的例子.

20. 提供反向测试反向测试是指刻意编写问题代码, 来验证鲁棒性和能否正确的处理错误.假设如下方法的参数如果传进去的是负数, 会立马抛出异常:void setLength(double length) throws IllegalArgumentExcepti可以用下面的方法来测试这个特例是否被正确处理:try { setLength(-1.0); fail(); // If we get here, something went wrong}catch (IllegalArgumentException exception) { // If we get here, all is fine}

21. 代码设计时谨记测试编写和维护单元测试的代价是很高的, 减少代码中的公有接口和循环复杂度是降低成本, 使高覆盖率测试代码更易于编写和维护的有效方法.一些建议:使类成员常量化, 在构造函数中进行初始化. 减少 setter 方法的数量.限制过度使用继承和公有虚函数.通过使用友元类 (C++) 或包作用域 (Java) 来减少公有接口.避免不必要的逻辑分支.在逻辑分支中编写尽可能少的代码.在公有和私有接口中尽量多用异常和断言验证参数参数的有效性.限制使用快捷函数. 对于黑箱而言, 所有方法都必须一视同仁的进行测试. 考虑以下简短的例子:public void scale(double x0, double y0, double scaleFactor){ // scaling logic}public void scale(double x0, double y0){ scale(x0, y0, 1.0);}删除后者可以简化测试, 但用户代码的工作量也将略微增加.

22. 不要访问预定的外部资源单元测试代码不应该假定外部的执行环境, 以便在任何时候/任何地方都能执行. 为了向测试提供必需的资源, 这些资源应该由测试本身提供.比如一个解析某类型文件的类, 可以把文件内容嵌入到测试代码里, 在测试的时候写入到临时文件, 测试结束再删除, 而不是从预定的地址直接读取.

23. 权衡测试成本不写单元测试的代价很高, 但是写单元测试的代价同样很高. 要在这两者之间做适当的权衡, 如果用执行覆盖率来衡量, 业界标准通常在 80% 左右.很典型的, 读写外部资源的错误处理和异常处理就很难达到百分百的执行覆盖率. 模拟数据库在事务处理到一半时发生故障并不是办不到, 但相对于进行大范围的代码审查, 代价可能太大了.

24. 合理安排测试优先次序单元测试是典型的自底向上过程, 如果没有足够的资源测试一个系统的所有模块, 就应该先把重点放在较底层的模块.

25. 为测试失败做好准备考虑下面的这个例子:Handle handle = manager.getHandle();assertNotNull(handle);String handleName = handle.getName();assertEquals(handleName, "handle-01");如果第一个断言失败, 紧接其后的语句会导致代码崩溃, 剩下的测试都将不被执行. 任何时候都要为测试失败做好准备, 避免单个失败的测试项中断整个测试套件的执行. 上面的例子可以重写成:Handle handle = manager.getHandle();assertNotNull(handle);if (handle == null) return;String handleName = handle.getName();assertEquals(handleName, "handle-01");

26. 写测试用例重现 bug每上报一个 bug, 都要写一个测试用例来重现这个 bug (即无法通过测试), 并用它作为成功修正代码的标准.

27. 了解局限单元测试永远无法证明代码的正确性一个跑失败的测试可能表明代码有错误, 但一个跑成功的测试什么也证明不了.单元测试最有效的应用场合是验证和, 以及 回归测试: 当新功能增加和代码进行重构的同时,会不会影响到旧功能的正确性.

22/2<12

软件测试输入准则,单元测试准则相关推荐

  1. 软件测试系列之单元测试 (转载)

    软件测试系列之单元测试   2009-05-26 作者:Delores 来源:Delores的blog   1 基本理论 整理资料时发现以前给兄弟们灌输的单元测试的一些基本知识,放在这里供大家参考.里 ...

  2. 软件测试系列之单元测试(1 基本理论)

    软件测试系列之单元测试(1 基本理论) 整理资料时发现以前给兄弟们灌输的单元测试的一些基本知识,放在这里供大家参考.里面参考了网上很多朋友的资料,这里没一一列出,一并谢过.ppt转的,比较乱,ppt已 ...

  3. 电子量产工具:输入系统-输入管理单元测试

    软件总框图: 输入管理单元测试 添加input_test.c,内容如下 #include <sys/mman.h> #include <sys/types.h> #includ ...

  4. 运筹学知识:决策分析技术-乐观准则,悲观准则,后悔准则

    运筹学知识:决策分析技术-乐观准则,悲观准则,后悔准则 最大最大(max-max)准则  最大最大准则也称乐观准则,它找出每种行动的最好结果,再从最好结果中找一个更好的做为选择:  u(Ai*) = ...

  5. Soft:软件开发的简介(敏捷开发等6大软件开发模式)、软件测试的简介(单元测试/集成测试/系统测试/验收测试/回归测试、黑白灰功能测试、DEV等四套环境)、运维的简介之详细攻略

    Soft:软件开发的简介(敏捷开发等6大软件开发模式).软件测试的简介(单元测试/集成测试/系统测试/验收测试/回归测试.黑白灰功能测试.DEV等四套环境).运维的简介之详细攻略 目录 1.软件开发( ...

  6. 芝麻翻译软件测试,细数35个单元测试准则 “Hello, world!”

    1.保持单元测试小巧.快速 理论上,任何代码提交前都应该完整跑一遍全部测试套件.保持测试代码执行符合预期,这样可以缩短迭代开发周期.程序员 2.单元测试应该是全自动/非交互式的 测试套件一般是按期执行 ...

  7. 软件测试缺陷等级划分准则

    戳:软件测试之对BUG进行错误类型划分

  8. 【软件测试】Junit单元测试

    文章目录 前言 一.单元测试 1.单元测试是什么? 2.为什么需要单元测试? 二.Junit 1.什么是junit 2.Junit概念--断言 3.Junit的简单使用 ①导入依赖 ②编写测试用例 4 ...

  9. libreoffice_利用Excel或LibreOffice的业务输入进行单元测试约束

    libreoffice 业务专家向我们(开发人员)解释业务限制. 但是,如何确保我们正确理解它们呢? 或更糟糕的是,一旦约束条件正式化,我们如何测试他们之间是否同意? 好吧,有一种很棒的方法可以做到: ...

  10. 利用Excel或LibreOffice的业务输入进行单元测试约束

    业务专家向我们(开发人员)解释业务限制. 但是,如何确保我们正确理解它们呢? 或更糟糕的是,一旦约束条件正式化,我们如何测试他们之间是否同意? 好吧,有一种很棒的方法可以做到这一点:由*.xlsx数据 ...

最新文章

  1. 【jQuery】用jQuery给文本框添加只读属性【readOnly】
  2. k8s Service的类型和实现流程图解
  3. maven 配置文件 settings.xml
  4. 四天学会Mybatis
  5. 从0开始安卓开发之路_Android Studio安装包
  6. mysql内部代码的优缺点
  7. java/php/net/python基于Java的校园一卡通管理系统
  8. word vba设置表格样式
  9. 【PAT刷题甲级】部分笔记1065-1155~(下)
  10. Java 开通会员增加会员天数(LocalDateTime)
  11. 运算放大器---封装尺寸
  12. Vuex入门及进阶笔记
  13. 大厂面试通行证- Java基础
  14. 【AV1 编码器研究一】aomenc.exe命令行参数简析
  15. 如何简单的抓取网站数据
  16. MATLAB在线编辑网站及使用教程
  17. 【ASML】EUV光刻技术PPT
  18. Golang源码中xmm0寄存器
  19. three.js加载obj模型和材质
  20. jtitle=Reactions Weekly,2013MBA联考英语试卷(附答案) 2

热门文章

  1. 常用街机模拟器机台设置[更新中](新手看)
  2. 「股票」东方财富网公式-缩量
  3. 2022年《社区护理学》 试题及答案
  4. 摩天轮社区_摩天轮:基于真实地理位置游戏
  5. java公路赛_为什么Java公路车总被黑?
  6. 类和对象6:相关内置函数
  7. justinmind夜话:数据母板系列视频教程之原型设计二十一条军规
  8. 以太坊源码分析(37)eth以太坊协议分析
  9. 一个人赶着鸭子去每个村庄卖,每经过一个村子卖去所赶鸭子的一半又一只。这样他经过了七个村子后还剩两只鸭子,问他出发时共赶多少只鸭子?经过每个村子卖出多少只鸭子以及角谷定理的计算
  10. Protected multilib versions XXX