集成测试

1.什么是集成测试

  集成测试是指在单元测试的基础上,将所有模块按照设计要求组装成为子系统或系统,进行测试。

  集成测试最简单的形式是:把两个已经测试过的单元组合成一个组件,测试它们之间的接口。从这一层意义上讲,组件是指多个单元的集成聚合。在现实方案中,许多单元组合成组件,而这些组件又聚合为程序的更大部分。方法是测试片段的组合,并最终扩展成进程,将模块与其他组的模块一起测试。最后,将构成进程的所有模块一起测试。此外,如果程序由多个进程组成,应该成对测试它们,而不是同时测试所有进程。

  集成测试测试组合单元时出现的问题。通过使用要求在组合单元前测试每个单元并确保每个单元的生存能力测试计划,可以知道在组合单元时所发现的任何错误很可能与单元之间的接口有关。这种方法将可能发生的情况数量减少到更简单的分析级别。一个有效的集成测试有助于解决相关的软件与其它系统的兼容性和可操作性的问题。

  集成测试是在单元测试的基础上,测试在将所有的软件单元按照概要设计规格说明的要求组装成模块、子系统或系统的过程中各部分工作是否达到或实现相应技术指标及要求的活动。也就是说,在集成测试之前,单元测试应该已经完成,集成测试中所使用的对象应该是已经经过单元测试的软件单元。这一点很重要,因为如果不经过单元测试,那么集成测试的效果将会受到很大影响,并且会大幅增加软件单元代码纠错的代价。

  集成测试是单元测试的逻辑扩展。在现实方案中,集成是指多个单元的聚合,许多单元组合成模块,而这些模块又聚合成程序的更大部分,如分系统或系统。集成测试采用的方法是测试软件单元的组合能否正常工作,以及与其他组的模块能否集成起来工作。最后,还要测试构成系统的所有模块组合能否正常工作。集成测试所持的主要标准是《软件概要设计规格说明》,任何不符合该说明的程序模块行为都应该加以记载并上报。

  所有的软件项目都不能摆脱系统集成这个阶段。不管采用什么开发模式,具体的开发工作总得从一个一个的软件单元做起,软件单元只有经过集成才能形成一个有机的整体。具体的集成过程可能是显性的也可能是隐性的。只要有集成,总是会出现一些常见问题,工程实践中,几乎不存在软件单元组装过程中不出任何问题的情况。从表中可以看出,集成测试需要花费的时间远远超过单元测试,直接从单元测试过渡到系统测试是极不妥当的做法。

活动 输入 输出 参与角色和职责
制定集成测试计划 设计模型
设计模型
集成测试用例
测试过程
测试设计员负责设计集成测试用例和测试过程
实施集成测试 集成测试用例
测试过程
工作版本
测试脚本(可选)
测试过程(更新)
测试设计员负责编制测试脚本(可选),更新测试过程。
驱动程序或稳定桩 设计员负责设计驱动程序和装,实施员负责实施驱动程序和桩
执行集成测试 测试脚本(可选)
工作版本
测试结果 测试员负责执行测试并记录测试结果
评估集成测试 集成测试计划
测试结果
测试评估摘要 测试员负责会同及成员、编码员、设计员等有关人员(具体化)评估此次测试,并生成测试评估摘要。

2.集成测试的目标

  集成测试的目标是按照设计要求使用那些通过单元测试的构件来构造程序结构。单个模块具有高质量但不足以保证整个系统的质量。有许多隐蔽的失效是高质量模块间发生非预期交互而产生的。以下两种测试技术是用于集成测试:

  1、功能性测试。使用黑盒测试技术针对被测模块的接口规格说明进行测试。

  2、非功能性测试。对模块的性能或可靠性进行测试。

  另外,集成测试的必要性还在于一些模块虽然能够单独地工作,但并不能保证连接起来也能正常工作。程序在某些局部反映不出来的问题,有可能在全局上会暴露出来,影响功能的实现。此外,在某些开发模式中,如迭代式开发,设计和实现是迭代进行的。在这种情况下,集成测试的意义还在于它能间接地验证概要设计是否具有可行性。

3.集成测试应考虑问题

  1、在把各个模块连接起来的时候,穿越模块接口的数据是否会丢失;

  2、各个子功能组合起来,能否达到预期要求的父功能;

  3、一个模块的功能是否会对另一个模块的功能产生不利的影响;

  4、全局数据结构是否有问题;

  5、是采用何种系统组装方法来进行组装测试;

  6、组装测试过程中连接各个模块的顺序;

  7、模块代码编制和测试进度是否与组装测试的顺序一致;

  8、测试过程中是否需要专门的硬件设备;

  9、单个模块的误差积累起来,是否会放大,从而达到不可接受的程度。

  因此,单元测试后,有必要进行集成测试,发现并排除在模块连接中可能发生的上述问题,最终构成要求的软件子系统或系统。对子系统,集成测试也叫部件测试。

  任何合理地组织集成测试,即选择什么方式把模块组装起来形成一个可运行的系统,直接影响到模块测试用例的形式、所用测试工具的类型、模块编号和测试的次序、生成测试用例和调试的费用。通常,有两种不同的组装方式:一次性组装方式和增值式组装方式。

4.集成测试过程

  根据IEEE标准 集成测试划分为4个阶段:计划阶段,设计阶段,实现阶段,执行阶段(实施阶段)

5.集成测试的实施方案

  集成测试的实施方案有很多种,如自底向上集成测试、自顶向下集成测试、Big-Bang集成测试、三明治集成测试、核心集成测试、分层集成测试、基于使用的集成测试等。常见的有: