集成测试深度理解

    这两天在复习软件测试的考试,对于之前不大理解的集成测试有了新的理解。

    集成测试,也叫组装测试或者联合测试。在单元测试的基础上,将所有模块按照设计要求(如根据结构图)组装成为子系统或系统,进行集成测试。

    可以说,集成测试是处于系统测试和单元测试之间,承上启下的重要测试。

    具体方法有两个:

    自下向上集成

  对任何系统几乎都可以采用这一策略。该策略是从低层次的、相互之间依赖性最步的模块开始的,可以用驱动程序来测试这些模块。这种策略能用来逐步建立系统,或者首先并行地建立起子系统,然后集成为一个完整系统。这种集成可以从开发过程的早期就开始进行。当然,如果项目计划中模块提交也是采用自下而上的方式,那么采用这种方法就能够尽早检测出接口问题,而且这些接口问题也比较容易被隔离,因此解决起来成本就低。其主要缺点是需要使用许多驱动程序来执行这一策略,而且因为测试需要迭代,所以也是一种非常耗时的策略。

    自上向下集成

  这种策略由系统的控制结构来引导。控制结构按照自上向下的顺序开发,这也提供了从上层控制模块开始,自上而下集成模块的能力。对每一个新的层次,位于同一层次的相关模块被集成起来并得到测试。还不存在的模块角色可以用占位来实现。采用该集成策略的一个缺点是:如果需求发生了变化,变化对底层模块产生影响,从而也将导致上层模块需要更改。这可能导致需要(部分)重新开始集成以及测试过程。另一个缺点是用于测试每个集成步骤所必须用的占位数目很大。如果在早期从上层模块开始集成测试,即使采用占位来替代系统的主要部件。仍然可以观察到整个系统的概貌以及工作方式。

    举个例子:

  被测试段代码实现的功能是:如果a>b,则返回a,否则返回a/b

  被测试段代码由两个函数实现,分别是

  ---int  max (int a, int b, char *msg)

  ---void divide (int *a, int *b)

  divide函数实现a/b功能,max函数实现其他对应功能,并进行结果输出

  int  max (int a, int b, char *msg)

  {

  char dsp[20];      /*声明一个大小为20的char型数组*/

  if (a<0 || b<0)       /*如果a和b中有一个数不是正数*/

  return -1;             /*则直接返回*/

  if (a>b)                 /*如果a大于b,*/

  ;                  /*什么也不做*/

  else

  divide (&a, &b);

  sprintf (dsp, ”%s %d”,msg,a);

  printf (dsp);

  return  a;

  }

  void divide (int *a, int *b)

  {

  (*a)=(*a)/(*b);

  return ;

  }

  画出结构图为:

  集成测试操作步骤

  确定集成测试策略

  ---采用自底向上的测试策略

  确定集成测试粒度

  ---函数

  选定测试用例设计方法

  ---等价类划分、边界值等

  编写测试用例

  ---因为测试策略是自底向上,所以先测试divide( int *a, int *b)函数

  构造驱动(其中m和n是测试用例输入)

  int  test ( )

  {

  int a=m;

  int b=n;

  divide( &a, &b);

  }

  依次执行测试用例,完成测试

  

原文地址:https://www.cnblogs.com/qbcq/p/4457086.html