黑盒测试课件.pptx
- 【下载声明】
1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
3. 本页资料《黑盒测试课件.pptx》由用户(晟晟文业)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 黑盒 测试 课件
- 资源描述:
-
1、 第二部分 黑盒测试 测试分类黑盒测试和白盒测试静态测试(检查和审阅)和动态测试(运行和使用软件)静态黑盒测试 对产品说明书进行高级审查 对产品说明书低级测试技术黑盒测试w黑盒测试着眼于程序外部结构,不考虑内黑盒测试着眼于程序外部结构,不考虑内部逻辑结构,主要针对软件界面和软件功部逻辑结构,主要针对软件界面和软件功能进行测试。能进行测试。w注重于测试软件的功能需求,主要试图发现下列几类错误:是否有不正确或遗漏了的功能在接口上,能否正确地接受输入数据,能否产生正确地输出信息访问外部信息是否有错性能上是否满足要求界面是否错误,是否不美观初始化或终止错误“黑盒”的两种基本方法w黑盒测试有两种基本方法
2、,即通过测试和失败测试。w在进行通过测试时,实际上是确认软件能做什么,而不会去考验其能力如何。软件测试员只运用最简单,最直观的测试案例。在设计和执行测试案例时,总是先要进行通过测试。在进行破坏性试验之前,看一看软件基本功能是否能够实现。这一点很重要,否则在正常使用软件时就会奇怪地发现,为什么会有那么多的软件缺陷出现?w在确信了软件正确运行之后,就可以采取各种手段通过搞“垮”软件来找出缺陷。纯粹为了破坏软件而设计和执行的测试案例,被称为失败测试或迫使出错测试。黑盒测试的优、缺点黑盒测试的优点有:1)比较简单,不需要了解程序内部的代码及实现;2)与软件的内部实现无关;3)从用户角度出发,能很容易的
3、知道用户会用到哪些功能,会遇到哪些问题;4)基于软件开发文档,所以也能知道软件实现了文档中的哪些功能;5)在做软件自动化测试时较为方便。黑盒测试的缺点有:1)不可能覆盖所有的代码,覆盖率较低,大概只能达到总代码量的30%;2)自动化测试的复用性较低。功能性测试概述w任何程序都可以看作是将从输入定义域取值映射到输出值域的函数w将系统看成黒盒,又称为黒盒测试w黒盒的实现是不需要了解的,只需要知道输入和预期输出w软件功能性测试就是通过大量的测试用例来检验软件的运行效果。功能性测试模型输入输出黒盒内部实现不可见测试用例测试用例定义w测试用例的定义:(1)测试用例是为特定的目的而设计的一组测试输入、执行
4、条件和预期的结果。(2)测试用例是执行的最小实体。w测试用例的特征:(1)最有可能抓住错误的;(2)不是重复的、多余的;(3)一组相似测试用例中最有效的;(4)既不是太简单,也不是太复杂。测试用例定义w测试用例的代表性 能够代表并覆盖各种合理的和不合理的、合法的和非法的、边界的和越界的以及极限的输入数据、操作和环境设置等。w测试结果的可判定性 即测试执行结果的正确性是可判定的,每一个测试用例都应有相应的期望结果。w测试结果的可再现性 即对同样的测试用例,系统的执行结果应当是相同的。功能性测试的优点w功能性测试与软件如何实现无关,如果实现发生变化,功能性测试用例仍然可用(可重用性,面向回归测试)
5、w测试用例开发可以与软件开发同时进行,可节省软件开发时间,通过软件的用例(use case)就可以设计出大部分功能性测试用例功能性测试的缺点w测试用例数量较大w测试用例可能产生很多冗余w功能性测试的覆盖范围不可能达到100%功能性测试的方法 黑盒测试主要是通过将“功能分解”,然后再按照以下方法来设计测试用例。w等价类划分w边界值分析w因果图法w决策表法w其他测试方法黑盒测试方法等价类划分w等价类是指某个输入域的子集合 w在该子集合中,各个输入数据对于揭露程序中的错误都是等效的,子集合中包含的元素要么全部被正确处理,要么全部都没有被正确处理。因此,可以把全部的输入数据划分成若干的等价类,在每一个
6、等价类中取一个数据来进行测试。这样就能以较少的具有代表性的数据进行测试,而取得较好的测试效果。等价类划分w等价类划分是将程序的输入域(较多见)或输出域(较少见)的不同区间划分为不同的数据类,以便导出测试用例w每个等价类所揭示的程序错误都是等价的w要求此方法的测试用例能各自发现一类错误,从而减少必须开发的测试用例数 w测试某等价类的代表值就是等效于对于这一类其它值的测试。w例如:程序在输入小于4的数得到结果5,那么使用2还是3或者都是一样的等价类划分w等价类划分法是一种重要的、常用的黑盒测试方法,它将不能穷举的测试过程进行合理分类,从而保证设计出来的测试用例具有完整性和代表性。w举例:设计这样的
7、测试用例,来实现一个对所有实数进行开平方运算(y=sqrt(x))的程序的测试。w思考方向:由于开平方运算只对非负实数有效,这时需要将所有的实数(输入域x)进行划分,可以分成:正实数、0 和 负实数。假设我们选定+1.4444代表正实数,-2.345代表负实数,则为该程序设计的测试用例的输入为+1.4444、0 和-2.345。等价类分类w有效等价类 对于程序的需求说明来说是合理的,有意义的输入数据所构成的集合利用它可以检验程序是否实现了预期的功能和性能(确认过程)w无效等价类 对于程序的需求说明来说是不合理的,没有意义的输入数据所构成的集合 利用它可以检验程序对于无效数据的处理能力(验证过程
8、)等价类划分w数学含义A=x=B C=y=D问题1:例子中共有多少个等价类?有效的几个,无效的几个?问题2:写出这些等价类,这些等价类是否可以合并?问题3:最好用多少个数据来测试?测试数据是否可以减少?确立等价类的原则 w严格的,可以按照变量来划分有效和无效等价类。即:-1-先按照X来划分有效等价类和无效等价类,然后再按照Y来划分有效等价类和无效等价类-2-最后再形成相应的测试用例。wX:有效等价类为:A=x=B;无效等价类为:xA和Bx两个无效等价类wY:有效等价类为:C=y=D;无效等价类为:yC和D=1&=50”两个无效等价类为“50”一个学生每学期只能选修13门课 有效等价类:选修13
9、门 无效等价类:不选 或 选修超过3门确立等价类的原则w如果输入条件是一个布尔量,则可以确立一个有效等价类和一个无效等价类 w如果规定了输入数据的一组值,而且程序要对每一个输入值分别进行处理,这时要对每一个规定的输入值确立一个有效等价类,而对于这组值之外的所有值确立一个无效等价类 确立等价类的原则w如果规定了输入数据必须遵守的规则,则可以确立一个有效等价类(即遵守规则的数据)和若干无效等价类(从不同角度违反规则的数据),例如:测试密码域,要求密码必须是数字或字母 有效等价类为“密码是数字和字母的组合”(还可以细分)无效等价类为“密码包括中文”、“密码包括其它符号”等w如果确知已划分的等价类中的
10、各元素在程序中的处理方式不同(例如字母还要区分大小写等),则应进一步划分成更小的等价类 等价类测试用例设计w在设计测试用例时,应同时考虑有效等价类和无效等价类测试用例的设计。w根据已列出的等价类表可确定测试用例,具体过程如下:(1)首先为等价类表中的每一个等价类分别规定一个唯一的编号。(2)设计一个新的测试用例,使它能够尽量覆盖尚未覆盖的有效等价类。重复这个步骤,直到所有的有效等价类均被测试用例所覆盖。(3)设计一个新的测试用例,使它仅覆盖一个尚未覆盖的无效等价类。重复这一步骤,直到所有的无效等价类均被测试用例所覆盖。w?3的顺序是否可以和2颠倒?w?123好还是132好?为什么?等价类测试用
11、例设计w针对是否对无效数据进行测试,可以将等价类测试分为 标准等价类测试和健壮等价类测试。w标准等价类测试不考虑无效数据值,测试用例使用 每个等价类中的一个值。w健壮等价类测试主要的出发点是考虑了无效等价类。对有效输入,测试用例从每个有效等价类中取一个值;对无效输入,一个测试用例有一个“无效值”,其他值均取“有效值”。健壮等价类测试存在两个问题:(1)需要花费精力定义无效测试用例的期望输出 (2)对强类型的语言没有必要考虑无效的输入,程序可以自己检测。举例1(保险费率计算)按照输入域划分等价类的例子。w某保险公司承担人寿保险,该公司保费计算方式为:保费=投保额*保险率,保险率依点数不同而有别,
12、10点以上(含10点)费率为0.6%,10点以下费率为0.1%w点数的计算是年龄、性别、婚姻、抚养人数所得的点数的总和w输入:年龄、性别、婚姻、抚养人数w输出:保险率输入数据说明 年龄20396点40594点99以下59以上、20以下1以上2点性别男5点女3点婚姻已婚3点未婚5点抚养人数1人扣0.5点最多扣3点(四舍五入)第一步:输入和输出变量确认按照输入域划分等价类的例子。w输入:年龄、性别、婚姻、抚养人数w输出:保险率w等价类划分原则:按照输入变量来确认等价类(有效等价类和无效等价类)第二步:等价类划分输入年龄有效等价类2039(6点)(1)4059(4点)(2)6099、119(2点)(
13、3)无效等价类空白(未知)(4)99(未知)(6)包含非数字字符(未知)(7)性别有效等价类男(5点)(8)女(3点)(9)婚姻有效等价类已婚(3点)(10)未婚(5点)(11)是否可以有更多无效等价类?第二步:等价类划分输入抚养人数有效等价类12(1点)(12)34(2点)(13)4(3点)(14)无效等价类空白(未知)(15)=10点(0.6%)(18)10点(0.1%)(19)第三步:设计测试用例按照输入域划分等价类的例子。1、设计测试用例,尽可能的覆盖尚未覆盖的有效等价类。w(1)(8)(10)(12)w(2)(9)(11)(13)w(3)(8)(10)(14)2、设计测试用俐,使得每
14、一个新设计的测试用例只包含一个无效等价类,其他的选择有效等价类。w(4)(8)(10)(12)w(5)(9)(11)(13)w(6)(8)(10)(14)w(7)(8)(10)(14)w(1)(8)(10)(15)w(2)(9)(11)(16)w(3)(8)(10)(16)说明:在设计无效部分的测试用例的时候,有效等价类部分,可以任意选择。第四步:选取测试用例用例编号输入输出备注年龄性别婚姻抚养人数保险率122男已婚10.6%(1)(8)(10)(12)(18)13点245女未婚40.1%(2)(9)(11)(13)(19)8点365男已婚80.1%(3)(8)(10)(14)(19)7点4空
15、白男未婚1错误(4)5-1男未婚2错误(5)6122男未婚8错误(6)7“tt1”女已婚1错误(7)822女已婚空白错误(15)922女已婚-1错误(16)1022女未婚“ct2”错误(17)举例2(三角形问题)按照输出域划分等价类的例子。w1、输入3个整数变量a、b、cw2、a、b和c均在1100之间w3、a、b和c任意2个加起来大于第三个w4、测试是否为等边三角形、等腰三角形、一般三角形和非三角形。第一步:输入和输出变量确认按照输入域划分等价类的例子。w输入:三个变量(a、b、c);a、b和c都在1到100之间。w输出:是否为三角形或各类三角形?分析:输入域较为复杂,很难明晰界定。输出域则
16、较为清晰。w等价类划分原则:按照输出变量来确认等价类(有效等价类和无效等价类)第二步:等价类划分输出域有效等价类等边三角形(1)等腰三角形(2)一般三角形(3)非三角形(4)a无效等价类100(6)b无效等价类100(8)c无效等价类100(10)增加的测试用例思考1、什么情况下按照输入域来设计测试用例?什么情况下按照输出域来设计测试用例?2、等价类划分在我们编程过程中对哪些模块比较有效?为什么?A、录入模块;B、查询模块;C、报表模块;D、算法模块;E、逻辑处理模块。课堂实际应用:有一个员工管理系统,现对其录入模块进行测试。其中,人员信息包括:1、编号:必须有,系统自动编号;2、姓名:必须有
17、,要求为不超过5个汉字;3、身份证:必须有,长度为15或18位置,末尾为数字或X,注意大小写;4、邮箱:要么为空白,输入必须包含和.5、年龄:18-80之间的数字6、住址:可以空白注意:如果录入正确,则提示录入成功,录入错误,则提示数据不对。要求:1、确认输入域和输出域;2、划出有效等价类和无效等价类;3、给出测试用例的个数。4、请大家上来介绍自己的划分。边界值分析w边界值分析法就是对输入或输出的边界值进行测试的一种黑盒测试方法。通常边界值分析法是作为对等价类划分法的补充,这种情况下,其测试用例来自等价类的边界。w为什么使用边界值分析法?无数的测试实践表明,大量的故障往往发生在输入定义域或输出
18、值域的边界上,而不是在其内部。因此,针对各种边界情况设计测试用例,通常会取得很好的测试效果。w怎样用边界值分析法设计测试用例?(1)首先确定边界情况。通常输入或输出等价类的边界就是应该着重测试的边界情况。(2)选取正好等于、刚刚大于或刚刚小于边界的值作为测试数据,而不是选取等价类中的典型值或任意值。举例 常见的边界值w对16-bit 的整数而言 32767 和-32768 是边界w屏幕上光标在最左上、最右下位置w报表的第一行和最后一行w数组元素的第一个和最后一个w循环的第 0 次、第 1 次和倒数第 2 次、最后一次边界值分析w数学含义A=x=B C=y=D确立边界值的原则w如果输入条件或输出
19、条件规定了值的范围并且有效条件包括了值的边界,可分别对边界和略超出边界取值,例如:数据范围是1=x=50正整数边界值取为:1、50、0、51w如果输入条件或输出条件规定了值的范围并且有效条件不包括了值的边界,可分别对边界和略处于边界内取值,例如:数据范围是1x50正整数边界值取为:1、50、2、49确立边界值的原则w如果输入或输出域是个有序的集合(如顺序文件、表格等),应注意选取有序集的第一个和最后一个元素以及集合外但靠近集合的元素作为边界,例如:输入文件名介于之间边界值取为,与等价划分的区别 1)边界值分析不是从某等价类中随便挑一个作为代表,而是使这个等价类的每个边界都要作为测试条件。2)边
20、界值分析不仅考虑输入条件,还要考虑输出空间产生的测试情况。边界值分析w边界值分析使用与等价类划分法相同的划分,只是边界值分析假定错误更多地存在于划分的边界上,因此在等价类的边界上以及两侧的情况设计测试用例。w例例:测试计算平方根的函数 输入:实数 输出:实数 规格说明:当输入一个0或比0大的数的时候,返回其正平方根;当输入一个小于0的数时,显示错误信息“平方根非法-输入值小于0”并返回0;库函数Print-Line可以用来输出错误信息。边界值分析w等价类划分:可以考虑作出如下划分:w 输入(i)=0w 输出(a)=0 和(b)Error测试用例有两个:w 输入4,输出2。对应于(ii)和(a)
21、。w 输入-10,输出0和错误提示。对应于(i)和(b)。w边界值分析:划分(ii)的边界为0和最大正实数;划分(i)的边界为最小负实数和0。由此得到以下测试用例:w 输入 最小负实数w 输入 绝对值很小的负数w 输入 0w 输入 绝对值很小的正数w 输入 最大正实数举例(找零钱最佳组合)w假设商店商品价格X皆不大于100元(整数),若顾客买一件商品,付款Y在100元内,求找给顾客的最少货币张数?w货币面值:50元R5020元R2010元R105元R52元R21元R1分析输入wX 100w0 X =100wX 100wX=Y=100wY X 分析输出w0=R50=1w0=R20=2w0=R10
展开阅读全文