当前位置:文档之家› 软件测试技术选择判断解答题

软件测试技术选择判断解答题

第一章软件测试基础

一、判断分析题

1.软件测试的目的是尽可能多的找出软件的缺陷。()

2.软件测试的目的是证明软件没有错误。()

3.测试组负责软件质量。( )

4.程序的效率与程序的复杂性相关。( )

5.软件是一种逻辑实体,而不是具体的物理实体,因而它具有抽象性。 ( )

6.测试程序仅仅按预期方式运行就行了。( )

7.好的测试员不懈追求完美。( )

8.不存在质量很高但可靠性很差的产品。( )

9.测试组负责软件质量。( )

10.测试是为了验证该软件已正确地实现了用户的要求。( )

11.发现错误多的程序模块,残留在模块中的错误也多。( )

12.程序效率的提高主要应通过选择高效的算法来实现。( )

13.测试人员要坚持原则,缺陷未修复完坚决不予通过。()

14.项目立项前测试人员不需要提交任何工件。()

15.缺陷跟踪系统只针对对测试人员来使用。( )

16.从用户软件开发者的角度出发,普遍希望通过软件测试暴露软件中隐藏的错误和缺陷,以考虑是否可接受该产品。 ( )

17.软件项目在进入需求分析阶段,测试人员应该开始介入其中。( )

18.测试是提高产品质量根本手段。()

19.项目立项前测试人员不需要提交任何工件。()

20.测试人员要坚持原则,缺陷未修复完坚决不予通过。()

21.代码评审员一般由测试员担任。()

22.代码评审是检查源代码是否达到模块设计的要求。()

二、简答题

1.什么是软件测试?软件测试的目的和作用是什么?

2.简述软件测试的目的和原则。

3.软件缺陷产生的原因?

4.在软件工程或软件测试中,哪些软件问题被称为软件缺陷?

5.软件的缺陷等级应如何划分?

6.针对缺陷采取怎样的管理措施?

7.在测试实施之前,如何才能确定好的测试策略和测试方法?

8.什么是软件测试,以及软件测试的意义?

9.什么是软件测试?什么是测试用例,测试用例必须包括那几部分?

10.简述静态测试和动态测试的区别?

11.分析软件测试的复杂性。

12.简述你对测试工作的认识过程、在以后的工作的一些建议。

13.为什么需要软件测试用例?

14.软件测试和软件质量保证的区别与联系?

15.软件的质量与哪些因素有关?

16.请辨析软件的质量是“设计出来的”还是“测试出来的”观点。

17.软件测试与软件开发的关系?

第二章软件测试模型与过程

简答题

1.不同测试模型的优缺点对比?

2.软件开发模型分哪几种?在进行软件测试中,如何确定合理的测试模型和测试过程?

3.简述软件测试与软件开发过程的关系。

4.简述CMM的5个成熟度级别和各级的主要特征。

5.请描述软件测试活动的生命周期。请画出软件测试活动的流程图。

6.在测试生命周期,测试过程分为几个阶段,以及各个阶段的含义?

7.软件测试层次包括哪些测试?并描述各测试层次的作用和特点。

8.软件测试应该划分几个阶段?简述各个阶段应重点测试的点?各个阶段的含义?

9.请描述软件测试的一般步骤?试叙述对一个软件项目测试的全过程。

10.在测试生命周期中,测试过程分为几个阶段?各个阶段的含义?以及各阶段的测试依据是什么?

第三章软件测试管理

简答题

1.你是如何理解测试的层次和主要的管理活动?

2.在实际项目中,如何对软件测试进行有效管理?

3.一名优秀的软件测试工程师应具备哪些素质?

4.如何利用相关测试管理工具,对测试计划和缺陷进行有效的管理?

5.在测试管理中,应该收集哪些测试过程数据,并如何对这些过程数据进行分析?

6.如何做一名合格的测试人员?

7.测试计划的目的是什么?

第四章黑盒测试

一、判断分析题

1.软件测试员可以对产品说明书进行白盒测试。( )

2.静态白盒测试可以找出遗漏之处的问题。( )

3.总是首先设计白盒测试用例。()

4.用黑盒法测试时,测试用例是根据程序内部逻辑设计的。()

5.黑盒测试方法中最有效的是因果图法。( )

6.软件测试按照测试过程分类为黑盒、白盒测试。()

7.白盒测试又称结构测试、逻辑驱动测试或基于程序的测试。()

8.白盒测试时一般由开发人员兼任测试人员的角色。()

9.黑盒测试是从用户观点出发的测试。()

10.白盒测试是从用户观点出发的测试。()

11.白盒测试根据程序外部特征进行测试,黑盒测试根据程序内部逻辑结构进行测试。()

12.程序通过了全面的白盒测试,就不需要再进行黑盒测试了。()

13.代码评审是检查源代码是否达到模块设计的要求。()

14.代码评审员一般由测试员担任。()

15.对于同一个测试对象,等价类的测试用例数多于边界值的测试用例数。()

16.如果输入条件规定了取值范围,则可定义一个有效等价类和两个无效等价类。()

17.不能对输出值域进行健壮性测试。()

18.有n个变量的函数的健壮最坏情况测试用例的个数为:5的n次方。()

19.有n个变量的函数的健壮最坏情况测试用例的个数为:7的n次方。()

20.有n个变量的函数的健壮性测试用例的个数为:5n+1。()

21.有n个变量的函数的最坏情况测试会产生5的n次方个测试用例。()

22.有n个变量的函数的边界值分析会产生4n+1个测试用例()

23.边界值分析的假设是“多缺陷”假设。()

24.健壮性测试的主要价值是观察例外情况的处理。()

25.在设计测试用例时,应包括合理的输入条件和不合理的输入条件。( )

26.弱健壮等价类测试基于多缺陷假设。()

27.强健壮等价类测试是基于多缺陷假设,并考虑了无效值。()

28.强一般等价类测试考虑了无效值。()

29.弱一般等价类是基于单缺陷假设。()

30.弱健壮等价类测试基于单缺陷假设并考虑了无效值。()

31.强健壮等价类测试是基于多缺陷假设,并考虑了无效值。()

32.等价类测试的弱形式不如对应的强形式的测试全面()

二、简答题

1.什么是黑盒测试?黑盒测试主要采用的技术有哪些?

2.简单描述黑盒测试各种方法的特点。

3.如果能够执行完美的黑盒测试,还需要进行白盒测试吗?为什么?

4.边界值测试有几种方法?

5.对于教材上的佣金问题,如果采用输入值边界值测试,有几个测试用例?如果结合输出值进行边界值测试,如何考虑测试用例?

6.什么是等价类?如何划分等价类?

7.等价分类法的测试技术采用的一般方法?举例说明?

8.什么是等价类?如何划分等价类?等价类测试中有哪些方法?

9.对于日期问题,佣金问题,如何合理划分等价类?

10.为日期问题和开发决策表测试用例,为三角形问题的直角三角形开发测试用例。

11.请画出维恩图来表示边界值分析、健壮性测试、最坏情况测试生成的测试用例之间的关系。

12.如果试图进行输出值域健壮性测试,会出现什么情况?

13.为什么要进行等价类的划分?等价类划分应该遵循哪些原则?

三、用例设计题

1.针对以下问题:某一种8位计算机,其十六进制常数的定义是以0x或0X开头的十六进制整数,其取值范围为-7f~7f(不区分

大小写字母),如0x11、0x2A、-0x3c。请采用等价类划分的方法设计测试用例。

2.有一个小程序,能够求出三个在0到9999间整数中的最大者,请分别用边界值分析和健壮性测试方法设计测试用例。

3.假定一台ATM机允许提取增量为50元,总金额从100到2000(包含2000元)不等的现金。请结合等价类方法和边界值分析进行

测试。

4.有一个小学生成绩管理系统,要求把成绩好的同学放到前面的,其中每个人都有三门课程:语文,数学和英语。首先是按个人的

总成绩进行排名,如果某两个人的总分相同,则按他们的语文成绩进行排名,如果总成绩和语文成绩都相同时,则按照他们的数学成绩进行排名的。请用等价类方法进行测试。

5.程序有三个输入变量month、day、year(month、day和year均为整数值,并且满足:1≤month≤12、1≤day≤31、1900≤ year ≤2050。),

分别作为输入日期的月份、日、年份,通过程序可以输出该输入日期在日历上隔一天(第三天)的日期。例如,输入为2005年11月29日,则该程序的输出为2005年12月1日。请用等价类测试和边界测试法设计测试用例。

6.某软件的一个模块的需求规格说明书中描述:

(1)年薪制员工:严重过失,扣年终风险金的4%;过失,扣年终风险金的2%。

(2)非年薪制员工:严重过失,扣当月薪资的8%;过失,扣当月薪资的4%。

请绘制出判定表,并设计相应的测试用例。

7.某公司折扣政策:年交易额在10万元以下的,无折扣;在10万元以上的并且近三个月无欠款的,折扣率10%;在10万元以上,

虽然近三个月有欠款,但是与公司交易在10年以上的,折扣率8%;在10万元以上,近三个月有欠款,且交易在10年以下的折扣率5%;请用判定表来描述该公司的折扣政策。

8.请讨论判定表测试能够在多大程度上处理多缺陷假设问题。

9.请使用因果图法为三角形问题设计测试用例。

10.分析中国象棋中走马的实际情况(下面未注明的均指的是对马的说明)

a)如果落点在棋盘外,则不移动棋子;

b)如果落点与起点不构成日字型,则不移动棋子;

c)如果落点处有自己方棋子,则不移动棋子;

d)如果在落点方向的邻近交叉点有棋子(绊马腿),则不移动棋子;

e)如果不属于1-4 条,且落点处无棋子,则移动棋子;

f)如果不属于1-4 条,且落点处为对方棋子(非老将),则移动棋子并除去对方棋子;

g)如果不属于1-4条,且落点处为对方老将,则移动棋子,并提示战胜对方,游戏结束。

11.假设商店货品价格(R) 都不大于100元(且为整数),若顾客付款(P)在100元内,现有一个程序能在每位顾客付款后给出找零钱

的最佳组合(找给顾客货币张数最少)。假定此商店的货币面值只包括:50元(N50)、10元(N10)、5元(N5)、1元(N1) 四种。

请结合等价类划分法和边界值分析法为上述程序设计出相应的测试用例。

第五章白盒测试

一、判断分析题

1.语句覆盖是最弱的逻辑覆盖。()

2.语句覆盖是最强的逻辑覆盖。()

3.判定覆盖不一定包含条件覆盖。()

4.条件覆盖不一定包含判定覆盖。()

5.判定/条件覆盖能同时满足判定、条件两种覆盖标准。()

6.判定/条件覆盖指满足判定覆盖标准或条件覆盖标准。()

7.DD-路径图是一种压缩图。()

8.详细设计的目的是为软件结构图中的每一个模块确定使用的算法和块内数据结构,并用某种选定的表达工具给出清晰的描述。( )

9.尽量用公共过程或子程序去代替重复的代码段。()

10.对于连锁型分支结构,若有n个判定语句,则有2n条路径。()

11.尽量采用复合的条件测试,以避免嵌套的分支结构。()

12.GOTO语句概念简单,使用方便,在某些情况下,保留GOTO语句反能使写出的程序更加简洁。()

二、简答题

1.请试着比较一下黑盒测试、白盒测试、单元测试、集成测试、系统测试、验收测试的区别与联系。

2.什么是白盒测试?白盒测试主要采用的技术有哪些?

3.白盒测试有那几种方法?并简单描述各种方法的特点。

4.举例说明结构性测试覆盖指标C0,C1,C1P,CMCC的区别。

5.常用的逻辑覆盖测试方法有哪几种?并简单描述各种方法的目的。

6.逻辑覆盖中几种主要覆盖的含义?举例说明?

7.逻辑覆盖中几种主要覆盖的含义?举例说明?

8.什么是DD-路径?什么是MM-路径?DD-路径和MM-路径的区别与联系。

9.使用数据流测试方法(定义/使用测试)设计佣金问题中变量totalStocks的测试用例。

三、用例设计题

说明:程序段中每行开头的数字(1~10)是对每条语句的编号。

(1)画出程序的控制流图(用题中给出的语句编号表示)。

(2)分别以语句覆盖、判定覆盖、条件覆盖、判定/条件覆盖、组合覆盖和路径覆盖方法设计测试用例,并写出每个测试用例的执行路径(用题中给出的语句编号表示)。

(1)请画出以上代码的控制流图

(2)请计算上述控制流图的圈复杂度V(G)(独立线性路径数)

(3)假设输入的取值范围是0 < year < 2010,请使用基本路径测试法为变量year 设计测试用例,使其满足基本路径覆盖的要求。

4.请用逻辑覆盖和基路径测试方法对下面的java代码进行测试。代码的功能是:用折半查找法在元素呈升序排列的数组中查找

5.设计判别一个整数x(x≥2)是否为素数的程序,并设计测试用例满足条件覆盖和基本路径覆盖。

6.请用逻辑覆盖和基路径测试方法对下面的java代码进行测试。代码的功能是:输入三个数,判断它们是否为有效的日期(其

7.在三角形计算中,要求三角型的三个边长:A、B 和C。当三边不可能构成三角形时提示错误,可构成三角形时计算三角形周长。

若是等腰三角形打印“等腰三角形”,若是等边三角形,则提示“等边三角形”。画出程序流程图、控制流程图、计算圈复杂度V(g),

找出基本测试路径。

第六章单元测试

一、判断分析题

1.单元测试能发现约80%的软件缺陷。()

2.单元测试属于动态测试。 ( )

3.单元测试多采用白盒测试(结构性测试)技术。()

4.单元测试能发现约80%的软件缺陷。()

5.单元测试需要从程序的内部结构出发设计测试用例。()

6.单元测试需要为每个基本单元开发驱动模块或桩模块。()

7.在面向对象语言语言中,单元测试是函数或子过程。()

8.单元测试又称为模块测试,是针对软件测试的最小单位-程序模块进行正确性检验的测试工作。()

二、简答题

1.单元测试有那些步骤,各个步骤有那些实施内容。

2.简述单元测试的目标和意义。

第七章集成测试

一、判断分析题

1.集成测试计划在需求分析阶段末提交。()

2.自底向上集成需要测试员编写驱动程序。()

3.进行自底向上集成测试,需要为所测模块或子系统编制相应的驱动模块。()

4.进行自底向上集成测试,需要为所测模块或子系统编制相应的桩模块。()

5.进行自顶向下集成测试,需要为所测模块或子系统编制相应的驱动模块。()

6.进行自顶向下集成测试,需要为所测模块或子系统编制相应的桩模块。()

7.MM-路径是可执行路径。()

8.非渐增式集成方式,发现错误难以诊断定位。()

9.集成测试是检验程序单元或部件的接口关系,逐步集成为符合概要设计要求的程序部件或整个系统。()

10.集成测试计划在需求分析阶段末提交。()

11.自底向上集成需要测试员编写驱动程序。()

二、简答题

1.为什么在单元测试之后要进行集成测试?如何组织集成测试?

2.非增量式测试与增量式测试

3.简述自顶向下增量式测试和自底向上增量式测试两种集成测试方法,并比较两者的优点和缺点。

4.简述集成测试的过程。集成测试的方法有那些?

5.比较自顶向下集成测试和自底向上集成测试的优劣?

第八章系统测试

一、判断分析题

1.系统测试多采用白盒测试(结构性测试)技术。()

2.验收测试是由最终用户来实施的。()

3.负载测试是验证要检验的系统的能力最高能达到什么程度。()

4.我们可以人为的使得软件不存在配置问题。()

5.可以发布具有配置缺陷的软件产品。( )

6.所有软件必须进行某种程度的兼容性测试。( )

7.所有软件都有一个用户界面,因此必须测试易用性。( )

8.β测试是由软件的多个用户在实际使用环境下进行的测试。()

9.系统测试是在真实或模拟系统运行环境下,检查完整的程序系统能否和相关硬件、外设、网络、系统软件和支持平台等正确配

置与连接,并满足用户需求。()

10.Beta 测试是验收测试的一种。()

11.验收测试是由最终用户来实施的。()

12.负载测试是验证要检验的系统的能力最高能达到什么程度。()

13.我们可以人为的使得软件不存在配置问题。()

二、简答题

1.以Windows 计算器程序和画笔程序为例,说明如何进行GUI系统测试。

2.系统测试计划是否需要同行评审,为什么?

3.什么叫α测试(Alpha 测试)?什么叫β测试(beta 测试)?α测试和β测试有什么区别?

4.客户 / 服务器体系结构的测试

5.比较负载测试、容量测试和强度测试的区别。

6.什么是单元测试?什么是集成测试?什么是系统测试?他们的测试依据是什么?他们和功能测试,结构性测试有何关系?

7.你认为一个优秀的测试工程师应该具备哪些素质?

8.请试着比较一下黑盒测试、白盒测试、单元测试、集成测试、系统测试、验收测试的区别与联系。

9.什么是测试评估,测试评估的范围是什么?

10.阐述工作版本的定义。

11.阶段评审与同行评审的区别。

12.回归测试测试如何进行?

【5-1】从供选择的答案中选出应填入下列( )中的字句。

软件测试的目的是( A )。为了提高测试的效率,应该( B )。使用白盒测试方法时,确定测试数据应根据( C )和指定的覆盖标准。与设计测试数据无关的文档是( D )。

软件的集成测试工作最好由( E )承担,以提高集成测试的效果。

供选择的答案:

A. ① 评价软件的质量② 发现软件的错误③ 找出软件中的所有错误④ 证明软件是正确的

B. ① 随机地选取测试数据② 取一切可能的输入数据作为测试数据

③ 在完成编码以后制定软件的测试计划④ 选择发现错误的可能性大的数据作为测试数据

C. ① 程序的内部逻辑② 程序的复杂程度③ 使用说明书④ 程序的功能

D. ① 该软件的设计人员② 程序的复杂程度③ 源程序④ 项目开发计划

E. ① 该软件的设计人员② 该软件开发组的负责人

③ 该软件的编程人员④ 不属于该软件开发组的软件设计人员

【5-2】请从供选择的答案中选出应填入下列()中的字句。

程序的三种基本控制结构是( A )。它们的共同点是( B )。结构化程序设计的一种基本方法是( C )。软件测试的目的是( D )。软件调试的目的是( E )。

供选择的答案:

A. ① 过程,子程序,分程序② 顺序,条件,循环③ 递归,堆栈,队列④ 调用,返回,转移

B. ① 不能嵌套使用② 只能用来写简单的程序③ 已经用硬件实现④ 只有一个入口和一个出口

C. ① 筛选法② 递归法③ 归纳法④ 逐步求精法

D. ① 证明程序中没有错误② 发现程序中的错误③ 测量程序的动态特性④ 检查程序中的语法错误

E. ① 找出错误所在并改正之② 排除存在错误的可能性③ 对错误性质进行分类④ 统计出错的次数

【5-3】从下列关于软件测试的叙述中,选出5条正确的叙述。

(1) 用黑盒法测试时,测试用例是根据程序内部逻辑设计的。 (2) 尽量用公共过程或子程序去代替重复的代码段。

(3) 测试是为了验证该软件已正确地实现了用户的要求。 (4) 对于连锁型分支结构,若有n个判定语句,则有2n条路径。

(5) 尽量采用复合的条件测试,以避免嵌套的分支结构。

(6) GOTO语句概念简单,使用方便,在某些情况下,保留GOTO语句反能使写出的程序更加简洁。

(7) 发现错误多的程序模块,残留在模块中的错误也多。 (8) 黑盒测试方法中最有效的是因果图法。

(9) 在做程序的单元测试时,桩(存根)模块比驱动模块容易编写。 (10) 程序效率的提高主要应通过选择高效的算法来实现。【5-4】从供选择的答案中选出同下列关于软件测试的各条叙述关系最密切的字句。

(1) 对可靠性要求很高的软件,例如操作系统,由第三者对源代码进行逐行检查。

(2) 已有的软件被改版时,由于受到变更的影响,改版前正常的功能可能发生异常,性能也可能下降。因此,对变更的软件进行测试是必要的。

(3) 在意识到被测试模块的内部结构或算法的情况下进行测试。 (4) 为了确认用户的需求,先做出系统的主要部分,提交给用户试用。

(5) 在测试具有层次结构的大型软件时,有一种方法是从上层模块开始,由上到下进行测试。此时,有必要用一些模块替代尚未测试过的下层模块。

供选择的答案:

A ~ E:① 仿真器② 代码审查③ 模拟器④ 桩⑤ 驱动器⑥ 域测试⑦ 黑盒测试⑧ 原型⑨ 白盒测试⑩ 退化测试

【5-5】对小的程序进行穷举测试是可能的,用穷举测试能否保证程序是百分之百正确呢?

【5-6】在任何情况下单元测试都是可能的吗?都是需要的吗?

【5-7】从供选择的答案中选出应填入下面有关软件测试的叙述的()内的正确答案。

软件测试方法可分为黑盒测试法和白盒测试法两种。

黑盒测试法是通过分析程序的( A )来设计测试用例的方法。除了测试程序外,它还适用于对( B )阶段的软件文档进行测试。

白盒测试法是根据程序的( C )来设计测试用例的方法。除了测试程序外,它也适用于对( D )阶段的软件文档进行测试。

白盒法测试程序时常按照给定的覆盖条件选取测试用例。( E )覆盖比( F )覆盖严格,它使得每一个判定的每一条分支至少经历一次。( G )覆盖既是判定覆盖,又是条件覆盖,但它并不保证使各种条件都能取到所有可能的值。( H )覆盖比其他条件都要严格,但它不能保证覆盖程序中的每一条路径。

单元测试一般以( I )为主,测试的依据是( J )。

供选择的答案:

A, C:① 应用范围② 内部逻辑③ 功能④ 输入数据

B, D:① 编码② 软件详细设计③ 软件总体设计④ 需求分析

E, F, G, H:① 语句② 判定③ 条件④ 判定/条件⑤ 多重条件⑥ 路径

I:① 白盒法② 黑盒法 J:① 模块功能规格说明② 系统模块结构图③ 系统需求规格说明

【5-8】从供选择的答案中选出应该填入下列关于软件测试的叙述的( )内的正确答案。

软件测试中常用的静态分析方法是( A )和( B )。( B )用于检查模块或子程序间的调用是否正确。分析方法(白盒方法)中常用的方法是( C )方法。非分析方法(黑盒方法)中常用的方法是( D )方法和( E )方法。( E )方法根据输出对输入的依赖关系设计测试用例。

软件测试技术软件评测师 TD RequestPro 软件测试开发技术 Windows 面向对象单元测试嵌入式测试 WinRunner RQM 软件测试开发语言 Unix MDA 单元测试方法金融测试 QuickTestPro Borland软件测试工具 Java 网络知识测试驱动开发 TDD 服务器 .net Borland QTP 银行测试单元测试代码功能测试电信测试 QualityCenter SilkTest VB 质量保证解决方案开源软件测试技术质量保障 PHP SilkPerformer QC boss测试手工测试测试用例游戏测试 Rational软件测试工具

供选择的答案:

A ~ B:① 引用分析② 算法分析③ 可靠性分析④ 效率分析⑤ 接口分析⑥ 操作分析

C ~ E:① 路径测试② 等价类③ 因果图④ 归纳测试⑤ 综合测试⑥ 追踪⑦ 深度优先⑧ 调试⑨ 相对图

【5-9】下面是选择排序的程序,其中datalist是数据表,它有两个数据成员:一是元素类型为Element的数组V,另一个是数组大小n。算法中用到两个操作,一是取某数组元素V 的关键码操作getKey ( ),一是交换两数组元素内容的操作Swap( ):

void SelectSort ( datalist & list ) {

//对表list.V[0]到list.V[n-1]进行排序, n是表当前长度。

for ( int i = 0; i < list.n-1; i++ ) {

int k = i; //在list.V .key到list.V[n-1].key中找具有最小关键码的对象

for ( int j = i+1; j < list.n; j++)

if ( list.V[j].getKey ( ) < list.V[k].getKey ( ) ) k = j; //当前具最小关键码的对象

if ( k != i ) Swap ( list.V , list.V[k] ); //交换

} }

(1) 试计算此程序段的McCabe复杂性; (2) 用基本路径覆盖法给出测试路径; (3) 为各测试路径设计测试用例。

【5-10】根据下面给出的规格说明,利用等价类划分的方法,给出足够的测试用例。

“一个程序读入三个整数。把此三个数值看成是一个三角形的三个边。这个程序要打印出信息,说明这个三角形是三边不等的、是等腰的、还是等边的。”

【5-11】设要对一个自动饮料售货机软件进行黑盒测试。该软件的规格说明如下:

“有一个处理单价为1元5角钱的盒装饮料的自动售货机软件。若投入1元5角硬币,按下“可乐”、“雪碧”或“红茶”按钮,相应的饮料就送出来。若投入的是2元硬币,在送出饮料的同时退还5角硬币。”

(1) 试利用因果图法,建立该软件的因果图; (2) 设计测试该软件的全部测试用例。

【5-12】对一个长度为100,000条指令的程序进行测试,记录下来的数据如下:

测试开始, 发现错误个数为0; 经过160小时的测试, 累计改正100个错误, 此时, MTTF = 0.4小时;又经过160小时的测试, 累计改正300个错误, 此时, MTTF = 2小时;

(1) 估计程序中固有的错误总数; (2) 为使MTTF达到10小时, 必须测试和调试这个程序多长时间?

(3) 给出MTTF与测试时间t之间的函数关系。

【5-13】应该由谁来进行确认测试?是软件开发者还是软件用户?为什么?

答案:【5-1】A. ② B. ④ C. ① D. ④ E. ④ 【5-2】A. ② B. ④ C. ④ D. ② E. ①

【5-3】正确的叙述有(4)、(5)、(6)、(7)、(10)【5-4】(1) ② (2) ⑩ (3) ⑨ (4) ⑧ (5) ④

【5-5】对小程序进行穷举测试,不见得能保证程序百分之百正确。所谓穷举测试是拿所有可能的输入数据来作为测试用例(黑盒测试),或覆盖程序中所有可能的路径(白盒测试)。对于小程序来说,实际上并不能真正作到穷举测试

【5-6】单元测试又称模块测试,是针对软件设计的最小单位─程序模块,进行正确性检验的测试工作。其目的在于发现各模块内部可能存在的各种差错。单元测试需要从程序的内部结构出发设计测试用例。多个模块可以平行地独立进行单元测试。

单元测试是在编码阶段完成的,每编写出一个程序模块,就开始做这个模块的单元测试,所以只要采用模块化方法开发软件,单元测试都是必需的。它可由编写程序的人来完成。因为它需要根据程序的内部结构设计测试用例,对于那些不了解程序内部细节的人,这种测试无法进行。

【5-7】A. ③ B. ④ C. ② D. ② E. ② F. ① G. ④ H. ⑤ I. ① J. ① 【5-8】A. ① B. ⑤ C. ① D. ② E. ③

【5-9】图太复杂,不好贴【5-10】图太复杂,不好贴【5-11】图太复杂,不好贴【5-12】图太复杂,不好贴

【5-13】在对照需求做有效性测试和软件配置审查时,是由软件开发者在开发环境下进行的测试。而接下来做验收测试时则以用户为主。软件开发人员和QA(质量保证)人员也应参加。由用户参加设计测试用例,使用用户界面输入测试数据,并分析测试的输出结果。一般使用生产中的实际数据进行测试。

如果软件是为多个客户开发的,则需要进行α测试和β测试。α测试是由一个用户在开发环境下进行的测试,也可以是公司内部的用户在模拟实际操作环境下进行的测试。软件在一个自然设置状态下使用。开发者坐在用户旁边,随时记下错误情况和使用中的问题。这是在受控制的环境下进行的测试。

β测试是由软件的多个用户在一个或多个用户的实际使用环境下进行的测试。这些用户是与公司签定了支持产品预发行合同的外部客户,他们要求使用该产品,并愿意返回有关错位错误信息给开发者。与α测试不同的是,开发者通常不在测试现场。因而,β测试是在开发者无法控制的环境下进行的软件现场应用。

下面是一段求最大值的程序,其中datalist是数据表,n是datalist的长度。

int GetMax(int n, int datalist[ ]) {

int k=0;

for ( int j=1; j

if ( datalist[j] > datalist[k] ) k=j;

return k; }

(1)画出该程序的控制流图,并计算其McCabe环路复杂性(2)用基本路径覆盖法给出测试路径(3)为各测试路径设计测试用例。

1.控制流图如下,McCabe环路复杂性为3。

2. 测试路径:

Path1:①→③ Path2:①→②→④→⑥→… Path3:①→②→⑤→⑥→…

一、填空

1、软件测试阶段的基本任务应当是根据软件开发各阶段的______和程序的_______ ,精心设计一批“高产”的测试用例,利用这些测试用例_______,找出软件中潜藏的各种错误和缺陷。

2、测试用例不仅要选用合理的测试输入数据,还需要选用不合理的测试输入数据,这样能更多地_______,提高程序的可靠性。对于不合理的测试输入数据,程序应_______,并给出相应的提示。

3、动态测试指通过_______发现错误。对软件产品进行动态测试时使用黑盒测试法和_______法。

4、静态测试指_______不在机器上运行,而是采用_______和_______的手段对程序进行检测。

5、黑盒测试依据_______,检查程序是否满足_______。因此,黑盒测试由称为功能测试或_______测试。

6、白盒测试以检查处理过程的细节为基础,对程序中尽可能多的_______进行测试,检查内部_______和_______是否有错,程序的_______与预期的状态是否一致。

7、在基本路径测试中,独立路径是指包括一组以前没有处理过的_______的一条路径。从程序图来看,一条独立路径是至少包含有一条_______的边的路径。

8、在单元测试中,驱动模块的作用是用来模拟被测模块的_______。它的工作是接受_______,以上层模块调用被测模块的形式_______被测模块,接收被测模块的_______并输出。

9、在单元测试中,桩模块用来代替被测模块的_______。其作用是_______的信息。

10、错误的群集现象是指模块错误发现率与模块的残留错误数成_______关系。

二、选择题

1、在软件测试中,下面说法中错误的是( )。

A. 测试是为了发现程序中的错误而执行程序的过程

B. 测试是为了表明程序是正确的

C. 好的测试方案是极可能发现迄今为止尚未发现的错误的方案

D. 成功的测试是发现了至今为止尚未发现的错误的测试

2、软件测试的目的是( )。A. 试验性运行软件 B. 发现软件错误C. 证明软件正确 D. 找出软件中全部错误

3、软件测试用例主要由测试输入数据和( )两部分组成。A. 测试计划B. 测试规则C. 测试的预期结果D. 以往测试记录分析

4、与设计测试用例无关的文档是( ). A. 项目开发计划 B. 需求规格说明书 C. 软件设计说明书 D. 源程序

5、软件测试是软件质量保证的主要手段之一,测试的成本已超过( )的30%以上。因此,提高测试的有效性非常重要。

A. 软件开发成本

B. 软件维护成本

C. 软件开发成本和维护成本

D. 软件研制成本

6、“高产”的测试是指( )。

A. 用适量的测试用例说明被测试程序正确无误

B. 用适量的测试用例说明被测试程序符合相应的要求

C. 用适量的测试用例发现被测试程序尽可能多的错

D. 用适量的测试用例纠正被测试程序尽可能多的错误

7、如果想要进行成功的测试,为其设计测试用例主要依赖于( )。

A. 黑盒测试方法

B. 测试人员的经验

C. 白盒测试方法

D. 错误推测法

8、使用白盒测试方法时,确定测试数据应根据( )和指定的覆盖标准。

A. 程序的内部结构

B. 程序的复杂性

C. 使用说明书

D. 程序的功能

9、在用逻辑覆盖法设计测试用例时,有语句覆盖、分支覆盖、条件覆盖、判定-条件覆盖、条件组合覆盖和路径覆盖等。其中( )

是最强的覆盖准则。 A. 语句覆盖 B. 条件覆盖 C. 判定-条件覆盖 D. 路径覆盖

10、在设计测试用例时,( )是用得最多的一种黑盒测试方法。 A. 等价类划分 B. 边界值分析C. 因果图 D. 功能图

11、在黑盒测试中,着重检查输入条件的组合的测试用例设计方法是( )。

A. 等价类划分

B. 边界值分析

C. 错误推测法

D. 因果图法

12、从下列叙述中,能够与软件开发各阶段,如需求分析、设计、编码相对应的软件测试是( )。

A. 组装测试、确认测试、单元测试

B. 单元测试、组装测试、确认测试

C. 单元测试、确认测试、组装测试

D. 确认测试、组装测试、单元测试

13、单元测试将根据在( )阶段中产生的规格说明进行。A. 可行性研究与计划 B. 需求分析 C. 概要设计 D. 详细设计

14、组装测试计划是在( )阶段制定的。A. 可行性研究与计划 B. 需求分析C. 概要设计 D. 详细设计

15、确认测试计划是在( )阶段制定的。A. 可行性研究与计划 B. 需求分析 C. 概要设计 D. 详细设计

16、软件的组装测试最好是由( )承担,以提高组装测试的效果。

A. 该软件的设计者

B. 该软件开发组的负责人

C. 该软件的编程者

D. 不属于该开发组的人员

17、( )是简化了的模拟较低层次模块功能的虚拟子程序。A. 过程 B. 函数 C. 仿真 D. 桩

18、( )是指为查明程序中的错误和缺陷,可能使用的工具和手段。 A. 调试技术 B. 测试技术 C. 跟踪法 D. 动态测试

19、从已发现故障的存在到找到准确的故障位置并确定故障的性质,这一过程称为( ) A. 错误检测B. 故障排除C. 调试D. 测试

20、在程序设计的过程中应为程序调试做好准备,主要体现在( )方面。

A. 采用模块化、结构化的程序设计方法设计程序

B. 编写程序时要为程序调试提供足够的灵活性

C. 根据程序调试的需要,选择并安排适当的中间结果输出和必要的断

D. 以上全是

21、统计资料表明,软件测试的工作量占整个软件开发工作量的( )。A. 30% B. 70% C. 40%~50% D. 95%

22、软件测试计划是一些文档,它们描述了( )。

A. 软件的性质

B. 软件的功能和测试用例

C. 软件的规定动作

D. 对于预定的测试活动将要采取的手段

23、IBM公司的统计资料表明,使用静态测试的方法最高可以查出在测试中查出的全部软件错误的( )。A. 80% B. 70% C. 50% D. 35%

24、黑盒测试方法的优点是( )。

A. 可测试软件的特定部位

B. 能站在用户立场测试

C. 可按软件内部结构测试

D. 可发现实现功能需求中的错误

25、白盒测试方法的优点是( )。

A. 可测试软件的特定部位

B. 能站在用户立场测试

C. 可按软件内部结构测试

D. 可发现实现功能需求中的错误

26、等价类划分完成后,就可得出( ),它是确定测试用例的基础。A. 有效等价类B. 无效等价C. 等价类表D. 测试用例集

27、由因果图转换出来的( )是确定测试用例的基础。A. 判定表 B. 约束条件表 C. 输入状态表 D. 输出状态表

三、选择填空题

1、从供选择的答案中选出应填入下列( )中的字句。

软件测试的目的是( A )。为了提高测试的效率,应该( B )。使用白盒测试方法时,确定测试数据应根据( C )和指定的覆盖标准。与设计测试数据无关的文档是( D )。

软件的集成测试工作最好由( E )承担,以提高集成测试的效果?BR>供选择的答案:

A. ①评价软件的质量②发现软件的错误③找出软件中的所有错误④证明软件是正确的

B. ①随机地选取测试数据②取一切可能的输入数据作为测试数据

③在完成编码以后制定软件的测试计划④选择发现错误的可能性大的数据作为测试数据

C. ①程序的内部逻辑 ②程序的复杂程度③使用说明书 ④程序的功能

D. ①该软件的设计人员 ②程序的复杂程度③源程序 ④项目开发计划

E. ①该软件的设计人员 ②该软件开发组的负责人 ③该软件的编程人员 ④不属该软件开发组的软件人员

2、从供选择的答案中选出应填入下列( )中的字句。

为了把握软件开发各个环节的正确性和协调性,人们需要进行( A )和( B )工作。( A )的目的是想证实在一给定的外部环境中软件的逻辑正确性。它包括( C )和( D ),( B )则试图证明在软件生存期各个阶段,以及阶段间的逻辑( E )、( F )和正确性。

供选择的答案:

A, B. ①操作②确认③验证④测试⑤调试

C, D. ①用户的确认②需求规格说明的确认③程序的确认④测试的确认

E, F. ①可靠性②独立性③协调性④完备性⑤扩充性

3、从供选择的答案中选出应填入下列( )中的字句。

测试过程需要三类输入:( A )、( B )和( C )。请选择正确的答案填入下图中以完成测试信息处理的全过程。

供选择的答案

A~C. ①接口选择 ②软件配置 ③硬件配置④测试配置 ⑤测试环境 ⑥测试工具

D~ F. ①排错②可靠性分析③结果分析④数据分类

4、请从供选择的答案中选出应填入下列()中的字句。

程序的三种基本控制结构是( A )。它们的共同点是( B )。结构化程序设计的一种基本方法是( C )。软件测试的目的是( D )。软件调试的目的是( E )。

供选择的答案:

A. ①过程,子程序,分程序②顺序,条件,循环③递归,堆栈,队列④调用,返回,转移

B. ①不能嵌套使用②只能用来写简单的程序③已经用硬件实现④只有一个入口和一个出口

C. ①筛选法②递归法③归纳法④逐步求精法

D. ①证明程序中没有错误②发现程序中的错误③测量程序的动态特性④检查程序中的语法错误

E. ①找出错误所在并改正之②排除存在错误的可能性③对错误性质进行分类④统计出错的次数

5、从供选择的答案中选出同下列各条叙述关系最密切的字句。

(1) 对可靠性要求很高的软件,例如操作系统,由第三者对源代码进行逐行检查。

(2) 已有的软件被改版时,由于受到变更的影响,改版前正常的功能可能发生异常,性能也可能下降。因此,对变更的软件进行测试是必要的。

(3) 在意识到被测试模块的内部结构或算法的情况下进行测试。

(4) 为了确认用户的需求,先做出系统的主要部分,提交给用户试用。

(5) 在测试具有层次结构的大型软件时,有一种方法是从上层模块开始,由上到下进行测试。此时,有必要用一些模块替代尚未测试过的下层模块。

供选择的答案:

A~E: ①仿真器②代码审查③模拟器④桩⑤驱动器⑥域测试⑦黑盒测试⑧原型⑨白盒测试⑩退化测试

6、从供选择的答案中选出应填入下面叙述的()内的正确答案。

软件测试方法可分为黑盒测试法和白盒测试法两种。

黑盒测试法是通过分析程序的( A )来设计测试用例的方法。除了测试程序外,它还适用于对( B )阶段的软件文档进行测试。白盒测试法是根据程序的( C )来设计测试用例的方法。除了测试程序外,它也适用于对( D )阶段的软件文档进行测试。

白盒法测试程序时常按照给定的覆盖条件选取测试用例。( E )覆盖比( F )覆盖严格,它使得每一个判定的每一条分支至少经历一次。(G )覆盖既是判定覆盖,又是条件覆盖,但它并不保证使各种条件都能取到所有可能的值。(H )覆盖比其他条件都要严格,但它不能保证覆盖程序中的每一条路径?BR> 单元测试一般以(I )为主,测试的依据是(J )。

供选择的答案:

A, C: ①应用范围②内部逻辑③功能④输入数据

B, D: ①编码②软件详细设计③软件总体设计④需求分析

E~H: ①语句②判定③条件④判定/条件⑤多重条件⑥路径

I: ①白盒法②黑盒法J:①模块功能规格说明②系统模块结构图③系统需求规格说明

7、从供选择的答案中选出应填入下面叙述的()内的正确答案。

集成测试也叫做( A )或( B )。通常,在( C )的基础上,将所有模块按照设计要求组装成为系统。子系统的集成测试特别称为?nbsp; D ),它所做的工作是要找出子系统和系统需求规格说明之间的( E )。需要考虑的问题是:在把各个模块连接起来的时侯,穿越模块接口的数据是否会( F );一个模块的功能是否会对另一个模块的功能产生不利的影响;各个(G )组合起来,能否达到预期要求的(H );(I )是否有问题;单个模块的误差累积起来是否会放大。

供选择的答案:

A~D. ①单元测试②部件测③组装测试④系统测试⑤确认测试⑥联合测试

E~I. ①子功能②丢失③父功能④局部数据结构⑤全局数据结构⑥不一致⑦一致

8、从供选择的答案中选出应该填入下列叙述的( )内的正确答案。

软件测试中常用的静态分析方法是( A )和( B )。( B )用于检查模块或子程序间的调用是否正确。分析方法(白盒方法)中常用的方法是( C )方法。非分析方法(黑盒方法)中常用的方法是( D )方法和( E )方法。( E )方法根据输出对输入的依赖关系设计测试用例。

供选择的答案:

A~B: ①引用分析②算法分析③可靠性分析④效率分析⑤接口分析⑥操作分析

C~E: ①路径测试②等价类③因果图④归纳测试

⑤综合测试⑥追踪⑦深度优先⑧调试⑨相对图

9、从供选择的答案中选出应填入下面叙述的()内的正确答案。

等价类划分是一种典型的( A )方法,也是一种非常实用的重要的测试方法。使用这一方法,完全不考虑程序的( B )。用所有可能输入的数据来测试程序是不可能的,只能从全部可供输入的数据中选择一个( C )进行测试。( D )是指某个输入域的集合,在该集合中,各个输入数据对于揭露程序中的错误是( E )。

供选择的答案:

A:①白盒测试方法②黑盒测试方法B:①内部结构②外部环境③顺序④流程

C~E: ①全集②子集③等效?BR> ④不同的⑤等价类⑥典型集

10、从供选择的答案中选出应填入下面叙述的()内的正确答案。

①黑盒测试方法的缺点是( )和( )。

A不可测试软件的特定部位B不能发现功能需求中的错误C无法检验软件的外部特性D.无法测试未实现功能需求的软件的内部缺陷

②白盒测试方法的缺点是( )和( )。

A.不可测试软件的特定部位B不能发现功能需求中的错误C无法检验软件的外部特性D无法测试未实现功能需求的软件的内部缺陷

四、问答计算题

1、从下列关于软件测试的叙述中,选出5条正确的叙述。

(1) 用黑盒法测试时,测试用例是根据程序内部逻辑设计的。(2) 尽量用公共过程或子程序去代替重复的代码段。

(3) 测试是为了验证该软件已正确地实现了用户的要求。(4) 对于连锁型分支结构,若有n个判定语句,则有2n条路径。

(5) 尽量采用复合的条件测试,以避免嵌套的分支结构?BR> (6) GOTO语句概念简单,使用方便,在某些情况下,保留GOTO语句反能使写出的程序更加简洁。

(7) 发现错误多的程序模块,残留在模块中的错误也多。(8) 黑盒测试方法中最有效的是因果图法。

(9) 在做程序的单元测试时,桩(存根)模块比驱动模块容易编写。(10) 程序效率的提高主要应通过选择高效的算法来实现。2、对小的程序进行穷举测试是可能的,用穷举测试能否保证程序是百分之百正确呢?

3、在任何情况下单元测试都是可能的吗?都是需要的吗?

4、如图所示的程序有三条不同的路径。分别表示为L1(a→b)、L2(a→c→d)、L3(a→c→e),或简写为ace、abd、abe及acd。根据判定覆盖、条件覆盖、判定–条件覆盖、条件组合覆盖和路径覆盖等五种覆盖标准,从供选择的答案中分别找出满足相应覆盖标准的最小测试用例组。(用①~ ⑩回答)

供选择的答案:

① x = 90, y = 90 ② x = 50, y = 50

③ x = 90, y = 90 ④ x = 90, y = 70

x = 50, y = 50 x = 40, x = 90

⑤ x = 90, y = 90 ⑥ x = 90, y = 90

x = 50, y = 50 x = 70, y = 90

x = 90, y = 70 x = 50, y = 50

⑦ x = 90, y = 90 ⑧ x = 90, y = 90

x = 50, y = 50 x = 50, y = 50

x = 80, y = 70 x = 90, y = 50

x = 70, y = 90 x = 80, y = 80

⑨ x = 90, y = 90 ⑩ x = 90, y = 90

x = 90, y = 70 x = 80, y = 80

x = 90, y = 30 x = 90, y = 70

x = 70, y = 90 x = 90, y = 30

x = 30, y = 90 x = 70, y = 90

x = 70, y = 70 x = 30, y = 90

x = 50, y = 50 x = 70, y = 70

x = 50, y = 50

5、在白盒测试用例设计中,有语句覆盖、分支覆盖、条件覆盖、路径覆盖等,其中( A )是最强的覆盖准则。为了对如下图所示的程序段进行覆盖测试,必须适当地选取测试用例组。若x, y是两个变量,可供选择的测试用例组共有Ⅰ、Ⅱ、Ⅲ、Ⅳ四组,如表中给出,则实现判定覆盖至少应采取的测试用例组是( B )或( C );实现条件覆盖至少应采取的测试用例组是( D );实现路径覆盖至少应采取的测试用例组是( E )或( F )。

供选择的答案

A: ①语句覆盖②条件覆盖③判定覆盖④路径覆盖

B~F: ①Ⅰ和Ⅱ组②Ⅱ和Ⅲ组③Ⅲ和Ⅳ组④Ⅰ和Ⅳ组

⑤Ⅰ、Ⅱ、Ⅲ组⑥Ⅱ、Ⅲ、Ⅳ组⑦Ⅰ、Ⅲ、Ⅳ组⑧Ⅰ、Ⅱ、Ⅳ组

6、下面是快速排序算法中的一趟划分算法,其中datalist是数据表,它有两个数据成员:一是元素类型为Element的数组V,另一个是数组大小n。算法中用到两个操作,一是取某数组元素V[i]的关键码操作getKey ( ),一是交换两数组元素内容的操作Swap( ):

int Partition ( datalist &list, int low, int high ) {

//在区间[ low, high ]以第一个对象为基准进行一次划分,k返回基准对象回放位置。

int k = low; Element pivot = list.V[low]; //基准对象

for ( int i = low+1; i <= high; i++ ) //检测整个序列,进行划分

if ( list.V[i].getKey ( ) < pivot.getKey( ) && ++ k != i )

Swap ( list.V[k], list.V[i] ); //小于基准的交换到左侧去

Swap ( list.V[low], list.V[k] ); //将基准对象就位

return k; //返回基准对象位置 }

(1) 试画出它的程序流程图;(2) 试利用路径覆盖方法为它设计足够的测试用例(循环次数限定为0次,1次和2次)。

7、下面是选择排序的程序,其中datalist是数据表,它有两个数据成员:一是元素类型为Element的数组V,另一个是数组大小n。算法中用到两个操作,一是取某数组元素V[i]的关键码操作getKey ( ),一是交换两数组元素内容的操作Swap( ):

void SelectSort ( datalist & list ) {

//对表list.V[0]到list.V[n-1]进行排序, n是表当前长度。

for ( int i = 0; i < list.n-1; i++ ) {

int k = i; //在list.V[i].key到list.V[n-1].key中找具有最小关键码的对象

for ( int j = i+1; j < list.n; j++)

if ( list.V[j].getKey ( ) < list.V[k].getKey ( ) ) k = j;

//当前具最小关键码的对象

if ( k != i ) Swap ( list.V[i], list.V[k] ); //交换

}}

(1) 试计算此程序段的McCabe复杂性;(2) 用基本路径覆盖法给出测试路径;(3) 为各测试路径设计测试用例。

8、根据下面给出的规格说明,利用等价类划分的方法,给出足够的测试用例。

“一个程序读入三个整数。把此三个数值看成是一个三角形的三个边。这个程序要打印出信息,说明这个三角形是三边不等的、是等腰的、还是等边的。”

9、设要对一个自动饮料售货机软件进行黑盒测试。该软件的规格说明如下:

“有一个处理单价为1元5角钱的盒装饮料的自动售货机软件。若投入1元5角硬币,按下“可乐”、“雪碧”或“红茶”按钮,相应的饮料就送出来。若投入的是2元硬币,在送出饮料的同时退还5角硬币。”

(1) 试利用因果图法,建立该软件的因果图;(2) 设计测试该软件的全部测试用例。

4、对一个长度为100,000条指令的程序进行测试,记录下来的数据如下:

测试开始, 发现错误个数为0; 经过160小时的测试, 累计改正100个错误, 此时, MTTF = 0.4小时;又经过160小时的测试, 累计改正300个错误, 此时, MTTF = 2小时;

(1) 估计程序中固有的错误总数;

(2) 为使MTTF达到10小时, 必须测试和调试这个程序多长时间? (3) 给出MTTF与测试时间t之间的函数关系。

11、应该由谁来进行确认测试?是软件开发者还是软件用户?为什么?

三、选择填空题

1、解答:A. ② B. ④ C. ① D. ④ E. ④

2、解答:A. ② B. ③ C. ② D. ③ E. ③ F. ④

到程序的测试为止,软件开发工作已经经历了许多环节,每个环节都可能发生问题。为了把握各个环节的正确性,人们需要进行各种确认和验证工作。

所谓确认,是一系列的活动和过程,其目的是想证实在一个给定的外部环境中软件的逻辑正确性。它包括需求规格说明的确认和程序的确认,而程序的确认又分为静态确认与动态确认。静态确认一般不在计算机上实际执行程序,而是通过人工分析或者程序正确性证明来确认程序的正确性;动态确认主要通过动态分析和程序测试来检查程序的执行状态,以确认程序是否有问题。

所谓验证,则试图证明在软件生存期各个阶段,以及阶段间的逻辑协调性、完备性和正确性。下图中所示的就是软件生存期各个重要阶段之间所要保持的正确性。它们就是验证工作的主要对象。

确认与验证工作都属于软件测试。在对需求理解与表达的正确性、设计与表达的正确性、实现的正确性以及运行的正确性的验证中,任何一个环节上发生了问题都可能在软件测试中表现出来。

3、解答:A. ② B. ④ C. ⑥ D. ③ E. ① F. ②

4、解答:A. ② B. ④ C. ④ D. ② E. ①

5、解答:(1) ②(2) ⑩(3) ⑨(4) ⑧(5) ④

6、解答:A. ③ B. ④ C. ② D. ② E. ② F. ①G. ④H. ⑤I. ①J. ①

7、解答:A. ③B. ⑥C. ①D. ② E. ⑥F. ②G. ①H. ③I. ⑤A、B的答案可互换

8、解答:A. ① B. ⑤ C. ① D. ② E. ③

软件测试中常用的静态分析方法是引用分析和接口分析。接口分析用于检查模块或子程序间的调用是否正确。分析方法(白盒方法)中常用的方法是路径测试方法。非分析方法(黑盒方法)中常用的方法是等价类(划分)方法和因果图方法。因果图方法根据输出对输入的依赖关系设计测试用例。

9、解答:A. ② B. ① C. ② D. ⑤ E. ③10、解答:A和D,B和C,

四、问答计算题

1、解答:正确的叙述有(4)、(5)、(6)、(7)、(10)。

黑盒测试主要是根据程序的有关功能规格说明和覆盖准则来设计测试用例,进行测试的,不是根据程序的内部逻辑来设计测试用例,这是白盒测试做的事情。在所有黑盒测试方法中,最有效的不是因果图法,而是边界值分析方法。测试的目的是尽可能多地发现软件中的错误,其附带的收获才是验证该软件已正确地实现了用户的要求。测试的一条重要原则是:发现错误多的程序模块,残留在模块中的错误也多。软件可靠性模型(Shooman)就是依据这个原则建立它的公式的。对于连锁型分支结构,若有n个判定语句,则有2n 条路径。因此,随着n的增大,路径数增长非常快。单元测试时,因为桩模块要模拟子模块的功能,这不是一件容易的事情,而驱动模块只是控制被测模块的执行,所以桩模块的编写比驱动模块的编写要难得多。

在程序设计风格方面,如果重复的代码段没有明显的功能,不可以抽取出来形成独立的公共过程或子程序,只有在这些代码段表现出独立的功能时,才可把它们抽取出来形成独立的公共过程或子程序。另外,程序效率的提高主要应通过选择高效的算法或使用高效的语言编译器来实现。GOTO语句概念简单,使用方便,在某些情况下,保留GOTO语句反能使写出的程序更加简洁,这句话是正确的。

2、解答:对小程序进行穷举测试,不见得能保证程序百分之百正确。所谓穷举测试是拿所有可能的输入数据来作为测试用例(黑盒测试),或覆盖程序中所有可能的路径(白盒测试)。对于小程序来说,实际上并不能真正作到穷举测试。例如前面讲过,一个小程序P只有两个输入X和Y及输出Z,在字长为32位的计算机上运行。如果X、Y只取整数,考虑把所有的X、Y值都做为测试数据,按黑盒方法进行穷举测试,这样做可能采用的测试数据组(Xi,Yi),基数(radix)i的最大可能数目为:232×232=264。如果程序P 测试一组X、Y数据需要1毫秒,而且假定一天工作24小时,一年工作365天,要完成264组测试,需要5亿年。

3、解答:单元测试又称模块测试,是针对软件设计的最小单位─程序模块,进行正确性检验的测试工作。其目的在于发现各模块内部可能存在的各种差错。单元测试需要从程序的内部结构出发设计测试用例。多个模块可以平行地独立进行单元测试。单元测试是在编码阶段完成的,每编写出一个程序模块,就开始做这个模块的单元测试,所以只要采用模块化方法开发软件,单元测试都是必需的。它可由编写程序的人来完成。因为它需要根据程序的内部结构设计测试用例,对于那些不了解程序内部细节的人,这种测试无法进行。

4、解答:针对覆盖标准,相应的测试用例组如下

注意:测试是一个程序的执行过程。对于逻辑表达式 A or B,当A为真时不再对B做判断,对于逻辑表达式 A and B,当A为假时不再对B做判断。未能做判断的条件,在解答中用“□”表示。

此测试用例组在满足条件覆盖的情况下又满足了判定覆盖的要求。

在条件组合覆盖情形,(x?90)or(y?90)的组合有4种,与条件(x+y?140)的组合应有8种,但(x+y?140=F)and((x?90=T)or(y?90=T))不可能出现,因此,7个测试用例就够了。

因为流程图有3条路径,只需3个测试用例就够了。如果将判定中的复合条件表达式改为单个条件的嵌套选择结构,第一个判定有3条路径,其中两条路径通向第二个判定。第二个判定有4条路径,组合起来总共应有9条路径。但是,其中受测试条件的限制,有3条路径不可达,因此,程序中应有6条路径,需要6个测试用例来覆盖它们。

5、解答:A. ④ B. ⑤ C. ⑧ D. ④ E. ⑤ F. ⑧

判定表

为判定覆盖选取测试用例情形:对第一个判定选取测试用例组Ⅰ和Ⅱ,当用Ⅰ覆盖判定的T分支时,不会走到第二个分支;当用Ⅱ覆盖判定的F分支时,第二个判定需另取一个测试用例组覆盖其T分支,此时取测试用例组Ⅲ或Ⅳ即可。因此,选择⑤或⑧均可。为条件覆盖选取测试用例情形:取测试用例组Ⅰ和Ⅳ就可以覆盖所有4个条件的取值。

为路径覆盖选取测试用例情形:总共3条路径,需3个测试用例,可选使各路径为T的测试用例。Ⅰ、Ⅱ、Ⅲ或Ⅰ、Ⅱ、Ⅳ均可,可选⑤或⑧。

6、解答:(1)流程图如下。

(2) 测试用例设计

画程序流程图是设计测试用例的关键。从以往同学解题的经验来看,在画流程图时就出错了。所以首先要把流程图中的逻辑关系搞清楚再画出正确的流程图。考虑测试用例设计需要首先有测试输入数据,还要有预期的输出结果。对于此例,控制循环次数靠循环控制变量i和循环终值high。循环0次时,取low = high,此时一次循环也不做。循环一次时,取low +1 = high,循环二次时,取low+2 = high。

若出题时特别强调要使用BRO策略,条件V[i] < pivot && ++k≠i的约束集合为{ (<, < ), (<, = ), (=, <), (>, < ) },因此,测试用例设计为:

7、解答:(1) McCabe环路复杂性= 5

(2) 独立路径有5条:

①③①②⑤⑧……①②⑤⑨……①②④⑥……①②④⑦……

(3) 为各测试路径设计测试用例:

路径①③:取n = 1

路径①②⑤⑧……:取n = 2,预期结果:路径⑤⑧③不可达

路径①②⑤⑨……:取n = 2,预期结果:路径⑤⑨③不可达

路径①②④⑥⑤⑧③:取n = 2, V[0] = 2, V[1] = 1, 预期结果:k = 1, V[0] = 1, V[1] = 2

路径①②④⑥⑤⑨③:取n = 2, V[0] = 2, V[1] = 1, 预期结果:k = 1, 路径⑨③不可达

路径①②④⑦⑤⑧③:取n = 2, V[0] = 1, V[1] = 2, 预期结果:k = 0, 路径⑧③不可达

路径①②④⑦⑤⑨③:取n = 2, V[0] = 1, V[1] = 2, 预期结果:k = 0, V[0] = 1, V[1] = 2

8、解答:设三角形的三条边分别为A, B, C。如果它们能够构成三角形的三条边,必需满足:A > 0,B > 0,C > 0,且A + B > C,B +

C > A,A + C > B。

如果是等腰的,还要判断是否A = B,或B = C,或A = C。对于等边的,则需判断是否A = B,且B = C,且A = C。

列出等价类表:

测试用例设计(略)

9、解答:

(1) 因果图

(2) 测试用例设计

测试用例每一纵列为一个测试用例

10、解答:由shooman公式:

其中,IT = 105,MTTF1 = 0.4,T1 = 160,n1 = 100,MTTF2 = 2,T2 = 320,n2 = 300。得:

(1) 解得程序中固有得错误总数ET = 350,此外K = 1000。

(2) 设MTTF = 10,有

解得x = 340。由可靠性累积曲线EC (t) = ET (1-e-K1 t ),

得100 = 350 (1-e-160K1)

300 = 350 (1-e-320K1)

因此,3-3*e-160K1 = 1-e-320K1

2 = 3*e-160K1- e-320K1 设x = e-160K1

有x2 –3x + 2 = 0

解得x1 = 2,x2 = 1, K1 = ln(x1)/(-160) = - 0.693/160 ? 0.00433。

因为ln(x2)/(-160) = 0,舍去

代入:340 = 350 (1-e-K1 t ) = 350(1-e-0.00433 t )

350e-0.00433 t = 10

t = (ln(35))/0.00433 ? 821 (小时)

因此求得为使MTTF = 10,测试和调试该程序需要花费821小时。

(3) MTTF与测试时间t之间的函数关系:

因为EC (t) = ET (1-e-K1 t ),则ET - EC (t) = ET e-K1 t。代入shooman公式:

11、解答:在对照需求做有效性测试和软件配置审查时,是由软件开发者在开发环境下进行的测试。而接下来做验收测试时则以用户为主。软件开发人员和QA(质量保证)人员也应参加。由用户参加设计测试用例,使用用户界面输入测试数据,并分析测试的输出结果。一般使用生产中的实际数据进行测试。

如果软件是为多个客户开发的,则需要进行α测试和β测试。α测试是由一个用户在开发环境下进行的测试,也可以是公司内部的用户在模拟实际操作环境下进行的测试。软件在一个自然设置状态下使用。开发者坐在用户旁边,随时记下错误情况和使用中的问题。这是在受控制的环境下进行的测试。

β测试是由软件的多个用户在一个或多个用户的实际使用环境下进行的测试。这些用户是与公司签定了支持产品预发行合同的外部客户,他们要求使用该产品,并愿意返回有关错位错误信息给开发者。与α测试不同的是,开发者通常不在测试现场。因而,β测试是在开发者无法控制的环境下进行的软件现场应用。

城市的电话号码由两部分组成。这两部分的名称和内容分别是:

地区码:以0开头的三位或者四位数字(包括0);

电话号码:以非0、非1开头的七位或者八位数字。

假定被调试的程序能接受一切符合上述规定的电话号码,拒绝所有不符合规定的号码,就可用等价分类法来设计它的调试用例。

等价划分

相关主题
相关文档 最新文档