欢迎来到天天文库
浏览记录
ID:44411708
大小:25.50 KB
页数:3页
时间:2019-10-21
《浅谈软件测试常识》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、软件开发和使用的丿力史己经留给了我们很多由于软件缺陷而导致的巨人财力、物力损失的经验教训。这些经验教训迫使我们这些测试工程师们必须采取强有力的检测措施來检测未发现的隐藏的软件缺陷。牛产软件的最终目的是为了满足客户需求,我们以客户需求作为评判软件质量的标准,认为软件缺陷(SoftwareBug)的具体含义包括下面儿个因素:?软件未达到客户需求的功能和性能;?软件超出客户需求的范围;?软件出现客户需求不能容忍的错误;?软件的使川未能符合客户的习惯和工作坏境。考虑到设计等方面的因素,我们还町以认为软件缺陷还可以包括软件设计不符合规范,未能在特定的条件(资金、范围等)达到最佳等。可惜的是,我们
2、小的很多人更倾向于把软件缺陷看成运行时出现问题上來,认为软件测试仅限于程序捉交之后。在冃前的国内环境下,我们几乎看不到完整准确的客户需求说明书,加以客户的需求时时在变,追求完美的测试变得不太可能。因此作为一个优异的测试人员,追求软件质量的完美固然是我们的宗旨,但是明确软件测试现实与理想的差距,在软件测试屮学会取舍和讣步,对软件测试是有百益而无一弊的。下面是一些软件测试的常识,对这些常识的理解和运用将冇助于我们在进行软件测试时能够更好的把握软件测试的尺度。?测试是不完全的(测试不完全)很显然,由于软件需求的不完整性、软件逻辑路径的组合性、输入数据的大量性及结果多样性等因素,哪怕是一个极其
3、简单的程序,要想穷尽所有逻辑路径,所有输入数据和验证所有结果是非常困难的一件事情。我们举一个简单的例子,比如说求两个整数的最大公约数。其输入信息为两个正整数。但是如果我们将整个正整数域的数字进行一番测试的话,从其数冃的无限性我们便口J证明是这样的测试在实际生活中是行不通的,即便某一天我们能够穷尽该程序,只怕我们乃至我们的子孙都早已作古了。为此作为软件测试,我们一般采用等价类和边界值分析等措施來进行实际的软件测试,寻找最小用例集合成为我们精简测试复杂性的一条必经Z道。?测试具有免疫性(软件缺陷免疫性)软件缺陷与病毒一样具有可怕的“免疫性”,测试人员对其采用的测试越多,其免疫能力就越强,寻
4、找更多软件缺陷就更加因难。由数学上的概率论我们町以推出这一结论。假设一个50000行的程序中有500个软件缺陷并且这些软件错误分布时均匀的,则每100行可以找到一个软件缺陷。我们假设测试人员用某种方法花在查找软件缺陷的精力为X小时/100行。照此推算,软件存在500个缺陷时,我们查找一个软件缺陷需要X小时,当软件只存在5个错误时,我们每查找一个软件缺陷需要100X小时。实践证明,实际的测试过程比上面的假设更为苛刻,为此我们必须更换不同的测试方式和测试数据。该例子还说明了在软件测试中采川单一的方法不能高效和完全的针对所冇软件缺陷,因此软件测试应该尽可能的多采用多种途径进行测试。?测试是“
5、泛型概念”(全程测试)我一直反对软件测试仅存在于程序完成Z后。如果单纯的只将程序设计阶段后的阶段称之为软件测试的话,需求阶段和设计阶段的缺陷产牛的放人效应会加人。这非常不利于保证软件质量。需求缺陷、设计缺陷也是软件缺陷,记住“软件缺陷具有牛育能力”。软件测试应该跨越整个软件开发流程。需求验证(自检)和设计验证(自检)也可以算作软件测试(建议称为:需求测试和设计测试)的一种。软件测试应该是一个泛型概念,涵盖整个软件住命周期,这样才能确保周期的每个阶段禁得起考验。同时测试本身也需要有笫三者进行评估(信息系统审计和软件工程监理),即测试本身也应当被测试,从而确保测试H身的可靠性和高效性。否则
6、自身不正,难以服人。另外还需指出的是软件测试是提高软件产品质量的必要条件而非充分条件,软件测试是提高产品质量最直接、最快捷的手段,但决不是一个根本手段。?80-20原则80%的软件缺陷常常生存在软件20%的空间里。这个原则告诉我们,如果你想使软件测试冇效地话,记住常常光临其高危多发“地段”。在那里发现软件缺陷的可能性会大的多。这一原则对于软件测试人员提高测试效率及缺陷发现率冇着重大的意义。聪明的测试人员会根据这个原则很快找出较多的缺陷而愚蠢的测试人员却仍在漫无口的地到处搜寻。80-20原则的另外一种情况是,我们在系统分析、系统设计、系统实现阶段的复审,测试工作中能够发现和避免80%的软
7、件缺陷,此后的系统测试能够帮助我们找出剩余缺陷中的80%,授后的5%的软件缺陷nJ能只冇在系统交付使用后用户经过大范围、长时间使用后才会曝露出來。因为软件测试只能够保证尽可能多地发现软件缺陷,却无法保证能够发现所有的软件缺陷。8020原则还能反映到软件测试的自动化方面上來,实践证明80%的软件缺陷可以借助人工测试而发现,20%的软件缺陷可以借助自动化测试能够得以发现。由于这二者间具有交叉的部分,因此尚有5%左右的软件缺陷需要通过其他方式进行发现
此文档下载收益归作者所有