软件工程-质量概念课件.ppt

上传人:飞****2 文档编号:70508332 上传时间:2023-01-21 格式:PPT 页数:43 大小:2.73MB
返回 下载 相关 举报
软件工程-质量概念课件.ppt_第1页
第1页 / 共43页
软件工程-质量概念课件.ppt_第2页
第2页 / 共43页
点击查看更多>>
资源描述

《软件工程-质量概念课件.ppt》由会员分享,可在线阅读,更多相关《软件工程-质量概念课件.ppt(43页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、第10章质量概念软 件 工 程主要内容什么是软件质量产品度量框架软 件 工 程10.1 什么是质量现如今软件质量仍然是一个问题,每年耗费了大量的资金客户责备开发人员,认为粗心的实践导致低质量的软件。开发人员责备额客户,认为不合理的交工日期以及连续不断的变更使开发人员在还没有完全验证时就交付了软件。这都是问题所在。软 件 工 程10.1 什么是质量质量是什么不好清楚的定义质量涵盖很多观点在最一般的意义上,软件质量可以这样定义:在一定程度上应用有效的软件过程,创造有用的产品,为生产者和使用者提供明显的价值。软 件 工 程10.1 什么是质量软件质量是对明确陈述的功能和性能需求、明确记录的开发标准以

2、及对所有专业化软件开发应具备的隐含特征的符合度。软 件 工 程Gavin的质量维度Gavin建议采用多维的观点考虑质量:性能质量内容、功能和特性是否交付特性质量用户惊喜特性是否提供可靠性所有的特性和能力是否提供符合性标准、编码惯例耐久性是否能对软件进行维护和改正适用性可否短时间内完成维护和改正审美难量化,但不可缺感知偏见或好的声誉软 件 工 程10.1 什么是质量McCall 的质量因素影响软件质量的因素可以分为两大类:可以直接测量的因素(如:测试期间发现的错误)只能间接测量的因素(如:易用性和可维护性)所有情况下,度量都必须发生。软 件 工 程软 件 工 程McCall、Richards 和

3、 Walters对软件质量的分类:正确性:程序满足其需求规格说明和完成用户目标的程度。可靠性:期望程序以所要求的精度完成其预期功能的程度。效率:程序完成其功能所需计算资源和代码的数量完整性:对为授权的人员访问软件或数据的可控程度。易用性:对程序学习、操作、准备输入和解释输出所需要的工作量。可维护性:定位和修复程序中的一个错误所需要的工作量。灵活性:修改一个运行的程序所需的工作量。可测试性:测试程序以确保它能完成预期功能所需要的工作量。可移植性:将程序从一个硬件和软件系统环境移动到另一个所需要的工作量。可复用性:程序(或程序的一部分)可以在另一个程序中使用的程度。可操作性:将一个系统连接到另一个

4、系统所需要的工作量。软 件 工 程10.1 什么是质量ISO质量因素:ISO 9126标准标准标识了六个关键的质量属性:功能性,子属性:适应性、准确性、互操作性、依从性和安全性可靠性,子属性:成熟性、容错性和可恢复性易用性,子属性:可理解性、易学习性和可操作性效率,子属性:时间表现和资源表现可维护性,子属性:可分析性、可修改性、稳定性和可测试性可移植性,子属性:适应性、可安装性和可替代性。软 件 工 程10.1 什么是质量定向质量因素软件团队可以提出一套质量特征和相关的问题以调查满足每个质量因素的程度。为了进行评价,需要说明白具体的、可测量的属性细化。参看教材P218软 件 工 程直觉直觉界面

5、布局易于理解吗?界面操作容易找到和上手吗?界面使用了可识别的隐喻吗?输入安排地节约敲击键盘和点击鼠标吗?界面符合个重要原则吗?美学的运用有助于理解和使用吗?软 件 工 程效率:界面的布局和风格可以使用户有效地找到操作和信息吗?一连串的操作(或数据输入)可以用简单动作达到吗?输出的数据和显示的内容能被立即理解吗?分层操作是否组织得能使用户完成某项工作所需导航的深度更小?软 件 工 程健壮性:如果输入了规定边界上的数据或恰好在规定边界外的数据,软件能识别出错误吗?更为重要的是,软件还能继续运行而不出错或性能不下降吗?界面能识别出常见的可识别的错误或操作操作,并能清晰地指导用户回到正确的轨道上来吗?

6、当发现了错误的情况(与软件功能有关),界面是否提供有用的诊断或指导?软 件 工 程丰富性界面是否能按照用户的特定要求进行客户化?界面是否提供宏操作以使用户将单个的行为或命令当做一连串的常用操作?软 件 工 程10.1 什么是质量过渡到量化观点我们可以提出一组应用于软件质量评估的软件度量。在所有的情况下,这些度量表间接的测度(从不真正测量质量,而是测量质量的一些表现)软 件 工 程10.2 软件质量困境“足够好”的软件?成本高,可能错失市场机会“足够好”可以起作用,但只是对于少数几个公司,而且只是在有限的几个应用领域。软 件 工 程10.2 软件质量困境质量成本表面上看,质量是有成本的,但是缺乏

7、质量也要成本。既要了解实现质量的成本,也要了解低质量软件的成本。为了了解这些费用,一个组织必须收集度量数据,为目前的质量成本提供一个基准软 件 工 程10.2 软件质量困境质量成本可以分为:预防成本管理、技术活动、测试、培训评估成本技术评审、收集、估算、测试和调试失效成本内部失效成本和外部失效成本软 件 工 程10.2 软件质量困境软 件 工 程风险-质量低劣导致风险,其中一些非常严重疏忽和责任到了交付时,互相抱怨质量和安全-没有表现出高质量的软件比较容易被攻击管理活动的影响决策对软件质量有重大影响估算决策如果交付日期不合理,检查立场很重要进度安排决策构件之间有先后依赖关系,造成有些缺陷发现晚

8、,影响质量面向风险的决策当风险变成现实,质量水平必然下降软 件 工 程10.3 实现软件质量1、软件工程方法采用适当的分析和设计方法2、项目管理技术进度管理、风险规划、变更管理等3、质量控制如检查代码、一系列的测试步骤、测量等4、质量保证如审核和包噶,评估质量控制过程的有效性和完整性软 件 工 程10.4 微软软件质量测试常用度量1.产品设计规范(Spec或设计文档)质量状态2.缺陷(bug)数据有关度量3.测试案例度量4.测试规范度量5.测试过的系统数量6.自动化测试度量7.CodeCoverage(代码覆盖)8.单一功能测试验收质量度量软 件 工 程1.产品设计规范质量状态分类常用的五种状

9、态一页(One page)用于安排时间和分配人员草稿(Draft)用于提出疑问和初步设想以供讨论审阅(Review)有所有的设计技术细节,可以供审阅提交审核会(Inspection)所有的设计技术细节到位、没有明显遗留疑问、漏洞等开始编码(Coding)开发人员可以开始编写代码来实现该设计功能规范软 件 工 程产品设计规范质量到位状况五种状态中各占的%是多少?按事先计划日程完成的比例是多少?多少%开发人员至少有一个指派给他的功能可以进行编码?软 件 工 程2.缺陷统计数据的度量所有缺陷数量的时间走势或趋势统计(Bug Trends By Time)未被处理的缺陷按照严重程度的统计(Active

10、 Bugs By Severity)未被处理的缺陷按照优先程度的统计(Active Bugs By Priority)未被处理的缺陷数量的时间走势或趋势统计(Active Bugs Over Time)所有的缺陷按照严重程度的统计(All Bugs By Severity)新被发现的缺陷按严重程度的统计(Opened Bugs By Severity)已处理的缺陷按照严重程度的统计(Resolved Bugs By Severity)被修复的缺陷按照严重程度的统计(Fixed By Severity)软 件 工 程时间时间缺缺陷陷数数量量所有的缺陷按照严重程度的统计所有的缺陷按照严重程度的统计

11、(All Bugs By Severity)软 件 工 程2.缺陷统计数据的度量(续)已发现缺陷的数量和已修复的缺陷的数量的比率(Fixed/Found)。也被称为修改率或纠错率(Fix Rate)未处理的缺陷数量和已处理的的缺陷数量的比率(active/resolved)已处理的被修复的缺陷数量和已处理的缺陷数量的比率(Resolved as Fixed/resolved)重新被激活的已修复的缺陷数量(Bug re-activation rate)通过测试找到的缺陷的统计(Bugs opened by testing activity)软 件 工 程2.缺陷统计数据的度量(续)不同语言版本缺

12、陷数量的统计(Bugs opened by Language version)被报告存在缺陷的各功能统计(Where your bugs were found)处理缺陷的平均时间的统计(Average Time to Resolve)关闭缺陷的平均时间的统计(Average Time to Close)被处理缺陷的不同结论统计(Resolved Bugs By Resolution)软 件 工 程里程碑编程阶段缺陷变化趋势软 件 工 程3.测试案例度量运行测试案例数量和通过测试的案例数量之比不同产品开发阶段该比率变化测试案例包括的范围运行测试案例的频率有测试案例的功能数量软 件 工 程4.测试

13、规范度量测试规范数量和所有功能数量之比满足撰写要求的测试规范数量和所有测试规范数量之比必要的内容遗漏的比率测试规范测试规范:微软把针对怎样测试某功能的,有细分功微软把针对怎样测试某功能的,有细分功能后的具体测试条例等细节的测试文档叫做测试规范能后的具体测试条例等细节的测试文档叫做测试规范(Test Design Specification 或简称或简称 TDS)。)。软 件 工 程5.测试过的系统数量所支持的不同语言系统的总数与测试过的语言系统数量所支持系统的总数与测试过的系统数量Windows 2000(SPx)Windows XP(SPx)Windows 2003 Server(SPx)T

14、ablet PC新的系统平台软 件 工 程6.自动化测试度量测试的可自动化程度能自动化的和实现自动化的比率运行通过的自动化脚本比率不同产品开发阶段该比率变化软 件 工 程7.Code Coverage(代码覆盖)代码覆盖度量定义和目的代码覆盖种类代码覆盖的有效使用开发人员:单元测试(unit testing)测试人员:系统测试(system testing)和自动化测试软 件 工 程代码覆盖是什么?动态白盒测试评价技术已经执行(测试)了什么(what has been executed)没有执行的(测试)有什么 what has not been executed and still rema

15、ins to be tested.需要有源代码内部辅助工具软 件 工 程使用代码覆盖度量的目地经验总结:大约的20%代码囊括缺陷总数的80%目的不是要达到某个神奇的数字,而是要发现测试中的漏洞达到比较广泛的覆盖率相对容易,但要达到100%覆盖常需要多得多的成本 平均目标 65%理想目标 75%软 件 工 程代码覆盖度量种类1.代码函数覆盖数量2.代码运行使用到的功能覆盖数量3.代码数据种类覆盖数量4.代码函数条件覆盖数量5.代码通路(path)覆盖数量软 件 工 程代码覆盖结果分析软 件 工 程使用代码覆盖度量改进测试代码覆盖度量只能揭示测试的漏洞,并不能直接改进测试 为什么有些代码没有执行到

16、?脚本运行时执行到了代码不意味着测试的深度和全面性先查功能代码覆盖率,再计划写自动化脚本的优先顺序撰写测试用例已覆盖所有要测试的功能行为,然后编写自动化脚本加以验证 添加新自动化脚本覆盖找到的漏洞软 件 工 程使用代码覆盖度量结果分析没有覆盖代码的可能原因和改进措施:遗漏的功能行为:追加测试程序中有死角代码,没有功能行为可以执行该代码:删除?很难模拟的出错条件:可否有其他方法?过时的功能规范?-更新功能规范软 件 工 程8.单一功能测试验收质量度量预先计划的详细测试:100%完成?自动化测试覆盖率:65%?自动化测试运行结果:0%失败率?发现缺陷的难易程度:4小时发现缺陷2缺陷严重度和数量变化趋势:近期无高严重度缺陷功能稳定程度:近期代码无需改变、自动化运行一直保持100%通过软 件 工 程使用软件质量度量的注意事项和建议应当加以分析后挑选适当度量不应作为唯一的测试质量衡量标准考虑人为因素和不定性因素的影响同一产品不同功能也应使用统一衡量标准分析度量结果以指导测试和开发过程研发适合自己产品使用的质量度量

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 教案示例

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁