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