软件测试与软件开发过程.pptx
《软件测试与软件开发过程.pptx》由会员分享,可在线阅读,更多相关《软件测试与软件开发过程.pptx(28页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、定义:定义:软件测试软件测试是软件工程(是软件工程(Software Engineering)的一个重要分支,随着软件工)的一个重要分支,随着软件工程学科的发展,现在的软件测试与传统的软件测试相比有了很大的发展,它与软件程学科的发展,现在的软件测试与传统的软件测试相比有了很大的发展,它与软件开发过程和软件质量保证(开发过程和软件质量保证(Quality Assurance,QA)密切相关。)密切相关。软件开发过程软件开发过程是生产软件产品所用的工具、方法和实践过程的集合。在商业上是生产软件产品所用的工具、方法和实践过程的集合。在商业上软件开发通常是由一组协同工作的人来完成的,我们把这组人称为开
2、发团队。开发软件开发通常是由一组协同工作的人来完成的,我们把这组人称为开发团队。开发团队里有各种角色,一个人可以充当不止一个角色,特别是在许多小公司,有时一团队里有各种角色,一个人可以充当不止一个角色,特别是在许多小公司,有时一个人身上集中了几个角色。个人身上集中了几个角色。生命周期 一个软件产品是由上述多种角色的团队协同工作而完成的。从策划、定义、开发、使用与维护直到最后废,要经过一个漫长的时期,通常把这个时期称为软件的生命周期(Software Life Cycle),很多人也把它称为软件开发生命周期(Software Development Life Cycle)。8.1 软件开发过程概
3、述软件开发过程概述第1页/共28页各种角色及主要职责l 项目经理(程序经理):负责管理产品的质量,以及项目的进度和预算。l 商业分析师(软件分析师):分析客户的真正需求,用能被程序员或其他设计人员理解的术语来定义客户的需求。l 架构师(系统工程师):是产品小组的专家,负责系统的总体内部设计(定义代码,数据结构,数据通信和开发策略等)。l 程序员(开发人员):设计、编写程序并编写内部设计规格说明。l 测试员(质量保证员):负责找出并报告软件产品的问题。l 产品经理(产品营销经理):负责符合公司长期战略和形象的产品的交付,并在产品发布后负责市场营销活动。对产品的盈利负责。l 技术支持代表:负责处理
4、客户投诉和服务的小组的成员。在产品开发期间他们会尽力对产品的设计和手册的内容施加影响,以减少客户的投诉。l 技术文档编写员:制作用户手册和在线帮助。第2页/共28页瀑布模型(Waterfall Model)几个特征:几个特征:(1)阶段间的顺序性和依赖性)阶段间的顺序性和依赖性(2)推迟实现的观点)推迟实现的观点(3)质量保证的观点)质量保证的观点缺点:缺点:(1)不适应需求经常发生变更的环境。)不适应需求经常发生变更的环境。(2)瀑布模型也经常不能接受项目开始)瀑布模型也经常不能接受项目开始阶段自然存在的不确定性。阶段自然存在的不确定性。(3)线性顺序模型种特征导致工作中发)线性顺序模型种特
5、征导致工作中发生生“阻塞阻塞”状态。状态。第3页/共28页8.1.1 软件开发生命周期模型 模型种类种类有瀑布模型、原型模型、快速应用开发模型、增量模型、螺旋模型、V模型、形式方法模型、RUP(Rational Unified Process)模型、敏捷过程模型、构件组装模型、并发开发模型等。几种比较流行的模型 1传统的瀑布模型(Waterfall Model)2原型模型(Prototyping Model)3螺旋模型(Spiral Model)第4页/共28页原型模型(Prototyping Model)在项目开发的初始阶段,人们对软件的需求认识常常不够清在项目开发的初始阶段,人们对软件的需
6、求认识常常不够清晰,使得开发项目难以做到一次开发成功,出现返工再开发在所晰,使得开发项目难以做到一次开发成功,出现返工再开发在所难免。因此,可以先做试验开发,其目标只是探索可行性,弄清难免。因此,可以先做试验开发,其目标只是探索可行性,弄清软件需求;然后在此基础上获得较为满意的软件产品。通常把第软件需求;然后在此基础上获得较为满意的软件产品。通常把第一次得到的试验性产品称为一次得到的试验性产品称为“原型原型”。第5页/共28页螺旋模型(Spiral Model)优点:优点:1.瀑布模型与原型的迭代特征结合起来,加入两种模型均忽略了的风险分析。2.能够快速开发软件的增量版本。3.不要求每一个增量
7、都是可以运行的程序。4.划分为若干个框架活动,活动也称划分为若干个框架活动,活动也称为任务区域。为任务区域。包括包括制定计划 风险分析 实施工程 客户评估第6页/共28页8.1.2 软件测试与软件开发过程的关系狭义定义测试:比如“程序设计”与“测试”之间的关系,传统上总以为程序设计在先,测试在后。这种专指测试程序代码,定义在编码之后的“测试”是一种狭义定义的测试。广义定义定义测试:这种测试活动可以在软件开发生命周期的任何阶段进行。但是,随着开发不断地进行,越到后续阶段,找出错误并改正它的代价会越大全新的软件开发模式:以测试驱动软件开发。软件测试贯穿了整个软件开发过程,软件开发生命周期的各个阶段
8、中都少不了相应的测试,这种思想与软件质量保证的出发点是一致的。第7页/共28页8.2 各种软件测试在软件开发生命周期中的位置适用于所有的软件生命周期的三个阶段适用于所有的软件生命周期的三个阶段软件规划软件规划软件开发软件开发运行与维护运行与维护在软件规划阶段中,在软件规划阶段中,主要进行软件目标的策划、主要进行软件目标的策划、可行性研究和软件的需求分析工作。可行性研究和软件的需求分析工作。软件被定义之后,软件被定义之后,进入开发阶段,主要对软件的体系架构、进入开发阶段,主要对软件的体系架构、数据结构和主要算法进行设计;数据结构和主要算法进行设计;将设计用程序语言编码实现,并进行测试。将设计用程
9、序语言编码实现,并进行测试。软件的运行与维护阶段在软件生命周期中软件的运行与维护阶段在软件生命周期中占据的比例最大。针对不同的需求,维护工作占据的比例最大。针对不同的需求,维护工作一般可以分为纠错性维护、适应性维护、一般可以分为纠错性维护、适应性维护、扩充性维护和预防性维护等不同类型。扩充性维护和预防性维护等不同类型。软件开发阶段还可细分为软件设计、编码和测试阶段软件开发阶段还可细分为软件设计、编码和测试阶段第8页/共28页8.2.1 软件规划阶段的测试 产品策划 由项目经理确定进度计划、项目范围和开发产品所需的资源规划阶段 需求分析 由产品市场开发团队根据客户提出的要求来描述产品的需求第9页
10、/共28页需求规格说明文档评审这是否是真正的需求:描述的产品是否就是要开发的产品?需求是否完备:第一个发布的版本是否需要更多的功能?需求是否兼容:在逻辑上是否矛盾?需求是否可实现?需求是否合理:在开发进度、费用、产品性能、可靠性之间存在平衡关系,这些都考虑到了吗?是否认识到应该根据实际安排一个优先级计划?需求是否可测试:从测试的角度出发,判断这 样的需 求实现的产品是否可以进行测试。文档编写是否规范,描述是否正确、完整和一致。第10页/共28页需求规格说明文档评审 在需求规格说明评审通过后,测试或质量保证人员就可以以该文档为依据编写测试计划。并以同行评审(Peer Review)的方式对测试计
11、划进行评审。评审人员应该包括项目以外的测试或质量保证人员、项目经理和开发人员(非必需)。第11页/共28页8.2.2 软件设计阶段的测试定义软件设计阶段是设计人员将软件需求转换为语言文字和图表的集合,用来描述系统结构、数据结构、算法和用户界面。根据不同的设计方法和模式,设计分为外部设计和内部设计,或者分为高层设计(或概要设计)和低层设计(或详细设计)。设计描述 外部设计主要从用户的角度对产品进行描述,内部设计则描述产品的内部工作机制。它们是并行展开,相互制约,相互要求。概要设计描述了总体上系统架构应该包含的组成元素,各个模块之间的关联。详细设计主要描述各个模块如何实现以及所用的算法和数据结构。
12、第12页/共28页8.2.2 软件设计阶段的测试由于设计依赖于需求文档,如果文档不存在、不完善或者始终处于变更之中,设计人员就需要与需求分析人员沟通,以确定软件产品应该具备什么能力。因此设计阶段也是对软件需求的深化理解和完善阶段。设设计计文文档档进进行行评评审审设计是否满足需求:设计是否满足需求:如果需求规格说明文档是非正式的,可变的如果需求规格说明文档是非正式的,可变的或是有歧义的,那么设计文档就是对产品需求的第一份正式说明。或是有歧义的,那么设计文档就是对产品需求的第一份正式说明。管理人员和市场营销人员应该从这个角度来评审文档,而不仅仅局管理人员和市场营销人员应该从这个角度来评审文档,而不
13、仅仅局限于设计本身。同时还需要建立需求和设计之间的映射关系,可以限于设计本身。同时还需要建立需求和设计之间的映射关系,可以很好地追踪软件设计和需求的关系,从而避免设计上的遗漏。很好地追踪软件设计和需求的关系,从而避免设计上的遗漏。设计是否完备:设计是否完备:它是否规定了模块间的关系,模块如何传递数据,它是否规定了模块间的关系,模块如何传递数据,异常条件下会发生什么,每个模块是否赋予了初始状态等。异常条件下会发生什么,每个模块是否赋予了初始状态等。设计是否良好:设计是否良好:能否产出高效、简洁、可测试、可维护的软件产能否产出高效、简洁、可测试、可维护的软件产品。品。设计是否可行:设计是否可行:计
14、算机能运行这么快吗?内存够吗?数据库中的计算机能运行这么快吗?内存够吗?数据库中的数据检索速度能达到这么快吗?数据检索速度能达到这么快吗?设计的错误处理程度如何。设计的错误处理程度如何。同时还要评审文档编写是否规范,描述是否正确、完整和一致。同时还要评审文档编写是否规范,描述是否正确、完整和一致。第13页/共28页评审会议通评审会议通常由会议管理者(也是召集者)主持,会议的目的在评审会议通常由会议管理者(也是召集者)主持,会议的目的在于识别出设计中存在的问题,而如何修改和设计不是会议的内容。评审人于识别出设计中存在的问题,而如何修改和设计不是会议的内容。评审人员把一系列问题带入到会议中,评审的
15、目的在于生成一个问题列表,并确员把一系列问题带入到会议中,评审的目的在于生成一个问题列表,并确认设计人员是否理解了其中的歧义或者容易混淆的问题。会议记录人员记认设计人员是否理解了其中的歧义或者容易混淆的问题。会议记录人员记录下所有达成共识的意见和遗留到下次要解决的问题。录下所有达成共识的意见和遗留到下次要解决的问题。在概要设计和详细设计评审通过后,测试或质量保证人员就可以在概要设计和详细设计评审通过后,测试或质量保证人员就可以以该文档为依据编写测试用例,并以同行评审的方式对测试用例进行评审。以该文档为依据编写测试用例,并以同行评审的方式对测试用例进行评审。评审人员应该包括项目以外的测试或质量保
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 软件 测试 开发 过程
限制150内