从测试方法的角度可以分为手工测试和自动化测试。

1、静态测试

    所谓静态测试static testing)就是不实际运行被测软件,而只是静态地检查程序代码界面或文档中可能存在的错误的过程。

    从概念中我们可以知道,其包括对代码测试、界面测试和文档测试三个方面:

    对于代码测试,主要测试代码是否符合相应的标准和规范。

    对于界面测试,主要测试软件的实际界面与需求中的说明是否相符。

    对于文档测试,主要测试用户手册和需求说明是否符合用户的实际需求。

    其中后两者的测试容易一些,只要测试人员对用户需求很熟悉,并比较细心就很容易发现界面和文档中的缺陷。而对程序代码的静态测试要复杂得多,需要我们按照相应的代码规范模板来逐行检查程序代码。那么我们从哪里获得这个规范模板呢?其实没有一个统一的标准,每个公司内部一般都有自己的编码规范,比如《c/c++编码规范》,你只需要按照上面的条目逐条测试就可以了。当然很白盒测试工具中就自动集成了各种语言的编码规范,比如parasoft公司的C++Test就集成了C/C++的编码规范,我们只要点击一个按钮,这些工具就会自动帮助我们检测代码中不符合语法规范的地方,非常方便。

    下面我们举一个实际的例子。

       C语言程序的静态分析和动态分析

#include <stdio.h>

Max(float x, float y)

{

float z;

z=x>y?x:y;

return(z);

}

Main()

{

float a, b;

int c;

scanf(“%f, %f”&a,&b);

c=max(a,b);

printf(“Max is %d
”, c);

}

    这段C语言编写的小程序,比较简单,实现的功能为:在主函数里输入两个单精度的数ab,然后调用max子函数来求ab中的大数,最后将大数输出。

    我们现在就对代码进行静态分析,主要根据一些C语言的基础知识来检查。

    我们把问题分为两种,一种必须修改的,另一种建议修改的。

    必须修改的问题有三个:

   (1)程序没有注释。注释是程序中非常重要的组成部分,一般占到总行书的1/4左右。程序开发出来不仅是给程序员看得,其他程序员和测试人员也要看得。有了注释,别人就能很快地了解程序实现的功能。注释应该包含作者,版本号、创建日期等,以及主要功能模块的含义

   (2)子函数max没有返回值的类型。由于类型为单精度,我们可以在max()前面加一个float类型声明。

   (3)精度丢失问题。大家注意“c=max(a,b)”语句,我们知道c的类型为整型int ,而max(a,b)的返回值z为单精度float, 将单精度的数赋值给一个整型的数,c语言的编译器会自动地进行类型转换,将小数部分去掉,比如z=2.5,赋给c则为2,最后输出的结果就不是ab 中的大数,而是大数的整数部分。

    建议修改的问题也有三个;

      (1)Main函数没有返回值类型和参数列表。虽然main函数没有返回值和参数,但是我们组后将其改为void main(void),来表明main函数的返回值和参数都为空,因为在有的白盒测试工具的编码规范中,如果不写void会认为是个错误。

    (2)一行代码只定义一个变量。

    (3)程序适当加些空行。空行不占内存,会使程序看起来更清晰。

程序修改如下:

#include <stdio.h>

float max(float x, float y)//返回两个单精度数中的大数

{

float z;

z=x>y?x:y;

return(z);

}

main()

{

float a;

float b;

int c;

 

scanf(“%f, %f”&a,&b);

c=max(a,b);

printf(“Max is %d
”, c);

}

    根据上面的分析,我们来编写一个简单的C语言代码规范

规范编号

规范内容

是否通过

1

一行代码只做一件事情

 

2

代码行的最大长度控制在70-80字,否则不便于阅读和打印

 

3

函数和函数之间,定义语句和执行语句之间加空行

 

4

在程序开头加注释,说明程序的基本信息;在重要的函数模快处加注释,说明函数的功能

 

5

低层次的语句比高层次的缩进一个tab4个空格)

 

6

不要漏掉函数的参数和返回值,如果没有,用void表示

 

2. 动态测试

    动态测试(dynamic testing),指的是实际运行被测程序,输入相应的测试数据,检查实际输出结果和预期结果是否相符的过程,所以判断一个测试属于动态测试还是静态的,唯一的标准就是看是否运行程序。

    我们还是以刚才的那段代码为例,实际运行修改后的程序,输入1.2 和3.5两个实数,按回车,得到结果3.500000,与我们预期的相符合。

    这是一个动态测试的过程。可能有的读者会问,以上过程不也是黑盒测试的过程马?黑盒白盒、动态静态,它们之间有什么关系呢?

    它们只是测试的不同角度而已,同一个测试,既有可能是黑盒测试,也有可能是动态测试;既有可能是静态测试,也有可能是白盒测试。

    黑盒测试有可能是动态测试(运行程序,看输入输出),也有可能是静态测试(不运行,只看界面)

    白盒测试有可能是动态测试(运行程序并分析代码结构),也有可能是静态测试(不运行程序,只静态察看代码)

    动态测试有可能是黑盒测试(运行,只看输入输出),也有可能是白盒测试 (运行并分析代码结构)

    静态测试有可能是黑盒测试(不运行,只察看界面),也有可能是白盒测试(不运行,只察看代码)