• 软件测试技术
  • 软件测试博客
  • 软件测试视频
  • 开源软件测试技术
  • 软件测试论坛
  • 软件测试沙龙
  • 软件测试资料下载
  • 软件测试杂志
  • 软件测试人才招聘
    暂时没有公告

字号: | 推荐给好友 上一篇 | 下一篇

  浅论单元测试的内部输入问题

发布: 2009-12-17 10:12 | 作者: 不详 | 来源: 领测国际软件测试网采编 | 查看: 11次 | 进入软件测试论坛讨论

领测软件测试网

      //调用compare

  int Func(int r, int x)

  {

  int a1 = GetArea(r);

  int result = Compare(a1, x);

  printf("result %d\n", result);

  return result;

  }

  两组代码的差别在对GetArea()的调用是在Compare()之内还是之外。假如我们的测试目标是Comapre(),圆的外接正方形的面积a1在代码一中通过调用Compare()取得,在代码二中通过参数传递,显然,两者之间并无本质区别。Compare()的功能是,计算指定正方形的面积后并与外接正方形面积比较,GetArea()只是一个取得数据的调用,GetArea()本身是否正确,不是我们的测试目标,测试目标在于:对参数输入和GetArea()的各种输出是否做了合适的计算,只要这些计算正确,Comapre()就没有错误。因此,从测试角度来看,被测函数调用其他函数(称为底层函数)所取得的数据,完全可以和通过参数传递的数据同等对待,都是一种输入,称为内部输入。

  只有深刻理解内部输入,才能真正理解单元测试。单元测试是针对代码单元的独立测试,一个函数,在调用了其他函数的情况下,如何能够独立测试?只有把底层函数的输出,视作被测函数的一种输入,才能真正进行独立测试。

  把底层函数的输出视为被测函数的输入,会不会影响测试效果?当然不会,因为单元测试主要目的就是检查被测函数的功能逻辑,检查是否针对各种输入包括内部输入做了合适的处理。无论底层函数是否正确或者是否存在,只要被测函数对输入包括内部输入的各种可能做了正确的处理,被测函数本身就不会有功能错误。

  内部输入是单元测试的关键难题。代码耦合有两种,虚耦合和实耦合。虚耦合是指没有调用关系的耦合,例如我们要测试Compare(),这个函数位于一个文件A中,文件A中可能还有很多其他代码,也可能包含了很多头文件,虽然这些代码并没有被Compare()调用,但是,这些代码仍然可能造成文件A难于单独编译和链接,这就是虚耦合,虚耦合一般可以靠简单打桩解决。实耦合就是调用关系形成的耦合,例如在代码一中,Comapre()和GetArea()就是实耦合,实耦合又有两种情况:一是底层函数没产生被测函数需要使用的输出,这种情形可以不处置;二是底层函数产生了被测函数需要使用的输出,成了内部输入。

  内部输入有以下几种情形:

  自然内部输入

  这是指对底层函数的正常调用即可获得的内部输入,前面的示例就属于自然输入。代码一中Compare()函数,int a1 = GetArea(r);可以自然取得外接正方形的面积。如果外接矩形面积a1要得到某个预期的值,要传递合适的半径r。自然输入有两个条件:一是底层函数存在,二是底层函数正确。

  不可控的内部输入

  是指调用实际代码,但实际代码的输出难于控制,难于把各种可能输出都测试到。例如,底层函数返回一个随机数,就是不可控。在实际项目中,不可控是很常见的,下面的代码是空调控制程序中的一个函数(代码清单4.3.cpp):

  /*

  函数说明:

  

文章来源于领测软件测试网 https://www.ltesting.net/

63/6<123456>

关于领测软件测试网 | 领测软件测试网合作伙伴 | 广告服务 | 投稿指南 | 联系我们 | 网站地图 | 友情链接
版权所有(C) 2003-2010 TestAge(领测软件测试网)|领测国际科技(北京)有限公司|软件测试工程师培训网 All Rights Reserved
北京市海淀区中关村南大街9号北京理工科技大厦1402室 京ICP备10010545号-5
技术支持和业务联系:info@testage.com.cn 电话:010-51297073

软件测试 | 领测国际ISTQBISTQB官网TMMiTMMi认证国际软件测试工程师认证领测软件测试网