1.白盒、灰盒、黑盒测试
软件测试的两种极端情况:
已知产品的需求规格,但不知道其内部实现,可以进行测试证明每个需求是否实现。(白盒测试)
已知产品的内部实现过程,可以通过测试证明每种内部操作是否符合设计规格的要求,所有内部成分是否已经过检查。(黑盒测试)
什么是白盒测试?
白盒测试是依据被测软件分析程序内部构造,并根据内部构造设计用例,来对内部控制流程进行测试,可完全不顾程序的整体功能实现情况。
白盒测试是基于程序结构的逻辑驱动测试。
白盒测试又可以被称为玻璃盒测试、透明盒测试、开放盒测试、结构化测试、逻辑驱动测试。
什么是黑盒测试?
黑盒测试把被测对象看成一个黑盒,只考虑其整体特性,不考虑其内部具体实现。
黑盒测试针对的被测对象可以是一个系统、一个子系统、一个模块、一个子模块、一个函数等。
黑盒测试又可以被称为基于规格的测试。
为什么进行白盒测试
白盒测试一般在测试前期进行,通过达到一定的逻辑覆盖率指标,使得软件内部逻辑控制结构上的问题能基本得到消除。
白盒测试能保证内部逻辑结构达到一定的覆盖程度,能够给予软件代码质量更大的保证。
白盒测试发现问题后解决问题的成本较低。
黑盒测试的特点
对于更大的代码单元来说(子系统甚至系统级)比白盒测试效率要高;
测试人员不需要了解实现的细节,包括特定的编程语言;
从用户的视角进行测试,很容易被大家理解和接受;
有助于暴露任何规格不一致或有歧义的问题。
灰盒测试
根据利用的被测对象信息的不同,会采用不同的方法进行测试。
利用被测对象的整体特性信息,采用黑盒测试方法。
利用被测对象的内部具体实现信息,采用白盒测试方法。
如果既利用被测对象的整体特性信息,又利用被测对象的内部具体实现信息,采用的就是灰盒测试方法。两种信息占的比例不同,相应的灰度就不同。完全是整体特性信息,就是黑盒测试,完全是内部具体实现信息,就是白盒测试。
典型的灰盒测试比如集成测试和系统测试时借助log信息。
2.静态测试和动态测试
静态测试:不运行被测试的软件,而采用其他手段和技术对被测软件进行检查的一种测试技术。例如:代码走读、文档评审、程序分析等都是静态测试的范畴。(静态分析技术)
动态测试:按照预先设计好的数据和步骤去运行被测软件,从而对系统进行检测的一种技术。(动态分析技术)
静态分析技术
定义:静态分析是一种不通过执行程序而分析程序执行的技术
功能:检查软件的表示和描述是否一致,没有冲突或者没有歧义,它瞄准的是纠正软件系统在描述、表示和规格上的错误,因此是任何进一步测试执行的前提。
主要有三种不同的程序测试可能性:
考虑程序是否满足编码规则,语法上是否有一致性和完整性;
考虑文档是否规范、准确、便于查阅;
考虑程序和文档间的一致性。
3.人工测试和自动化测试
人工测试:测试活动(如评审、测试设计、测试执行等)由人来完成,狭义上是指测试执行由人工完成,这是最基本的测试形式。
自动化测试:一般是指通过计算机模拟人的测试行为,替代人的测试活动,狭义上是指测试执行由计算机来完成。
自动化测试的定义:
对程序新版本运行前一版本执行的测试,提高回归测试效率。
可以运行更多更频繁的测试,比如冒烟测试。
可以执行手工测试困难或不可能做的测试,比如大量的重复操作或者集成测试。
更好地利用资源,比如测试仪器或者被测对象。
自动化测试的限制:
不能取代手工测试,自动化测试只能提高测试效率,不能提高测试有效性,即不可能发现更多缺陷。
手工测试比自动测试发现的缺陷更多。
对测试设计依赖性极大,测试设计的不好会遗漏问题。
自动化测试对软件开发具有很大的依赖性,开发上出现变更可能导致前面的自动化测试完全失效。
工具本身并不具备想象力,工具不具有智能。