软件测试技术完整教程PPT.ppt
《软件测试技术完整教程PPT.ppt》由会员分享,可在线阅读,更多相关《软件测试技术完整教程PPT.ppt(234页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、第一章第一章 概概 述述1 本章要点本章要点 l 软件测试的发展历史;l 软件测试技术的分类方法;l 软件测试原则;l 软件测试的定义;l 软件测试同软件开发之间的关系;l 软件测试与开发模型;l 软件测试工作流程。2 本章目标本章目标 u 了解软件测试的发展历程和行业现状;u 掌握软件测试技术的分类;u 理解软件测试的目的和软件测试原则,以及了解 人们对软件测试行业的错误认识;u 掌握软件测试中的基本定义、基本知识;u 理解软件开发与软件测试的关系。31.1软件测试的发展历程及现状软件测试的发展历程及现状 1.1.1软件测试的发展历程软件测试的发展历程 20世纪50-60年代,软件仍然处于次
2、要位置,测试理论和方法的发展比较缓慢。70年代以后,软件技术的成熟和完善使得软件测试的规模和复杂度加大,软件测试也逐渐形成了一套完整的体系,逐渐走向规范化。1.1.2软件测试的现状软件测试的现状 与一些发达国家相比,国内测试工作还存在一定的差距。国内测试人员所占比例小,但是,在软件测试实现方面都是相当的,而且向产业化方向发展。4 1.2 1.2 什么是软件测试什么是软件测试 1.2.11.2.1软件测试的定义软件测试的定义 根据侧重点的不同,主要有以下三种观点:1)1983年IEEE将软件测试定义为:“使用人工或自动手段运行或测定某个系统的过程,其目的在于检验它是否满足规定的需求或是弄清预期结
3、果与实际结果之间的差别”,该定义明确地提出了软件测试以检验是否满足需求为目标。2)Myers认为:“是为了发现错误而执行程序的过程”,明确提出了“寻找错误”是测试目的。5 3)从软件质量保证的角度看:是一种重要的软件质量保证活动,其动机是通过一些经济、高效的方法,捕捉软件中的错误,从而达到保证软件内在质量的目的。测试过程中的活动包括“分析”软件(静态测试)和“运行”软件(动态测试)。也有人认为软件测试(software testing)就是在软件投入运行前,对软件需求分析、设计规格说明和编码的最终复审,是软件质量保证的关键步骤。6软件测试有两个基本职责:即验证和确认。注意:区分软件测试和软件调
4、试。1.2.21.2.2软件测试生命周期软件测试生命周期 测试的生命周期(softwaretestinglifecycle)分为几个阶段(如图1-1所示)。前三个阶段就是引入程序错误阶段;后三个阶段就是清除程序错误的阶段。7图1-1 测试生命周期8 1.2.3 1.2.3软件开发与测试模型软件开发与测试模型 下面我们将介绍几种典型的软件开发与测试模型。一、软件开发与测试一、软件开发与测试V V模型模型 在传统开发过程中测试不受重视,仅把它作为在需求分析、概要设计、详细设计及编码之后的一个阶段。尤其在瀑布模型中。如图1-2所示,在V模型中,描述了一些不同的测试级别,并说明了这些级别所对应的生命周
5、期中不同的阶段,清楚地描述了这些测试阶段和开发过程期间的对应关系。9图1-2 V模型示意图 10 V模型适用于所有类型的开发过程,但并不一定适用于开发和测试过程的所有方面。二、软件开发与测试二、软件开发与测试WW模型模型 由于各种原因,开发的每一个环节都可能产生错误,如果坚持各个阶段的技术评审,就能够尽早发现和预防错误。图1-3为软件开发与测试的W 模型,形象地说明了软件测试与开发的这种同步性。11图1-3 W模型示意图 12 应用该模型的优点在于,每个软件开发活动结束后就可以执行相应的测试,如:在需求分析结束后,就可以进行需求分析测试。三、软件开发与测试三、软件开发与测试H H模型模型 与前
6、两种模型相比,H模型充分地体现了测试过程。如图1-4所示的H 模型揭示了:1、软件测试不仅仅指测试的执行,还包括很多其他的活动。2、软件测试是一个独立的流程,贯穿产品的整个开发周期,与其它流程并发进行。3、软件测试要尽早准备,尽早执行。13图1-4 H模型示意图 4、软件测试根据被测物的不同是分层次的.不同层次的测试活动可以是按照某个次序先后进行的,但也可能是反复的。14 1.2.4 1.2.4与软件测试相关的术语与软件测试相关的术语 1.错误(Error)程序员在编写代码时会出错,我们把这种错误称之为bug。随着开发过程的进行,错误会不断的放大。2.缺陷(Default)缺陷是错误的结果,更
7、精确的说是错误的表现。3.失效(Failure)在缺陷运行时,常常会发生失效的情况。一种是过错缺陷对应的失效;一种是遗漏缺陷对应的失效。4.测试(Test)测试是一项采用测试用例执行软件的活动,在这项活动中某个系统或组成的部分将在特定的条件下运行,然后要观察并记录结果,以便对系统或组成部分进行评价。15 5.测试用例(Test Case)测试用例是为特定的目的而设计的一组测试输入、执行条件和预期的结果。6.回归测试(Regression testing)回归测试的目的是为了测试由于修正缺陷而更新的应用程序,以确保彻底修正了上一个版本的缺陷,并且没有引入新的软件缺陷。1.31.3软件测试技术分类
8、软件测试技术分类 从不同的角度,可以把软件测试技术分成不同种类,如:一、从是否需要执行被测软件的角度,可分为静态测试和动态测试。16 那些不利用计算运行被测程序,而是通过其他手段达到测试目的的方法称作静态测试。下面我们对这几种静态测试分别加以介绍:代码检查 代码走查 桌面检查 同行评分 下面我们将要介绍的黑盒测试和白盒测试就属于动态测试。二、从软件测试用例设计方法的角度,可分为黑盒测试(Black-Box Testing)和白盒测试(White-Box Testing)。17 三、按照软件测试的策略和过程分类,软件测试可分为单元测试(UnitTesting)、集成测试(IntegrationT
9、esting)、确认测试(ValidationTesting)、系统测试(SystemTesting)和验收测试(VerificationTesting)。1.41.4软件测试的目的软件测试的目的 测试真正的目的是使我们通过对软件错误的原 因和分布进行归纳,来发现并排除当前软件产品的 缺陷,对在需求和设计过程中存在的问题查缺补漏,从而确保软件产品的质量。18 GMyers给出了关于测试的一些规则,我们也可以把这些规则看作是测试的目标:1)软件测试是为了发现错误而执行程序的过程。2)测试是为了证明程序有错,而不是证明程序无错。3)一个好的测试用例在于他能发现至今未发现的错误。4)一个成功的测试是
10、发现了至今未发现的错误的测试。这里要强调的一点是,软件测试不只是软件测试人员的工作,也是软件开发人员和软件使用者的工作。19 1.51.5软件测试的原则软件测试的原则 1.5.11.5.1尽早地和不断地进行软件测试尽早地和不断地进行软件测试 IBM的研究结果表明,缺陷存在放大趋势。图1-5表示了缺陷放大模型大致状况。图1-5 缺陷放大模型 由此可见,问题发现越早,解决问题的代价就越小,这是软件开发过程中的黄金法则。20 1.5.21.5.2不可能完全的测试不可能完全的测试 对一个程序进行完全测试就是意味着在测试结束之后,再也不会发现其它的软件错误了。其实,这是不可能的,主要原因有以下几点:一、
11、不可能测试程序对所有可能输入的响应。二、不可能测试到程序每一条可能的执行路径 三、无法找出所有的设计错误 四、不能采用逻辑来证明程序的正确性 21 1.5.3 1.5.3增量测试,由小到大增量测试,由小到大 图1-7 测试资源关系图22 由小到大,指的是软件测试的粒度。无论是传统的软件测试还是面向对象的软件测试都要遵循这样的原则。如图1-7所示,多个单元组合过渡到集成测试阶段,集成测试阶段过渡到更高级别的系统测试阶段,虚线是各个测试阶段的发布基线。随着测试的逐步深入,范围的逐步扩大,测试时间、可用资源也随之增大。1.5.41.5.4避免测试自己的程序避免测试自己的程序 避免程序员测试自己的代码
12、的主要原因归纳如下:1.程序员轻易不会承认自己写的程序有错误。23 2.程序员的测试思路有局限性,在做测试时很容易受到编程思路的影响。3.多数程序员没有严格正规的职业训练,缺乏专业测试人员的意识。4.程序员没有养成错误跟踪和回归测试的习惯.1.5.5 1.5.5设计周密的测试用例设计周密的测试用例 软件测试的本质就是针对要测试的内容确定一组测试用例。测试用例至少应该包括如下几个基本信息:1、在执行测试用例之前,应满足的前提条件。2、输入(合理的、不合理的)。24 3、预期输出(包括后果和实际输出)。图1-8显示了一个典型的测试用例所应该具有的基本信息。图1-8 典型的测试用例信息25 测试用例
13、是测试工作的核心,应该尽量设计的周密细致,这样才能更好的保证测试工作的质量。下面举例来说明这一点。以一个实现登录功能的小程序为例,它允许用户选择城市和地区,输入自己的账号和密码。如图1-9所示,通过Alt-F4组合键和“Exit”按钮来终止程序,Tab键在区域中间移动。26图1-9 登录窗口下面根据组成页面的具体元素,分别从几个方面做了一些比较全面的测试用例:271.下拉框和输入框测试用例 表1-1 下拉框和输入框测试用例测试测试内容内容输输入操作入操作预预期期输输出出实际结实际结果果下拉框下拉框未和后台数据未和后台数据库绑库绑定定(显显示列表元素固示列表元素固定)定)不允不允许许列表中出列表
14、中出现现NULL现现象,固定象,固定“请选择请选择-”已和后台数据已和后台数据库绑库绑定定(显显示列表元素活示列表元素活动动)不允不允许许列表中出列表中出现现NULL现现象,固定象,固定“请选择请选择-”输输入入框框限定字符型限定字符型输输入入12、6无无#,*等等错误错误提示提示限定型数字限定型数字输输入入测试测试数据数据无无12月、月、7*、0错误错误提示提示282、功能测试 (表1-2 功能测试用例)用例应产生行为结果失败原因1.基本功能测试1.1在输入框内输入资料并且执行存储程序必须能够接受使用者的输入并且将输入值存在登录文件内1.2在输入框内不输入资料但执行储存程序必须能够检查使用者
15、输入是否为空白,同时必须能够告知使用者原因1.3检查city字段储存结果City字段输入后存入cookies1.4检查area字段储存结果Area字段输入后存入cookies储存结果1.5检查ID字段储存结果ID字段输入后存入cookies2.使用接口功能测试2.1检查输入字段的输入值必须组织使用者输入空白,同时部分字段只能输入数字2.2检查使用者接口的TabOrder所有的TabOrder必须按照正常顺序2.2检查所有的Button所有的Button必须能够起作用2.3检查所有的HotKey所有的HotKey必须能够起作用293、各种错误数据的测试表1-3 错误数据的测试用例测试内容测试内容
16、输入操作输入操作预选测试数预选测试数据据预期输出预期输出实际结果实际结果点击登录点击登录按钮按钮不完整的数不完整的数据据CityCity,areaarea,IDID,pswdpswd略略提示错误对话提示错误对话框框不正确的数不正确的数据据CityCity,areaarea,IDID,pswdpswd略略提示错误对话提示错误对话框框回车操作回车操作不完整的数不完整的数据据CityCity,areaarea,IDID,pswdpswd略略提示错误对话提示错误对话框框点击点击“退退出出”按钮按钮无无无无无无关闭当前应用关闭当前应用系统系统304、特殊测试 表1-4 特殊测试用例测试内容测试内容输入操
17、作输入操作预选测试数预选测试数据据预期输出预期输出操作焦点逃操作焦点逃逸逸连续连续TabTab切换,察看异常切换,察看异常无无焦点可准确回归焦点可准确回归当前操作窗口当前操作窗口分配内存不分配内存不足足启动多个应用程序或模拟启动多个应用程序或模拟多个程序运行多个程序运行无无是否可以正常运是否可以正常运行行网络断线网络断线切断网络连接切断网络连接无无是否可正常抛出是否可正常抛出异常异常31 1.5.6 1.5.6注意错误集中的现象注意错误集中的现象 软件缺陷的“扎堆”现象的常见形式:1、对话框的某个控件功能不起作用,可能其他控件的功能也不起作用。2、某个文本框不能正确显示双字节字符,则其他文本框
18、也可能不支持双字节字符。3、联机帮助某段文字的翻译包含了很多错误,与其相邻的上下段的文字可能也包含很多的语言质量问题。4、安装文件某个对话框的“上一步”或“下一步”按钮被截断,则这两个按钮在其他对话框中也可能被截断。32 1.5.7 1.5.7确认确认BUGBUG的有效性的有效性 有时候测试人员提交的BUG并不是真正的BUG。图1-10具体地描述了无效BUG的来源。一般由A测试人员发现的BUG,一定要由另外一个B测试人员来进行确认,如果发现严重的BUG可以召开评审会进行讨论和分析。图1-10 无效BUG来源构成图33 1.5.8 1.5.8合理安排测试计划合理安排测试计划 合理的测试计划有助于
19、测试工作顺利有序地进行,因此要求在对软件进行测试之前所作的测试计划中,应该结合了多种针对性强的测试方法、列出所有可使用资源,建立一个正确的测试目标;要本着严谨、准确的原则,周到细致地做好测试前期的准备工作,避免测试的随意性。尤其是要尽量科学合理地安排测试时间。34 图1-11 错误依赖关系1.5.91.5.9回归测试回归测试35 这些错误之间存在单纯的依赖或者复杂的多重依赖关系,如图1-11所示。其中,(a)图中的A、B 关系表达为:A错误依赖于B错误的关闭而关闭。如果多了一条路径(如(b)图中A、B、C关系),A错误依赖于B错误和C错误的同时关闭而关闭。(c)图是(a)和(b)的复合方式,因
20、程序中的错误存在着一对多,多对多的复杂关系而变得难以处理,并且有些错误关联和依赖关系处于隐性状态。1.5.101.5.10测试结果的统计和分析测试结果的统计和分析 只有对这些输出信息进行深入地统计、分析和比较,才能够正确的鉴别测试后输出的数据,给出清晰的错误原因分析报告。当输出的信息很庞大时,我们可以借助专业的测试工具。36 1.5.11 1.5.11及时更新测试及时更新测试 事实上,有可能导致测试失败的原因还有很多,可大致归纳为如下几点:1、测试团队管理者失职;2、测试团队中沟通不好;3、测试团队和项目团队沟通不良;4、测试过程中,执行角色无准确定义;5、测试团队缺乏良好的培训。37 1.6
21、 1.6软件测试工作流程软件测试工作流程 一般的软件测试总体工作流程如图1-12所示:图1-12 软件测试工作总体流程图38 1、需求阶段 需求阶段是软件测试活动的前提。需求阶段测试工作流程如图1-13所示:图1-13 需求阶段测试活动流程图392、设计&编码阶段测试工作流程 图1-14 设计&编码阶段测试流程图40 这一环节以模块为单位循环:单元测试方案制定编码单元测试是否通过测试抽检是否通过,重新编写没有通过单元测试和测试抽检的代码。最终形成一份单元测试总结报告。具体流程如图1-14所示。3、集成测试、系统测试和验收测试阶段 该测试阶段流程如图1-15所示:41 图1-15 集成测试、系统
22、测试和验收测试阶段流程图42 1.7 1.7软件测试中的误区软件测试中的误区 误区1 调试和测试是一样的 误区2 软件测试在软件开发过程中并不重要 误区3 在软件开发结束之后进行测试 误区4 过分依赖Beta测试 误区5 过分依赖自动化测试 误区6 测试是可穷尽的 误区7 测试是证明软件的正确性 误区8 可以忽略测试的设计 1.81.8一个贯穿全文的例子一个贯穿全文的例子 电厂两票管理系统电厂两票管理系统 43 1.8.1 1.8.1系统简介系统简介 操作票、工作票(简称两票)是“电业(电厂)安全工作规程”中的核心内容之一,对保证电业安全生产具有重要的作用。操作票是保证正确电气倒闸(热机)操作
23、的重要环节和前提条件,使用操作票的目的是为了保障人身与设备的安全,确保电气设备倒闸操作的正确性,防止电气误操作事故发生。工作票是保证电气(电厂设备)检修工作安全的重要措施,是检修人员在运行设备上或运行区域内进行检修和试验工作,以及做可能影响设备的正常运行或备用状态的其它工作的重要书面依据。“两票”的办理过程基本上都是开票、各部门负责人或三种人审批签字、工作结束、部门或厂部检查审核这样的一种线性办理过程。44 电力部门分为水电、火电、供电三种类型,各厂、局要处理的两票类型通常有:水电厂:电气一种工作票、电气二种工作票、水力机械工作票、一级动火工作票、二级动火工作票、电气倒闸操作票、继保安措票、脚
24、手架工作单、水力机械操作票、溢洪闸门操作票 火电厂:电气一种工作票、电气二种工作票、水力机械工作票、一级动火工作票、二级动火工作票、电气倒闸操作票、继保安措票、脚手架工作单、热力工作票 供电局:电气一种工作票、电气二种工作票、水力机械工作票、一级动火工作票、二级动火工作票、电气倒闸操作票、继保安措票、脚手架工作单、45 一种工作票、线路二种工作票。为了使读者更好的了解两票系统以及后面各章节的内容,在这里对一些电力系统专业术语作如下解释:一次图:电气主接线是由高压电器通过连接线,按其功能要求组成接受和分配电能的电路,成为传输强电流、高电压的网络,故又称为一次接线。那么用规定的设备文字和图形符号并
25、按工作顺序排列,详细地表示电气设备或成套装置的全部基本组成和连接关系的单线接线图,成为主接线电路图,这里简称为一次图。二次图:在电力系统中,凡监视、控制、测量以及起保护作用的设备,如机电保护、控制和信号装 46 置等,皆属于二次设备。二次接线就是由二次设备构成的回路。这里我们就把二次设备接线图简称为二次图。分厂:发电厂通常由多个分厂组成,其中电气分厂、汽机分厂和锅炉分厂是发电厂的几个重要的分厂。电气设备:为满足生产的需要,发电厂中安装有各种设备。通常把生产和分配电能的设备称为一次设备,具体包括如下几种:生产和转换电能的设备;接通或断开电路的开关电器;限制故障电流和防御过电压的电气;接地装置;载
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 软件 测试 技术 完整 教程 PPT
限制150内