什么是软件测试

来源:互联网 发布:纯净手机浏览器 知乎 编辑:程序博客网 时间:2024/06/06 17:20

软件测试时代
1.为什么要测试

        测试有什么用?花那么多的人力物力和金钱做的测试到底是为了什么?很多所谓的专

业书籍对此讲了很多让人眼花缭乱的理论。

        其实很简单,测试就是为了让产品在交付给最终用户以后,在产品生存周期(或提供

有效服务的期限以内),不让最终用户发现其所不能接受的现象。

        良好的测试,可以有效的降低维护的成本。用户如果满意你的产品,就不会一而再、

再而三的要求改进,维护的成本自然会下降。

        当然,测试本身的成本也是不低的,所以为了让我们为测试付出的代价物有所值(大

概还没有人会说自己的产品从未经过测试吧),我们很有必要去认真的了解一下关于测试的一

些东西。

 

2.什么是测试

        软件测试是在有限的时间内提供高质量软件的保证,是一个完整正规的软件开发过程

中非常重要的一个部分。(《微软是怎样做测试的》——ATC ( Advanced Technology Center

,微软亚洲工程院 ) 测试组相关负责人)

        Any activities aimed at evaluating an attribute or capability of a program

or system. ( Bill Hetzel 1983年对测试的定义 )

        The process of executing a program or system with the intent of finding

errors. ( Glenford J. Myers 对测试的定义 )

        使用人工或自动的手段来运行或测定某个软件系统的过程,其目的在于检验它是否满

足规定的需求或弄清预期结果与实际结果之间的差别。( IEEE 1983年对测试的定义 )

        测试是以评价一个程序或者系统属性为目标的任何一种活动。测试是对软件质量的度

量。( Bill Hetzel 《软件测试完全指南》)

        我个人对测试的理解是,我们编写的代码应该通过全部的测试,使之完成所有需求。

即测试就是让我们的产品符合客户要求的过程。这里的理解有些狭隘,的确。客户并不专业,

客户未必能了解我们的产品中存在的Bug,而且客户并不关心这些,只要他们看到了他们想要的

东西,他们就愿意付钱。所以,以商业为目的的软件产品,大多时候没有必要深究一些无法带

来经济利益的问题,例如为一个运行时间为2秒的任务提高50%的效率,数字上很诱人,但这几

乎毫无意义,而且会浪费很多资源。

3.      测试的目的

        测试是为了证明程序有错,而不是证明程序无错误。

        一个好的测试用例是在于它能发现至今未发现的错误。

        一个成功的测试是发现了至今未发现的错误的测试。

(Grenford J. Myers《The Art of Software Testing》)

        上面的定义是一个关于测试目的的经典说明,但是容易让人产生误解——测试 = 发现

Bug。我并不赞同这样的观点。

        通常,测试作为一种质量保证的手段,作为项目后期自我检查的一部分。既是说,大

量的缺陷和Bug等堆积到一定数量后,我们才开始去发现他们。

        让我们来看看编译器报错的目的,很容易我们就可以看出它是用来保证我们编出正确

的代码的,当然这仅仅是正确的语法。它并不保证代码的功能。编译器对代码的测试,就很有

效的提高了我们的工作效率。

        我们也许应该尝试考虑这样的一个测试计划,用它来保证生产出正确的软件,而非仅

仅是查找Bug。Bug或者说缺陷,通常的理解就是干扰程序正常运行的因素。很显然,如果程序

正确,那么,Bug就不应该存在。这是一个理想状态,一个合理的测试过程,应该让我们更加接

近这个状态。

        合理的测试,会使软件产品趋于正确和完善。同时,测试也是验证这一结果的过程。

对于用户而言,他期望的是符合他需求的产品,测试的目的就是使产品不会偏离用户需求,并

且达到一个合理的质量水平。并且当场品对于客户的标准有所偏离时,测试能够为我们指明改

正的方向。