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就不应该存在。这是一个理想状态,一个合理的测试过程,应该让我们更加接近这个状态。
合理的测试,会使软件产品趋于正确和完善。同时,测试也是验证这一结果的过程。对于用户而言,他期望的是符合他需求的产品,测试的目的就是使产品不会偏离用户需求,并且达到一个合理的质量水平。并且当场品对于客户的标准有所偏离时,测试能够为我们指明改正的方向。
文章来源于领测软件测试网 https://www.ltesting.net/