俺在忽悠某个技术领域的玩意儿之前,通常先要分析一下优缺点——这样才能调动大伙儿的积极性。所以,本系列第1帖先分析一下灰盒测试的优缺点。

  ★几个基本概念 
  首先,把一些基本概念,简单通俗地说一下。如果觉得俺解释得不够好,不够细,可以自己去查维基百科的词条:洋文的在“这里 ”,中文的词条在“这里 ”(可惜中文词条不够全,偏偏缺了“灰盒测试”这一节)。

  ◇黑盒测试
  通俗来说:黑盒测试不关注软件内部的实现细节。他仅仅把被测试的软件当成一个整体来处理,只关注软件的外在表现,不关注内部细节。典型的黑盒测试,就是光拿着鼠标操作一下用户界面,看看功能是否满足要求。

  ◇白盒测试
  白盒测试与黑盒测试相反,重点关注软件内部的实现细节(比如代码覆盖率等)。

  ◇灰盒测试
  如果你是从事开发或者测试的行当,应该已经听过黑盒测试与白盒测试这2个概念。但对灰盒测试,或许比较耳生。单纯从名称上来看,灰盒测试是介于黑盒测试与白盒测试之间的一种测试方式。
  这种测试方式,主要用于多模块构成的稍微复杂的软件系统。在灰盒测试中,重点关注软件系统的各个组成模块之间的互动。这里所说的"互动",包括模块之间的互相调用、数据传递、同步/互斥、等等。

  ◇灰盒测试与黑盒测试的区别
  如果某软件包含多个模块,当你使用黑盒测试时,你只要关心整个软件系统的边界,无需关心软件系统内部各个模块之间如何协作。而如果使用灰盒测试,你就需要关心模块与模块之间的交互。这是灰盒测试与黑盒测试的区别。

  ◇灰盒测试与白盒测试的区别
  但是,在灰盒测试中,你还是无需关心模块内部的实现细节。对于软件系统的内部 模块,灰盒测试依然把它当成一个黑盒来看待。而白盒测试则不同,还需要再深入地了解内部 模块的实现细节。所以,这是灰盒测试与黑盒测试的区别。

  ◇灰盒测试与单元测试的区别
  刚才看到有网友在评论中问到此问题,俺补充一下。
   首先,在进行单元测试时,需要写一些测试代码(行话叫“桩代码”,洋文叫stub)。通常测试代码和被测试代码通常是同种语言(比如Java的单元测试 通常也用Java来写),且测试代码和被测试代码的耦合很紧密。因此,单元测试通常由开发人员来完成的,测试人员的能力未必能胜任。
  其次,单元测试的颗粒度会更细(会细到类一级、函数一级),而灰盒测试仅仅到模块一级。

  ★相对于黑盒测试的优点 
  灰盒测试相对黑盒测试的优点,其实有不少,俺挑几个重要的来说说。

  ◇测试可以及早介入
  由于黑盒测试把整个软件系统当成一个整体来测试。如果系统的某个关键模块还没有完工,那测试人员就无法对整个系统进行测试,只好闲着没事干。而灰盒测试是针对模块的边界进行,模块开发完一个就测试一个。

  ◇有助于测试人员理解系统结构
  为了进行灰盒测试,测试人员首先要熟悉内部模块之间的协作机制。在熟悉的过程中,“顺便”也就对整个系统(及其结构)有一个初步的、宏观的认识。这有助于测试人员发现一些系统结构方面的Bug。
  而对于黑盒测试来说,由于测试人员不清楚软件系统的内部结构,难以发现一些结构性的缺陷。

  ◇有助于管理层了解真实的开发进度
  一些复杂的大系统,经常会发生开发进度失控的情况。因为很多开发人员有报喜不报忧的倾向。当某个开发人员号称自己的工作已经完成了90%,往往意味着他/她还要花同样多的时间来完成剩下的10%。这导致负责项目管理的人,无法了解开发的真实进度。
  由于灰盒测试针对对每一个模块进行,而且测试人员会从一个客观的角度来反馈模块的完成情况,这非常有利于管理层了解整个系统的真实完成情况。

  ◇可以构造更好的测试用例
  如果仅仅用黑盒的方式测试系统的外部边界(通常是用户界面),有很多软件缺陷是不容易发现的。俺分别以B/S系统和C/S系统来举例。
   假设开发一个复杂的(Windows环境下的)C/S软件。那么,这个软件通常不会仅仅只有一个EXE文件。它可能会有若干个EXE文件以及若干个 DLL文件。假如某个DLL提供的导出函数,没有按照约定对输入参数进行有效性判断(比如指针是否为空),那你用黑盒测试的方式,难以暴露出这种缺陷。而 灰盒测试就容易发现此类问题(具体如何发现,后续的帖子会细说)。
  假如你开发的是一个Web应用系统,那么,这种系统的服务端多半会提供若干 个Web接口用于被客户端调用。假如某个Web接口存在安全性问题/并发性问题/健壮性问题/XX问题,你单纯用黑盒测试的手段,同样难以发现,而灰盒测 试就可以搞定(灰盒测试是如何搞定的,后续帖子会细说)。

  ◇利于提升测试人员能力
  很多公司搞的黑盒测试,就是让测试人员用鼠标(键盘都难得用)操作用户界面。在这种的环境里,测试人员干的活,很多都是重复性的体力劳动,技术能力难以得到提高。
  而如果搞灰盒测试,测试人员就需要多懂一点技术背景知识,必要时还得写点测试脚本,对测试人员的能力提升很有好处。

  ★相对于白盒测试的好处 
  灰盒测试相对白盒测试的好处,比较容易概括。简单来说,就是白盒测试较费钱(研发成本较高)。这多出来的研发成本,体现在如下几个方面。

  ◇首先,招聘成本较高
  在人才市场上,100个应聘的测试人员中,未必能够找到一个合适的白盒测试人员。至少从俺及周围同事的面试经历来看,难得碰到具备白盒测试能力的人。所以,你可能要花很长时间才能找到合适的人,时间成本浪费掉了。

  ◇其次,培训成本较高
  可能有同学会说,招不到就内部培养呗。这个说起来容易,但是培训也是有成本的。而且周期还不短,同样要耗费时间成本。

  ◇再其次,人力成本较高
  物以稀为贵是一条普遍的经济学规律。由于能搞白盒测试的家伙是稀有动物,你自然不能给他/她开太低的薪水。否则人家待不了多久就跑路了。薪水开得高了,人力成本自然也就提高了。

  ★其它的一些好处 
  前面拿灰盒测试分别跟黑盒/白盒进行了对比,列举了一些优点。还有另外一些优点,和黑盒/白盒没啥关系,单独列在这里。

  ◇顺便强化开发文档
  对于一个复杂的软件系统,模块之间的接口是很重要的,因此捏,接口文档也是很重要滴。而开发人员不爱写文档/不爱更新文档,(在软件业内)已经是臭名昭著了。很多软件开发到后期,模块之间的接口文档要么没有,要么和代码实现严重脱节。
  但是,如果引入测试人员对模块之间的接口进行测试,就可以有效防止此种弊端。因为测试人员在测试前,首先要看模块间的接口文档,然后再根据接口文档设计测试用例,最后再执行用例。因此,一旦接口文档和代码实现不符,立马就露馅了。

  ◇顺便搞搞自动化
  灰盒测试如果落实到位,还可以跟自动化测试相结合。从此可以大大提升测试的效率,进而大大提升软件的质量。(如何进行自动化的灰盒测试,后面的帖子会细谈)

  ★灰盒测试有啥缺点? 
  当然,凡事都有优点和缺点,灰盒测试自然也不例外。下面列举它的主要缺点。

  ◇不适用于简单的系统
  所谓的简单系统,就是简单到总共只有一个模块。由于灰盒测试关注于系统内部模块之间的交互。如果某个系统简单到只有一个模块,那就没必要进行灰盒测试了。

  ◇对测试人员的要求比黑盒测试高
  从上面的介绍来看,灰盒测试要求测试人员清楚系统内部由哪些模块构成,模块之间如何协作。因此,对测试的要求就提高了。因此,会带来一定的培训成本。不过捏,依照俺的经验,培训难度不大。稍微有点基础的测试人员,都可以在短期培训之后胜任。

  ◇不如白盒测试深入
  显然,灰盒不如白盒那么深入。不过捏,考虑到灰盒测试相比白盒测试有显著的成本优势,该缺点不是太明显。

  ★总结 
  总而言之,言而总之,灰盒测试是一个很不错的东东,其优点明显而缺点容易克服。另外,俺前后在两家公司的研发部门推行过,效果不错的说。大伙儿值得去尝试一下。今天光说了优缺点对比,在管理层面和技术层面,具体该如何落实捏?请看下一个帖子。

转载于:https://www.cnblogs.com/cwfsoft/archive/2010/12/04/1896199.html

如何开展灰盒测试[1]:灰盒测试优缺点分析相关推荐

  1. JWT 身份认证优缺点分析以及常见问题解决方案

    JWT 身份认证优缺点分析以及常见问题解决方案 参考文章: (1)JWT 身份认证优缺点分析以及常见问题解决方案 (2)https://www.cnblogs.com/idoljames/p/1169 ...

  2. 背景建模--Vibe 算法优缺点分析

    背景建模--Vibe 算法优缺点分析 一.Vibe 算法的优点 Vibe背景建模为运动目标检测研究邻域开拓了新思路,是一种新颖.快速及有效的运动目标检测算法.其优点有以下两点: 1.思想简单,易于实现 ...

  3. 【Android Protobuf 序列化】Protobuf 简介 ( Protobuf 项目简介 | Protobuf 优缺点分析 )

    文章目录 一.Protobuf 简介 二.Protobuf 优缺点分析 1.Protobuf 优点 2.Protobuf 缺点 三.参考资料 一.Protobuf 简介 Protobuf 是 Goog ...

  4. Linux桌面环境介绍以及优缺点分析

    1. KDE 桌面系统 KDE 是 K Desktop Environment 的缩写,中文译为"K桌面环境". KDE 是基于大名鼎鼎的 Qt 的,最初于 1996 年作为开源项 ...

  5. 氨氮吹脱法脱与php有关系吗,吹脱法处理氨氮废水的原理及优缺点分析

    原标题:吹脱法处理氨氮废水的原理及优缺点分析 利用空气通过废水时与水中溶解气体发生氧化反应,使水中溶解性挥发物质由液相转入气相,并进一步吹脱分离的水处理方法.一般可分为人工与自然吹脱,漓源环保带您简单 ...

  6. 最大熵学习笔记(六)优缺点分析

    生活中我们经常听到人们说"不要把鸡蛋放到一个篮子里",这样可以降低风险.深究一下,这是为什么呢?其实,这里边包含了所谓的最大熵原理(The Maximum Entropy Prin ...

  7. DataURL:实现原理及优缺点分析

    Data URL基本原理 Data URL给了我们一种很巧妙的将图片"嵌入"到HTML中的方法.跟传统的用img 标记将服务器上的图片引用到页面中的方式不一样,在Data URL协 ...

  8. java 设计模式 优缺点_java设计模式2:原型模式(机制\优缺点分析\使用场景)...

    1. 原型模式实现机制 原型模式在设计模式中相对比较简单,它直接通过实现 Cloneable接口,再重写 clone()方法返回想要的对象就OK 了. 一起来看下代码 : public class P ...

  9. CSS、JavaScript和Ajax实现图片预加载的三大方法及优缺点分析

    预加载图片是提高用户体验的一个很好方法.图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度.这对图片画 廊及图片占据很大比例的网站来说十分有利,它保证了图片快速.无缝地发 ...

  10. 前端埋点方法解析及优缺点分析

    1.文档说明 本文档是对前端埋点方案的梳理,整个文档会对现在主流方向的前端埋点方案进行分析整理.意在帮助产品经理和开发人员了解用户现实使用需求,为后期改进产品提供重要基础指标,优化用户体验的依据.文档 ...

最新文章

  1. C#基础笔记——命名规范
  2. Linux负载均衡--LVS(IPVS)
  3. jquery查找ul属性不是hide,jQuery的ul显示/隐藏功能
  4. HP的“高端”磁带库!
  5. 工具:帆软FineBI使用指南
  6. pwnable tw Starbound writeup
  7. 产品如何取得WFA的WiFi认证(二)成为WFA会员
  8. AprilTag: A robust and flexible visual fiducial system论文解读
  9. H5移动端前置摄像头成像方向错误,横屏方向错误
  10. 创新实训【12】——热词查询功能
  11. 网络划分与寻址三要素: IP地址、子网掩码和地址分类
  12. Proteus中七段数码管引脚说明
  13. Google优化排名方法
  14. 奢侈品行业数字化也要保持优雅
  15. 今晚,为梅西和莫德里奇熬夜!这个CV模型,让你猜球必赢
  16. 防灾科技学院的计算机如何,防灾科技学院最好的专业是什么
  17. precision scale
  18. 让你聪明10倍的哈佛学习力,颠覆脑力,做情智双高的“少数派”!
  19. jmeter参数化不起效果
  20. mac 命令行自动安装软件

热门文章

  1. Java_斐波那契数列_兔子生兔子算法
  2. 浅谈严格模式和混杂模式
  3. mybatis报错invalid types () or values ()解决方法
  4. Codevs 1010 过河卒 2002年NOIP全国联赛普及组
  5. 2012 Multi-University Training Contest 3
  6. android 适合mvp模式,Android中的MVP:如何使Presenter层系统化?
  7. iOS连接linux服务器用什么,iOS实现通过SSH2协议链接Linux服务器,并执行相关指令...
  8. mysql数据库的环境搭建_数据库学习(一)MySql环境搭建
  9. python怎么和sql一起用_自己写的Python数据库连接类和sql语句拼接方法
  10. linux eclipse下qt开发环境搭建,Qt Eclipse开发环境的部署 上篇