动态测试方法

动态测试方法,通过实际执行代码去发现潜在代码错误的测试方法。

人工动态方法

人工动态方法,可以真正检测代码的业务逻辑功能,其关注点是“什么样的输入,执行了什么代码,产生了什么样的输出”,主要用于发现算法错误和部分算法错误,是最主要的代码级测试手段。代码级测试的人工动态测试方法,其实就是单元测试所采用的方法。

单元测试,用驱动代码去调用被测函数,并根据代码的功能逻辑选择必要的输入数据的组合,然后验证执行被测函数后得到的结果是否符合预期。

单元测试中三个最主要的难点:

单元测试用例“输入参数”的复杂性;

单元测试用例“预期输出”的复杂性;

关联依赖的代码不可用。

单元测试用例“输入参数”的复杂性

单元测试用例“输入参数”的复杂性,表现在“输入参数”不是简单的函数输入参数。本质上讲,任何能够影响代码执行路径的参数,都是被测函数的输入参数。

第一,被测试函数的输入

参数 如示例的输入参数a和b


int someFunc(int a, int b)
{
  …
}

第二,被测试函数内部需要读取的全局静态变量。

如果被测函数内部使用了该函数作用域以外的变量,那么这个变量也是被测函数的输入参数。


bool someGlobalVariable = true;
void Func_SUT(int a)
{
  ...
  if(someGlobalVariable == true)
  {
    FuncA();
  }
  else
  {
    FuncB();
  }
  ...
}

示例中 全局变量 someGlobalVariable,需要设计为true和false的情况,导致这个全局变量也成为了输入。

第三,被测试函数内部需要读取的类成员变量


class someClass{
  ...
  bool someClassVariable = true;
  ...
  void Func_SUT(int a)
  {
    ...
    if(someClassVariable == true)
    {
      FuncA();
    }
    else
    {
      FuncB();
    }
    ...
  }
  ...
}

根据 someClassVariable 的取值不同,会执行两个不同的代码分支。同样地,单元测试想要覆盖这两个分支,就必须提供 someClassVariable 的不同取值,所以 someClassVariable 对于被测函数 Func_SUT 来说也是输入参数。

第四,函数内部调用子函数获得的数据 


void Func_SUT(int a)
  {
  bool toggle = FuncX(a);
  if(toggle == true)
  {
    FuncA();
  }
  else
  {
    FuncB();
  }
}

这里toggle 也成为一个被测函数的输入参数。

第五,函数内部调用子函数改写的数据

第六,嵌入式系统中,在中断调用中改写的数据

单元测试用例“预期输出”的复杂性

单元测试用例“预期输出”的复杂性,主要表现在“预期输出”应该包括被测函数执行完成后所改写的所有数据。

第一,被测函数的返回值

第二,被测函数的输出参数

第三,被测函数所改写的成员变量和全局变量

第四,被测函数中进行的文件更新、数据库更新、消息队列更新等

关联依赖的代码不可用

假设被测函数中调用了其他的函数,那么这些被调用的其他函数就是被测函数的关联依赖代码。

为了不影响被测函数的测试,我们往往会采用桩代码来模拟不可用的代码,并通过打桩补齐未定义部分

具体来讲,假定函数 A 调用了函数 B,而函数 B 由其他开发团队编写,且未实现,那么我们就可以用桩函数来代替函数 B,使函数 A 能够编译链接,并运行测试。

桩函数要具有与原函数完全相同的原形,仅仅是内部实现不同,这样测试代码才能正确链接到桩函数。一般来讲桩函数主要有两个作用,一个是隔离和补齐,另一个是实现被测函数的逻辑控制。

用于实现隔离和补齐的桩函数实现比较简单,只需拷贝原函数的声明,加一个空的实现,可以通过编译链接就可以了。用于实现控制功能的桩函数是最常用的,实现起来也比较复杂,需要根据测试用例的需要,输出合适的数据作为被测函数的内部输入。

自动动态方法

自动动态方法是,基于代码自动生成边界测试用例并执行来捕捉潜在的异常、崩溃和超时的测试方法。

自动动态方法的重点是:如何实现边界测试用例的自动生成。

解决这个问题最简单直接的方法是,根据被测函数的输入参数生成可能的边界值

任何数据类型都有自己的典型值和边界值,我们可以预先为它们设定好典型值和边界值,然后组合就可以生成了。

比如,函数 int func(int a, char *s),就可以按下面的三步来生成测试用例集。

定义各种数据类型的典型值和边界值。 比如,int 类型可以定义一些值,如 int 的最小值、int 的最大值、0、1、-1 等;char* 类型也可以定义一些值,比如“”、“abcde”、“非英文字符串”等。

根据被测函数的原形,生成测试用例代码模板,比如下面这段伪代码:

将参数 @a@和 @s@的各种取值循环组合,分别替换模板中的相应内容,即可生成用例集。由于该方法不可能自动了解代码所要实现的功能逻辑,所以不会验证“预期输出”,而是通过 try…catch 来观察是否会引发代码的异常、崩溃和超时等具有边界特征的错误。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
AD(Attention Deficit)双音动态测试方法是一种用于评估注意力缺陷的测试方法。该测试方法通过测量个体对两个不同频率的声音的反应,来评估其对听觉刺激的注意力和集中力。 AD双音动态测试通常包括在一段时间内,以特定频率播放两种不同音调的声音,并要求被测试个体通过按下按钮或其他方式来反应。测试者会记录下反应的准确性、时长和延迟等信息。 通过分析测试结果,可以得出被测试个体对不同频率的声音刺激的反应程度。通常,AD患者在高频音刺激下表现出更差的反应和更长的延迟,这可能表明了他们对注意力和集中力的缺乏。 AD双音动态测试方法具有一定的优点和局限性。优点是该方法简单易行,能够快速评估个体的注意力缺陷情况。同时,该测试可以用于对治疗方案的跟踪和评估效果,帮助医生调整治疗计划。 然而,AD双音动态测试方法也存在一些局限性。首先,该测试只能评估个体在特定频率下的注意力表现,而无法全面了解其在其他环境和任务下的表现。其次,测试结果可能受到个体其他因素的影响,如情绪状态、压力等。 综上所述,AD双音动态测试方法是一种简单快捷的评估注意力缺陷的方法,但在实际应用中仍需综合考虑其他因素,并结合其他评估工具和医生的临床判断,来确切评估个体的注意力缺陷情况。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值