Ch3软件测试基础知识.ppt
《Ch3软件测试基础知识.ppt》由会员分享,可在线阅读,更多相关《Ch3软件测试基础知识.ppt(117页珍藏版)》请在三一办公上搜索。
1、23.7.1,1,Part One 软件测试基础,Chapter 3 软件测试基础知识,23.7.1,2,软件测试基础知识,内容概要:序言软件测试定义软件测试目的对软件测试的认识软件测试理论软件测试原则软件测试的分类软件测试的术语和定义其它,23.7.1,3,3.1序言,困惑:软件测试可以说是一个非常令人捉摸不定的领域。“应该怎样对我们的产品进行测试?”和“怎样才算对产品进行了足够的测试?”等问题,对于不同企业的不同类产品、同一企业的不同类产品、或不同企业的同一类产品,实际操作上都会有很大的不同。,23.7.1,4,软件过程现状,实际项目中,看不到完全符合客户需求的产品需求规格说明书。客户需求
2、不断变化。代码频繁更改。资源有限,进度逼人理想的软件过程只是追求的目标。测试人员应该面对现实。,23.7.1,5,软件测试现状,软件测试的技术和方法多年以来并没有取得令人振奋的进展。软件测试的效果主要还是依赖于测试人员的经验。,23.7.1,6,对软件测试的认识的发展,测试=调试测试是证明软件正确测试是发现软件中的错误测试是减小软件不工作的风险测试是一种认识上的训练,23.7.1,7,关于软件测试的讨论,这个软件已经经过了测试。这个软件已经经过了严格的测试。这个软件通过了测试。,STE概述,23.7.1,8,软件测试的发展,二十世纪70年代以前 Ad-hoc testing,指的是测试者想到哪
3、测到哪,没有周密的测试计划和过程,没有测试文档,测试不能复用,与调试没有区分。70年代末80年代中期 测试基础理论和实用技术形成,测试作为软件质量保证(SQA)的主要职能。,23.7.1,9,软件测试的发展,80年代末90年代中期 测试工具在质量和数量上不断增长,测试与SQA分离,SQA注重于过程和质量监督,专职测试岗位产生。并且注重工具对测试效率的影响,测试自动化开始广泛应用。90年代后期 关注有效的过程管理对于软件测试的重要性,形成各种测试模型、测试能力成熟度模型。,23.7.1,10,软件测试的发展,二十一世纪初 软件测试的重要性越来越被人们接受,甚至出现了软件开发活动应以测试为主导的思
4、潮,如XP方法。而且,随着软件测试分工的细化和成熟,软件企业注重于自身核心竞争力的提升,促使大量的独立软件测试服务机构涌现出来。这些测试服务机构运作机制日趋成熟,从单一的第三方认证评测,逐步转向参与整个软件开发过程的测试服务,并按照软件领域形成市场细分,已经形成一个成熟和广阔的市场区间。,23.7.1,11,软件测试的发展,官方软件评测机构软件工程师资格认证专业软件测试企业专门的软件测试课程专门的软件测试学位(不远的将来),23.7.1,12,4.2软件测试定义,曾有的定义:软件测试是为了发现错误而执行程序的过程。软件测试是根据软件开发阶段的规格说明和程序的内部结构而精心设计的一批测试用例(即
5、输入数据及预期的输出结果),并利用这些测试用例去运行程序,以发现错误的过程。,23.7.1,13,软件测试的定义(推荐),【国家标准GBT 114571995】由人工或自动方法来执行或评价系统或系统部件的过程,以验证它是否满足规定的需求;或识别出期望的结果和实际结果之间的差别。【ISO/IEC2号导则】测试是指由给定产品、过程或按照规定的规程服务的一个或多个特性的测定组成的技术操作。,23.7.1,14,软件测试定义(推荐),【IEEE/ANSI,std829-1983】对软件进行分析,找出其现有状况与要求状况之间的差异。,基础概念,23.7.1,15,关于软件测试的著名论点,关于软件测试的著
6、名论点Grenford J.Myers:测试是为了发现错误而执行程序的过程一个好的测试是指很可能找到尚未发现的错误的测试一个成功的测试是指发现了至今未发现的错误的测试Hetzel:软件测试是对软件建立信心的过程测试是评估软件或系统的品质或能力的一种积极的行为测试是对软件质量的度量,23.7.1,16,4.3软件测试目的,Grenford J.Myers关于软件测试的著名论点:测试是程序的执行过程,目的在于发现错误;一个好的测试用例在于能够发现至今未发现的错误;一个成功的测试是发现了至今未发现的错误的测试。,23.7.1,17,软件测试目的,个人认为这是一种比较狭窄的观点。,23.7.1,18,
7、软件测试目的,一个被人忽略的软件测试目的是:测试可以帮助发现当前开发工作所采用的软件过程的缺陷,以便进行改进。测试并不仅仅是为了要找出错误。,23.7.1,19,软件测试目的,通过分析错误产生的原因,分析错误产生于哪一个开发阶段、而又在哪一个阶段被发现,我们可以判断从错误的产生到错误的发现,跨越了多少个开发阶段。一个错误能够超越本开发阶段而不被发现,就指明了该开发阶段的检测手段有缺陷,从而有针对性地制定出加强的措施与办法。这也就是软件过程改进的一项重要内容。,23.7.1,20,对软件测试目的理解,以最少时间和最小代价,发现最多数量的错误。测试具有发现错误的能力,但不能说明软件中不存在错误,恰
8、恰相反,测试只能证明软件中存在错误。测试可以减少软件中的错误。测试过程中的数据和测试结果,可以为软件质量的评价提供依据,可以得到软件性能指标。对测试而言,困难和挑战在于无法预知软件中潜在的错误总 量。但完整的测试是评定软件质量的一种方法。没有发现错误的测试也是有价值的。,23.7.1,21,4.4对软件测试的认识,软件测试能做什么?发现软件中残存的错误为软件质量的评价提供支持为软件开发过程的改进提供帮助一种有效的软件工程验证与确认方法,23.7.1,22,测试设计,测试是需要设计的。一个好的测试计划和测试用例往往能达到事半功倍的效果。测试是一项具有很大创造性的工作,其工作量一点也不比软件设计小
9、。软件测试的创造性主要表现在测试方案选择、测试计划制定、测试用例设计、测试结果的分析以及测试过程的管理等方面,23.7.1,23,测试目标,测试目标我们的目标是设计一个能够系统地发现不同阶段的错误的测试,且消耗最短的时间和最小的工作量。测试的附带收获示证了软件的功能依据其需求说明而工作表明软件满足其性能需求测试中收集的数据提供了软件可靠性和软件质量的部分信息,23.7.1,24,对软件测试的理解,基于上述定义,测试并不仅仅意味着运行程序的动态测试,也包括对需求定义和设计等进行分析的静态测试。测试是攻击和破坏软件的方法和过程,以达到提高软件质量的目的。测试是努力发现上述三类软件错误的活动,即:努
10、力发现偏离错误努力发现语言使用错误努力发现功能缺陷,基础概念,23.7.1,25,对软件测试的理解,从软件过程的角度来看测试:测试是指软件产品生命周期内所有的检查、评审和确认活动。如:设计评审、代码走查、系统测试等。测试的最终目的是确保交给用户的产品符合用户的需求。,23.7.1,26,对软件测试的理解,软件测试要解决的问题是:软件的行为是否符合“规定的”要求。它有两个方面的含义:第一,软件测试要解决的问题是,是否做了规定要做的事;第二,软件是否做了没有规定要做的事?,23.7.1,27,软件测试的局限性,无法实现彻底的测试被测系统存在故障敏感性和巧合正确性不能直接验证需求获得预期结果困难,甚
11、至不可能测试本身也可能存在错误,23.7.1,28,软件测试的致命缺陷,测试的不完全、不彻底性。由于任何软件只能进行有限的测试,发现了错误说明软件有问题;未发现错误不能说明软件没有问题。,23.7.1,29,对测试的正确认识,软件测试不是解决软件质量问题的唯一方法;软件测试不能取代其他的质量保证手段;软件测试不能保证发现软件中的所有错误,完全的测试是不现实的;软件测试是巨大的效益和艰苦的工作并存,测试的组织和管理就是在其中取得平衡。,23.7.1,30,软件测试的重要性,23.7.1,31,项目持续时间,消除缺陷,消除缺陷,软件测试重要性,Close the Quality Gap So We
12、 Can Release Working Software on time,23.7.1,32,100%,软件测试重要性,23.7.1,33,越早测试越好自动的测试测试每一个版本,传统的测试是在代码实现之后进行,软件测试重要性,23.7.1,34,一个好的软件工程的守则,软件开发全过程检测,力争本阶段修正错误。单元测试是在软件开发的“实现阶段”才开始的,在此之前的“可行性研究与计划阶段”,“需求分析阶段”,“概要设计阶段”,和“详细设计阶段”,都必须有切实的手段与措施对开发结果进行检验,以保证阶段的正确完成,23.7.1,35,测试的重要性,测试是软件生存周期中一个独立的、关键的阶段,是保证软
13、件质量的重要手段,也是软件质量保证的最后一个环节。测试活动贯穿于软件活动中的所有阶段。从需求阶段高层设计低层设计编码阶段单元测试集成测试系统测试验收测试测试越早开始,故障越早被发现,消除故障的成本越少。,23.7.1,36,内容概要:,序言软件测试定义软件测试目的对软件测试的认识软件测试理论软件测试原则软件测试的分类软件测试的术语和定义其它,23.7.1,37,3.5软件测试理论,后面总结了9条软件测试的基本原理,是软件测试和软件开发的“交通规则”、“生活法则”。理解它们有助于透彻了解软件过程。,23.7.1,38,Parito法则,一般情况下,在分析、设计、实现阶段的复审和测试工作只能够发现
14、和避免80%的Bug,而系统测试也只能找出其余Bug中的80%,最后剩余的Bug只有在用户的大范围、长时间使用后才有可能会曝露出来。因为测试只能够保证尽可能多地发现错误,无法保证能够发现所有的错误。也称80-20理论。,23.7.1,39,木桶理论,在软件产品生产方面就是全面质量管理(TQM)的概念。产品质量的关键因素是分析、设计和实现,测试应该是融于其中的补充检查手段,其他管理、支持、甚至文化因素也会影响最终产品的质量。应该说,测试是提高产品质量的必要条件,也是提高产品质量最直接、最快捷的手段,但决不是一种根本手段。反过来说,如果将提高产品量的砝码全部押在测试上,那将是一个恐怖而漫长的灾难。
15、木桶理论就是要强调改进我们木板最短的那一块.只有短木板变为长木板,桶装水才会更多。,23.7.1,40,测试不能证明软件无错,软件测试的不完全、不彻底性。测试无法显示潜伏的软件缺陷。由于任何程序只能进行有限的测试,在发现错误时能说明程序有问题;但在测试未发现错误时,不能说明程序中没有错误。,23.7.1,41,完全测试软件是不可能的,主要原因:输入量太大输出结果太多软件实现的途径太多软件需求规格说明书没有客观标准。“太多”的可能性加在一起,致使测试条件难以确定。,23.7.1,42,完全测试软件是不可能的,例如:WinX操作系统带的计算器程序。单个数据、多个数据的组合;+,-,*./各种算法组
16、合;正常、异常情况组合输入组合无穷多,无法完全测试。注:如果觉得某些测试条件是重复的或者无必要的而将其剔除,那么就不能称作完全测试。,23.7.1,43,软件测试是有风险的行为,如果决定不去测试所有的情况,那就是选择了风险。(泄漏故障的可能性)(碰巧在某个特定的输入组合下软件留有缺陷)如何把无边无际的输入可能减少到可以控制的范围?去粗存精,减小风险。,23.7.1,44,测试量和发现的软件缺陷数量之间的关系,23.7.1,45,软件测试是有风险的行为,由上图,随着测试工作量的增加,费用增加,遗漏软件缺陷数目减少。最佳平衡点在哪?找到了它,就找到了最合适的测试工作量。,23.7.1,46,测试无
17、法显示潜伏的软件缺陷,软件测试工作可以报告已发现的软件缺陷;却不能保证软件缺陷全部找到;也不知道还有多少潜伏的软件缺陷。继续测试,可能还会找到一些。,23.7.1,47,程序中存在错误的概率与该程序中已发现的错误数成比例。,软件缺陷的“群集”现象,80%的错误存在于20%的代码中。原因:程序员疲倦。一个软件缺陷很可能是附近有更多的软件缺陷的征兆。程序员易犯同样的错误。个人偏好。多个软件缺陷相互关联,甚至是由同一个原因造成的。缺陷的“传递”和“放大”。,23.7.1,48,程序中存在错误的概率与该程序中已发现的错误数成比例。,找到软件缺陷越多的模块,遗留的软件缺陷越多。如果某软件无论如何也找不出
18、软件缺陷,也可能是软件经过精心编制,确实存在极少的软件缺陷。,23.7.1,49,软件缺陷的免疫力,软件会对相同类型的测试会产生“免疫力”。(开发小组VS.测试小组)。经过几轮的测试,该发现的错误都被发现了,再测试下去也不会有新的发现了。农药杀虫剂怪事。解决:不断编写新的测试用例,采用新的测试程序,对程序的不同部分进行测试,以找出更多的软件缺陷。,23.7.1,50,并非所有软件缺陷都能修复,项目组需要对每一个软件缺陷进行评估和取舍,根据风险和成本决定哪些必须修复,哪些不用修复,哪些可以延期修复。通常有CCB会议决定。CCB由软件项目各方代表组成。,23.7.1,51,并非所有软件缺陷都能修复
19、,不需要修复的软件缺陷的原因:没有足够的时间。不算是真正的软件缺陷。小功能,小改进。修复的风险太大。技术难度,引入新的缺陷,不值得修复。商业风险(intel奔腾浮点数运算缺陷),23.7.1,52,相互关系,不可能进行完全的测试。由于1,测试是有风险的,即测试会遗漏软件缺陷。由于2,测试不能证明程序无措,而仅能证明程序有错。由于1,2,3,测试发现的错误越多,则说明软件的错误越多。错误密度大,遗漏的也多。,基础概念,23.7.1,53,内容概要:,序言软件测试定义软件测试目的对软件测试的认识软件测试理论软件测试原则软件测试的分类软件测试的术语和定义其它,23.7.1,54,3.6软件测试的基本
20、原则,基于上述的测试理论,下面列举一些测试原则,它们是软件测试工作中常用的策略。它们建立在实践的基础上。,23.7.1,55,测试的基本原则(一),所有的测试都应追溯到用户需求 产品最终是为了给用户使用,对用户来说,最严重的错误是那些导致程序不能够满足他们的需求的错误,所以测试应该从用户的角度来测试产品。事实上,需求是驱动整个研发过程的源头,不仅仅设计、开发要需求 驱动,测试更是要需求驱动。实际的做法:测试设计依据需求设计,并建立需求追踪矩阵,测试活动按照测试设计进行。测试人员把握用户真实的需求,不仅仅做验证工作,也要做确认工作。,23.7.1,56,测试的基本原则(二),所有测试活动都应该是
21、有计划的,并且计划能够得到保障。严格执行测试计划,排除测试的随意性。要坚决反对无计划、无明确目的、随意的测试活动;反对过程不可重复的即兴测试。测试计划应在需求一确定或需求模型一完成就开始,总之要在代码产生之前就开始。测试计划包括日程计划、资源计划、方案设计、测试用例设计等。现实工作中,常见的问题就是测试无计划或计划性不强、随意更改测试计划、迫于市场压力压缩测试计划等。,23.7.1,57,测试的基本原则(三),Good-enough原则 测试要权衡投入产出比,即要充分也不要过分。不充分的测试是不负责任的;过分的测试是一种资源的浪费,同样也是一种不负责任的表现。过分测试指无意义的重复测试和需要消
22、耗过大投入的非关键性测试。困难在于:如何界定什么样的测试是不充分的,什么样的测试是过分的。,23.7.1,58,测试的基本原则(三续),答案:制定最低测试通过标准和测试内容,然后具体问题具体分析。持续地对测试过程进行度量,对测试和测试结果评价,在保证充分性的前提下去除冗余测试,确保测试过程的有效性。然而,实际测试工作中,我们很少去关注这方面的数据。对于相对复杂的产品或系统来说,zero-bug是一种理想,good-enough是我们的原则。寻求合适的测试策略,在质量和成本之间寻求合适的平衡点。,23.7.1,59,测试的基本原则(四),软件测试应遵循Parito法则(二八法则)。二八法则最初来
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- Ch3 软件 测试 基础知识

链接地址:https://www.31ppt.com/p-5376736.html