关于白盒测试的一些想法

简介:
 近一年多一直在从事服务端的测试工作,虽然之前也做过两年,但融合了自动化测试功能测试以及单元测试,所以精力有限,接触到的白盒测试比较碎也比较浅。近期项目进入了调整期,有时间整理下对于项目测试中的代码测试一些感触。 顺便对未来的工作方向和计划做好准备工作。
  2014年可能需要继续负责服务端项目测试工作,但到底白盒测试和功能测试以及模块测试,自动化测试之间应该如何进行抉择,如何进行搭配,相互补充,来达到项目高质,高效的目的呢? 站在整个项目的角度,从以下几个维度对白盒测试进行了一些思考:
  1.   什么样的项目可以考虑做白盒测试
  1.1.  大项目,周期比较长(因为需要前期介入review RD代码)
  1.2.  功能测试不放心的项目,接口比较明确,重要函数做的修改
  1.3.  对整个项目了解较清晰,时间要求较低
  1.4.  新项目
  1.5.  逻辑较复杂的模块
  1.6.  通用类的
  1.7.  异步的、多线程的程序
  1.8.  函数用到的外部数据较多的不适合做,构造起来非常复杂,如大量的信令、词典等
  2.  如何结合白盒测试和其它测试方法
  首先,需要根据项目特点,比如项目周期,项目难度等来确定测试方法。
  然后,如果满足做白盒测试的条件,则需要先确定白盒测试处于项目测试中的什么阶段,如果是迭代或优化类的项目,建议进行分层测试,重点对更新的代码进行白盒测试,其它的进行传统的自动化或手工回归测试。如果是周期比较长的全新项目,可以考虑在RD编码阶段介入,了解接口和底层内部函数构造,为白盒测试做准备。        为了避免白盒测试和功能测试的交叉工作量,可以底层库用白盒测试,上层功能测试用功能测试,在功能测试上就不再关注底层的测试,可借助分层测试思想。
  3.  如何降低白盒测试成本
  不管从技术还是从周期上,白盒测试成本比较大,所以站在高效和简易的基础上,尽量借助工具来尽量减少白盒测试范围,比如可以借助:
  3.1.   手工测试+代码覆盖率测试来覆盖一部分代码
  3.2.   C代码可以用gdb(其它语言也有)来构造一些比较难引入的上层变量,再结合代码覆盖率来做
  3.3.   单测工具,比如cppunit,gtest等来做接口测试
  3.4.   其它
  我们之前的做法是将模块测试做成自动化CASE,然后新版本来后,进行自动化测试回归,并结合代码覆盖率来出一份覆盖报告(从分支和代码行两个维度),然后再对新升级的代码进行review,并拓展用例来覆盖,如果功能测试实在无法模拟,会采取gtest,最后仍不好模拟会采用gdb挂载的方式
  4、 白盒测试收益和风险是什么
  4.1. 功能测试无法深入到底层的测试上,白盒测试可以
  4.2. 投入成本较大,收益较小
  4.3. 通过白盒测试只能发现函数级的错误,较难发现函数接口之间的错误
  4.4.  时间会增加,覆盖率会增加
  4.5.  可促进rd的单元测试做的更充分
  4.6.  短期收益不明显,长远会有收益
  5、白盒测试方法
  5.1. 最基层的函数做详细的测试(倾向于功能),策略较复杂的做详细测试(倾向于逻辑),通过自己写5.2. 程序去调用被测函数,外层的通过GDB的方式去测试
  5.3. 自己写驱动去调用被测程序或构造上下层来验证被测程序
  5.5. 通过程序包装被测程序,通过多线程的方式去实现多个动作之间的交互
  5.6. cppunit去做,但调用关系较复杂的测试很难去实现,支持case的管理、验证
  5.7. 可借助gtest去实现,扩展为和c++test类似的功能
版权声明:本文出自 800716 的51Testing软件测试博客:http://www.51testing.com/?359684
原创作品,转载时请务必以超链接形式标明本文原始出处、作者信息和本声明,否则将追究法律责任。


最新内容请见作者的GitHub页:http://qaseven.github.io/
相关文章
|
7月前
|
安全 测试技术
白盒测试的总结
白盒测试的总结
68 0
|
9月前
|
Java 测试技术 数据库连接
软件测试实验二 白盒测试
软件测试实验二 白盒测试
138 0
|
13天前
|
测试技术
深入白盒测试:静态分析与动态分析的协同效应
【4月更文挑战第12天】 在软件开发的质量控制过程中,白盒测试作为一种重要的测试手段,它通过检查内部结构、设计和实现细节来确保代码的正确性。本文探讨了白盒测试中的两大核心方法——静态分析和动态分析,并分析了两者结合使用时如何提高软件测试的效率和有效性。文章首先概述了白盒测试的基本概念,随后分别详细讨论了静态分析和动态分析的特点和应用场景,最后通过实例说明了如何将这两种分析方法有效整合,以发现更多潜在的缺陷,从而提升软件产品的质量。
|
16天前
|
安全 测试技术 持续交付
深入探索白盒测试:提升软件质量的关键步骤
【4月更文挑战第9天】在软件开发的生命周期中,确保代码的质量和性能至关重要。白盒测试,作为软件测试的一个核心分支,提供了一种通过检查内部结构、设计和逻辑来验证程序正确性的方法。本文将深入探讨白盒测试的原理、方法和最佳实践,旨在帮助开发者和测试工程师提高测试效率,从而确保软件产品的可靠性与稳定性。通过对不同白盒测试技术的比较分析,我们将揭示如何更有效地利用这些技术来发现和修复潜在的缺陷。
|
6月前
|
测试技术
黑盒测试、白盒测试、灰盒测试的区别和各自的目的
黑盒测试、白盒测试和灰盒测试是软件测试中常用的测试方法。它们的区别和各自的目的如下: 1. 黑盒测试(Black Box Testing): - 黑盒测试是一种功能性测试方法,使用者只关注输入和输出,不考虑内部结构和实现细节。 - 黑盒测试的目的是验证软件功能是否按照需求规格说明书的要求来执行。 - 测试人员不需要了解软件的内部逻辑和代码,只需关注输入和输出的正确性。 - 黑盒测试可通过设计测试用例,模拟用户使用软件的场景,以验证系统的正确性。 2. 白盒测试(White Box Testing): - 白盒测试是一种结构性测试方法,测试人员了解软件的内部结构
294 0
|
8月前
|
安全 测试技术
53【软件测试】软件测试有哪些方法?白盒测试有哪些方法?黑盒测试有哪些方法?
| **黑盒测试** | 测试人员不考虑内部代码结构,仅考虑输入和输出的测试方法。|
66 0
|
9月前
|
测试技术
黑盒白盒测试
黑盒白盒测试
|
11月前
|
SQL 存储 数据采集
软件测试之测试的分类(重点:黑盒测试、白盒测试、单元测试、集成测试、系统测试)
1. 按照测试对象进行划分 1)界面测试 2)可靠性测试 3)容错性测试 4)文档测试 5)兼容性测试 6)易用性测试 7)软件安装卸载的测试 8)安全测试 9)性能测试 10)内存泄漏测试 2. 按照是否查看代码划分 1)黑盒测试 2)白盒测试 3)灰盒测试 3. 按照开发阶段划分 1)单元测试(结合 V 模型) 2)集成测试 3)系统测试 4)验收测试 5)将上面四种测试方法同 V 模型的阶段进行对应 4. 按照测试实施组织划分 1)α 测试 2)β 测试 3)第三方测试 5. 按照是否运行进行划分 1)静态测试 2)动态测试 6. 按照是否手工划分 1)手工测试 2)自动化测试
805 0
|
测试技术 程序员 开发者
软件测试面试题:请试着比较一下黑盒测试、白盒测试、单元测试、集成测试、系统测试、验收测试的区别与联系?
软件测试面试题:请试着比较一下黑盒测试、白盒测试、单元测试、集成测试、系统测试、验收测试的区别与联系?
126 0
|
测试技术
实验一 白盒测试用例设计
实验一 白盒测试用例设计
581 0
实验一 白盒测试用例设计