软件测试第3章静态测试技术

整理文档很辛苦,赏杯茶钱您下走!

免费阅读已结束,点击下载阅读编辑剩下 ...

阅读已结束,您可以下载文档离线阅读编辑

资源描述

软件测试第3章静态测试技术1.静态测试技术概述1概念:1.1定义:是指不通过执行被测程序而对软件产品(包括工作产品)进行分析的测试活动测试对象:需求规约、分析和设计规约、代码街开发过程中的各种文档1.2目的:一般是对工作产品进行确认(例如设计规格说明是否正确实现了所有的系统需求),并对设计的质量进行验证1.3优点:静态测试的成本低,效率高,可以在开发早期发现软件中的缺陷和错误,是有效的测试技术。2原则:2.1所有违背编码标准的因素都要进行评审,例如标识符如何命名,代码如何缩进2.2对代码的复杂度进行评审,代码要求易简不易繁,提高可读性,便于阅读,代码复杂度要降低2.3审查并删除不可用的代码、未被调用的过程和未使用的变量2.4报告所有类型的数据流异常常见的数据流异常变量在初始化前使用(未初始化就使用),未定义先使用被赋值的变量一直末被使用:变量是多余无意义变量在两次赋值之间末被使用:第一次赋值对程序而言是无意义参数不匹配:如果参数个数,类型,顺序不匹配,函数调用则失败可疑的类型转换:例如实型数据转为整型,小数会丢失,不为零的数据变为零,造成运算错误3静态测试方法分类:静态测试人工方法(评审)由测试人员手工逐步执行所有的活动,并观察每一步是否成功完成代码检查桌面检查代码审查走查正规技术评审自动方法使用一组测试工具对被测软件进行分析和验证说明:运行测试工具被测试软件自己不运行而是被测试工具分析,作为测试工具输入源2.代码检查1.概念:主要检查代码与设计的一致性,代码对标准的遵循、可读性,代码逻辑表达的正确性,代码结构的合理性等2.代码检查类型:2.1桌面检查程序员在程序通过编译后,对自己编写的程序代码进行分析、检验,补充相关文档,目的是发现程序中的错误和缺陷2.2代码审查2.3代码走查3代码审查:3.1由若干程序员和测试员组成一个审查小组,通过阅读、讨论和争议,对程序进行静软件测试态分析3.2审查步骤第一步:准备:事先把审查材料(如设计规格说明、控制流程图、程序文本以及相关的要求和规范)分发给小组成员,准备一份常见的错误和缺陷清单(称为检查表),小组成员充分阅读这些材料第二步:代码审查会:程序员介绍程序逻辑,审查小组成员提问、讨论、审查错误和缺陷是否存在3.3GB/T15532-2008《计算机软件测试规范》附录A介绍了静态测试方法-代码审查3.3.1测试内容:检查代码和设计的一致性;检查代码执行标准的情况;检查代码逻辑表达的正确性;检查代码结构的合理性;检查代码的可读性3.3.2组织:由四人以上组成,分别为组长、资深程序员、程序编写者与专职测试人员3.3.3过程:准备阶段,程序阅读,会议审查,形成报告3.3.4代码审查单内容:寄存器使用,格式,入口和出口连接,程序语言的使用,存储器使用,测试与转移,性能,可维护性,逻辑,软件等4代码走查:4.1走查是一种非正式评审,被查工作产品的开发者向其他相关人员描述其产品并征求意见属于一种即兴的审查,如编写了某一代码,直接与其他编程人员讨论,一般准备一组测试用例,人工模拟计算机运行软件;虽然笨拙,但发现错误的概率很高,在发现错误的同时能找到解决的方法。4.2代码走查的步骤与代码审查的步骤相似4.3走查的参与者模拟计算机运行过程来人工执行少量的、用于人工跟踪的测试用例,其目的是质疑隐藏在源代码之后的逻辑和基本假设4.4走查的主要目标是对故障进行检测和文档化,而不是对开发者的能力进行评价5走查过程:5.1计划走查会议5.2走查产品5.3走查会议5.4解决问题5.5记录走查5.6返工产品6走查类型:6.1规格说明走查规格说明走查包括:系统规格说明、项目计划和需求分析目标是检查规格说明中存在的问题以及不准确、不清晰和冗长之处参与者:用户、高级分析员、项目分析员对象:数据流图、数据字典、实体关系图等6.2设计走查设计走查包括初步设计和详细设计目标是检查设计结构中的缺陷、薄弱环节、错误和冗余参与者:用户、分析人员、高级设计师、项目设计人员对象:结构图、详细设计文档等6.3代码走查(使用人工方法模拟计算机运行软件)目标是检查代码中的错误以及违背标准、不清晰、不一致的地方参与者:编码人员、项目程序员、设计人员和外部程序员对象:代码列表、编译器列表等6.4测试走查软件测试测试走查包括测试计划和测试步骤目标是检查测试文档中不充分、不完整和不清晰的地方参与者:项目程序员、测试人员、分析人员和设计人员对象:测试计划、测试步骤、测试数据示例等3代码检查:代码检查的内容事项检查变量的交叉引用表检查标号的交叉引用表检查子程序、宏、函数等价性检查常量检查标准检查风格检查比较控制流选择、激活路径对照程序的规格说明,详细阅读源代码,比较实际代码与期望代码的差异,从中发现程序的问题和错误补充文档3.正式评审(正规评审)1概述:正式评审在软件开发生存周期中每个阶段结束时实施,采用正式的会议评审方式,通过正式评审的活动标志着该活动到达了一个里程碑,该活动的制品也就成为一个基线;正式评审也可以在出现严重问题的时候实施2两种类型:管理评审和技术评审a)项目管理评审的任务是针对适用的项目计划、进度安排、标准和指南进行项目状态的评价b)技术评审的任务是举行技术评审以评价正在考虑中的软件产品或服务,并提供相关证据(如它们是完备的、符合标准和规范的等)3.正式技术评审内容:3.1评审会议由评审会主席和若干名评审员组成,参加者大多是与评审内容相关的技术专家,参加人员不宜太多,通常为3~5人必要时(如需求评审)可请用户代表参加:是否与用户需求一致3.2评审记录指派专人记录会上提出的所有问题会议结束后将其整理成一份“评审问题列表”并存档3.3评审报告评审会结束时应形成评审总结报告,总结报告应指明被评审的制品,参加评审的人员,评审中发现的问题以及评审的结论评审总结报告不必很长(通常一页纸就够了),而“评审问题列表”可作为评审总结报告的附件4正式技术评审过程:4.1计划4.2预备会4.3会前准备(自评审)4.4评审会4.5修正错误软件测试4.6复审4.7复核5正式技术评审的指导原则:5.1评审产品,而不是评审生产者(对事不对人,不是对程序员的评判)5.2制定议事日程且遵守日程5.3限制争论和辨驳(主要是发现问题,不是为了解决问题,解决问题应放到评审会以后处理)5.4对各个问题都发表见解,但不要试图解决所有记录的问题5.5做书面笔记5.6限制参与者人数并坚持事先做准备5.7为每个可能要评审的工作制品建立一个检查表5.8为正式技术评审分配资源和时间5.9对所有评审者进行有意义的培训5.10评审以前所做的评审6正式技术评审的检查表:6.1根据不同的评审活动(如软件需求评审、软件设计评审、源代码评审等)设计不同的检查表6.2例如,软件设计评审检查表编号检查项是否1设计特征是否与需求一致?2设计是否实现了每个程序接口要求的程序行为?3是否包含了需要的处理步骤?4是否指明了每个决策点的可能结果?5是否在设计中考虑了所有预期的情形和条件?6是否能确保设计配置变更的完整性?7每个程序是否只有一个功能?8设计是否具有良好的结构化?9是否避免了不必要的设计复杂性和表示方式?

1 / 4
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功