既可以用于黑盒测试,也可以用于白盒测试的方法的是()
- 逻辑覆盖法
- 边界值法
- 基本路径法
- 正交试验设计法
选B,边界值法。
边界值法既可以用于黑盒测试用例,也可以用于白盒测试用例。
基本路径法用于白盒测试。
正交试验设计法用于黑盒测试。
逻辑覆盖法用于白盒测试用例设计。
所以答案为B,边界值法。
由于覆盖测试的目标和程度不同,逻辑覆盖又分为:语句覆盖、判定覆盖、条件覆盖、判定/条件覆盖和条件组合覆盖。
-
语句覆盖:测试用例能使被测程序的每条执行语句至少执行一次。
-
判定覆盖:测试用例能使被测程序中的每个判定至少取得一次“真”和一次“假”。又称分支覆盖。
-
条件覆盖:测试用例能使被测程序中每个判定的每个条件至少取得一次“真”和一次“假”。如果判定中只有一个条件,则条件覆盖便满足判定覆盖,否则,不一定。
-
判定/条件覆盖:测试用例既满足判定覆盖,又满足条件覆盖。
-
条件组合覆盖:测试用例使每个判定中所有可能的条件取值组合至少执行一次。
上述几种覆盖,其覆盖程度的强弱如图所示。
图中,连线上方的覆盖与连线下方的覆盖相比,其覆盖程度要强。例如,条件组合覆盖比判定/条件覆盖的覆盖程度强,也即满足条件组合覆盖的测试用例一定满足判定/条件覆盖,反之不成立。又例如,判定覆盖和条件覆盖分别在两个不同分支上,表示它们之间的覆盖程度不能比较强弱,也就是说满足判定覆盖的测试用例不一定能满足条件覆盖,反之亦然。也正因这样才有判定/条件覆盖。
針對有多重輸入的情況設計測試案例,我們可用「窮舉法」來將所有的情況全部都考慮到,但由於窮舉法的組合非常地多,需要執行的時間也要很久,因此就有了「正交試驗設計法」來改善窮舉法的缺點。 「正交試驗設計法」是一種針對多重輸入值的情況設計測試案例的方法,利用輸入的值做組合,挑選出有最有代表性的組合,來減少測試案例,用少數的測試案例,達到同樣的測試效果。
基本路径测试法是在程序控制流图的基础上,通过分析控制构造的环路复杂性,导出基本可执行路径集合,从而设计测试用例的方法。
下面不属于软件测试步骤的是
- 集成测试
- 回归测试
- 确认测试
- 单元测试
答案:回归测试
回归测试是指修改了旧代码后,重新进行测试以确认修改没有引入新的错误或导致其他代码产生错误。它不是软件测试的步骤
测试过程按4个步骤进行,即单元测试、集成测试、确认测试和系统测试及发版测试。
- 开始是单元测试,集中对用源代码实现的每一个程序单元进行测试,检查各个程序模块是否正确地实现了规定的功能。
- 集成测试把已测试过的模块组装起来,主要对与设计相关的软件体系结构的构造进行测试。
- 确认测试则是要检查已实现的软件是否满足了需求规格说明中确定了的各种需求,以及软件配置是否完全、正确。
- 系统测试把已经经过确认的软件纳入实际运行环境中,与其它系统成份组合在一起进行测试。
单元测试能发现约80%的软件缺陷。请判断这句话的正确与否。
答案:对的
因为缺陷放大理论,在单元测试阶段发现的 bug 会在系统测试阶段被放大,放大倍数完全符合 80/20 理论
下面属于白盒测试方法的是
- 等价划分方法
- 逻辑覆盖
- 边界值分析
- 错误推测法
答案:逻辑覆盖
其余为黑盒测试法。
验收测试是由最终用户来实施的。请判断这句话的正确与否。
答案:错的
验收测试有 alpha 和 beta 两种,且都由用户来实施,区别在于是否为最终用户
alpha 测试是由一个用户在开发环境下进行的测试,也可以是公司内部用户在模拟实际操作环境进行的受控测试
beta 测试是由软件的多个用户在一个或多个实际使用环境下进行的测试
软件测试的对象包括( )
- 目标程序和相关文档
- 源程序、目标程序、数据及相关文档
- 目标程序、操作系统和平台软件
- 源程序和目标程序
答案:B
软件测试的对象包括:程序、数据、文档。目标程序和源程序都属于程序。
测试的关键问题是()
-
如何组织对软件的评审
-
如何验证程序的正确性
-
如何采用综合策略
-
如何选择测试用例
答案:D
测试用例是测试程序正确性与否的关键。一个覆盖完全的测试用例可以测试出程序是否正确运行,是否有 bug 等等,是最重要的。
集成测试计划在需求分析阶段末提交。请判断这句话的正确与否。
答案:错的
集成测试计划在概要设计阶段末提交~
负载测试是验证要检验的系统的能力最高能达到什么程度。请判断这句话的正确与否。
答案:对的
负载测试的目标是确定并确保系统在超出最大预期工作量的情况下仍能正常运行
关于测试驱动开发,描述错误的是
- 测试驱动开发式是一种敏捷开发方法
- TDD需求开发人员学习测试相关知识
- 测试驱动开发不适合使用 CMM/CMMI 方法
- 测试驱动开发可以和结对编程结合使用
答案:C
CMM 是指“能力成熟度模型”,CMMI,能力成熟度模型集成;这两种方法属于测试驱动开发的方式。
结对编程技术是指两位程序员坐在同一工作台前开发软件。与两位程序员各自独立工作相比,结对编程能编写出质量更高的代码。
下图用基本路径法测试需要覆盖几条路径?( )
4 条
1)(iRecordNum-->0) False --->只有1条路径
2)(iRecordNum-->0) True --->共有3条路径
2.1)0==iType --->1条
2.2)1==iType --->1条
2.3)其他的状况 --->1条
共 4 条
下面有关白盒测试和黑盒测试说法错误的有?
- 白盒测试也称结构测试或逻辑驱动测试,是指基于一个应用代码的内部逻辑知识,即基于覆盖全部代码、分支、路径、条件的测试。
- 黑盒测试也称功能测试或数据驱动测试,它是在已知产品所应具有的功能,通过测试来检测每个功能是否都能正常使用
- 黑盒测试,也称作黑盒分析,是基于对程序内部细节有限认知上的软件调试方法
- 黑盒测试与白盒测试相比,更需要关心模块与模块之间的交互
答案:C
对于 C,度娘说“ 灰盒测试, 也称作灰盒分析,是基于对程序内部细节有限认知上的软件调试方法”
对于 D,灰盒测试中,测试员可能知道系统组件之间是如何互相作用的,但缺乏对内部程序功能和运作的详细了解。对于内部过程,灰盒测试把程序看作一个必须从外面进行分析的黑盒。因此,假设测试对象有很多模块组成,1.灰盒测试与黑盒测试相比,更关心模块与模块之间的交互 2.灰盒测试与白盒测试相比,灰盒测试无需关心内部模块实现细节,而白盒测试仍需更深入了解内部模块细节。
用边界值分析法,假定1<X<10,那么X在测试中应该取的边界值是( )
- X=1,X=2,X=9,X=10
- X=2,X=9
- X=1,X=10
- X=1,X=5,X=6,X=10
答案:A
边界值分析的基本思想是使用在最小值、略高于最小值、正常值、略低于最大值和最大值处取输入变量值,记为:min、min+、nom、max-、max 考虑到健壮性测试,还可以加一个略大于最大值 max+,以及一个略小于最小值 min- 的值。
如果我们可以通过覆盖率检测来判断我们是否对所有的路径都进行了测试,但是仍然可能存在未被检测出来的缺陷,原因是()
- 全部选项
- 程序可能因为缺某些路径而存在问题
- 穷举路径的测试可能不好暴露数据敏感的错误
- 就算穷举路径测试也不能保证程序符合需求
答案:A
计算一个任意三角形的面积,S=√(p(p-a)(p-b)(p-c)),p=(a+b+c)/2,以下等价类测试用例中,不属于无效等价类的是()
- a=5,b=3,c=6;
- a=2,b=3,c=5;
- a=7,b=3,c=3;
- a=2,b=6,c=3;
答案:A
选项 A 满足三角形两边之和大于第三边,两边之差小于第三边,是有效的
选项 BCD 都不满足两边之和大于第三边,属于等级无效的
在下面说列举的逻辑测试覆盖中,测试覆盖最强的是?
- 条件覆盖
- 条件组合覆盖
- 语句覆盖
- 判定/条件覆盖
答案:B
条件覆盖 CC(Condition Coverage),设计足够多的测试用例,运行被测程序,使得每一判定语句中每个逻辑条件的可能取值至少满足一次。条件覆盖率的公式:条件覆盖率=被评价到的条件取值的数量/条件取值的总数X100%
条件覆盖的缺点:只考虑到每个判定语句中的每个表达式,没有考虑到各个条件分支(或者涉及不到全部分支),即不能够满足判定覆盖.
条件组合覆盖,也称多条件覆盖 MCC (Multiple Condition Coverage),设计足够多的测试用例,使得每个判定中条件的各种可能组合都至少出现一次(以数轴形式划分区域,提取交集,建立最少的测试用例)。这种方法包含了“分支覆盖”和“条件覆盖”的各种要求。满足条件组合覆盖一定满足判定覆盖、条件覆盖、判定条件覆盖。条件组合覆盖率的公式:条件组合覆盖率=被评价到的条件取值组合的数量/条件取值组合的总数条件组合覆盖的缺点:判定语句较多时,条件组合值比较多
。
语句覆盖 SC(Statement Coverage),就是设计若干个测试用例,运行被测程序,使得程序中每一可执行语句至少执行一次。这里的“若干个”,意味着使用测试用例越少越好。语句覆盖在测试中主要发现缺陷或错误语句。
判定条件覆盖 CDC(Condition/ Decision Coverage),设计足够多的测试用例,使得判定中的每个条件的所有可能(真/假)至少出现一次,并且每个判定本身的判定结果也至少出现一次。判定条件覆盖率的公式:条件判定覆盖率=被评价到的条件取值和判定分支的数量/(条件取值总数+判定分支总数)
.
判定条件覆盖的缺点:没有考虑单个判定对整体结果的影响,无法发现逻辑错误。
如果某测试用例集实现了某软件的路径覆盖,那么它一定同时实现了该软件的
- 条件覆盖
- 判定/条件覆盖
- 组合覆盖
- 判定覆盖
答案:D
路径覆盖一定包含判定覆盖,与条件并没有直接关系
设计系统测试计划需要参考的项目文挡有哪些?
- 软件测试计划
- 可行性研究报告
- 软件需求规范
- 迭代计划
答案:ACD
【软件需求】是软件开发之前做好的,软件开发是根据这个做的,那么软件测试自然也需要参考该文件
【迭代计划】是软件的某个周期的计划,自然也需要参考
【可行性】是软件开发前做好,用于证明该计划可行的,没有必要参考
下面哪些属于网游的测试内容?
- 客户端性能
- 服务器端性能
- 从运行完 game.exe 打开游戏界面后可进行的各种操作、玩法
- 界面
答案:ABCD
下面属于白盒测试方法的有哪些?
- 语句覆盖
- 等价类划分
- 边界值分析
- 判定条件覆盖
答案:AD
具体的黑盒测试用例设计方法包括等价类划分法、边界值分析法、错误推测法、因果图法、判定表驱动法、正交试验设计法、功能图法、场景法等。
白盒测试的测试方法有代码检查法、静态结构分析法、静态质量度量法、逻辑覆盖法、基本路径测试法、域测试、符号测试、路径覆盖和程序变异
白盒测试法的覆盖标准有逻辑覆盖 、循环覆盖和基本路径测试 。其中逻辑覆盖包括语句覆盖 、 判定覆盖、条件覆盖、判定/条件覆盖、条件组合覆盖和路径覆盖。
下面描述测试工具的功能正确的有?
- JMeter: 基于JAVA的压力测试工具,Badboy用来进行脚本的录制
- Junit: 白盒测试工具:针对代码测试
- LoadRunner:负载压力测试
- TestLink: 用例管理工具
答案:ABCD
LoadRunner-负载压力测试:预测系统性能。
JMeter+Badboy:基于JAVA的压力测试工具,Badboy用来进行脚本的录制 功能测试:通过自动录制、检测和回放用户的应用操作。将输出记录同预先给定的记录比较。
Junit:白盒测试工具:针对代码测试
测试管理工具:对测试需求、计划、用例、实施进行管理
测试辅助工具:本身不执行,可以生成测试数据,为测试提供数据准备
负载压力测试:LoadRunner:预测系统行为和性能的工业标准级负载测试工具。模拟上千万用户同时实施并发操作,来实时监控可能发生的问题。
功能测试: QTP(quicktest professional):自动测试工具
白盒测试:C++ TEST(做 C 和 C++ 的白盒测试)、JUnit(Java 白盒测试)
缺陷管理工具:Mantis、BugFree、QC、TD
用例管理工具:TestLink、QC
测试辅助工具:SVN
软件验收测试的合格通过准则是:
- 软件需求分析说明书中定义的所有功能已全部实现,性能指标全部达到要求。
- 所有测试项没有残余一级、二级和三级错误。
- 立项审批表、需求分析文档、设计文档和编码实现一致。
- 验收测试工件齐全。
答案:ABCD
验收测试工件齐全(测试计划,测试用例,测试日志,测试通知单,测试分析报告)
软件验收测试包括哪些?
- 正式验收测试
- 白盒测试
- alpha 测试
- beta 测试
答案:ACD
软件验收测试分为三类:
正式验收测试;
非正式验收测试其中包括
- α 测试(由用户、测试人员、开发人员共同参与的内部测试。)
- β 测试(内测后的公测,即完全交给最终用户测试。)
软件测试计划评审会需要哪些人员参加?
- 项目经理
- SQA 负责人
- 配置负责人
- 测试组
答案:ABCD
软件测试计划评审会需要有项目经理、客户(可选)、配置管理员、测试经理、开发组长等人的参加。
系统测试的策略有哪些?
- 负载测试
- 易用性测试
- 强度测试
- 安全测试
答案:ABCD
系统测试的16个测试策略:
功能测试、性能测试、压力测试、容量测试、安全性测试、GUI 测试、可用性测试、安装测试、配置测试、异常测试、备份测试、健壮性测试、文档测试、在线帮助测试、网络测试、稳定性测试。
下面哪些测试属于黑盒测试方法()
- 路径测试
- 等价类划分
- 边界值分析
- 条件判断
- 循环测试
- 因果图分析
- 正交分析法
答案:BCFG
具体的黑盒测试用例设计方法包括等价类划分法、边界值分析法、错误推测法、因果图法、判定表驱动法、正交试验设计法、功能图法、场景法等。白盒测试的测试方法有代码检查法、静态结构分析法、静态质量度量法、逻辑覆盖法、基本路径测试法、域测试、符号测试、路径覆盖和程序变异。
有关"测试驱动开发",下列说法正确的有?
- TDD 的原理是在开发功能代码之前,先编写单元测试用例代码,测试代码确定需要编写什么产品代码
- TDD 的基本思路就是通过测试来推动整个开发得进行,但测试驱动开发并不只是单纯的测试工作,而是把需求分析,设计,质量控制量化的过程。
- TDD 的重要目的不仅仅是测试软件,测试工作保证代码质量仅仅是其中一部分,而且是在开发过程中帮助客户和程序员去除模棱两可的需求。
- TDD 首先考虑使用需求(对象、功能、过程、接口等),主要是编写测试用例框架对功能的过程和接口进行设计,而测试框架可以持续进行验证。
答案:ABCD
下列关于 alpha 测试的描述中正确的是哪些?
- alpha 测试需要用户代表参加
- alpha 测试不需要用户代表参加
- alpha 测试是系统测试的一种
- alpha 测试是验收测试的一种
答案:AD
alpha 测试都不是太正规的一种测试,它属于用户体验性测试,alpha 测试是测试环境尽量真实,由软件公司内部人员模拟各类用户对即将面世的软件产品进行测试, 测试人员在一旁记录发现的问题和缺陷;对于软件项目来说,在系统测试后,有验收测试(有用户参与);对于软件产品来讲,在系统测试后, 有 alpha 和 beta 测试。
下述有关负载测试,容量测试和强度测试的描述正确的有?
- 负载测试:在一定的工作负荷下,系统的负荷及响应时间。
- 强度测试:在一定的负荷条件下,在较长时间跨度内的系统连续运行给系统性能所造成的影响。
- 容量测试:容量测试目的是通过测试预先分析出反映软件系统应用特征的某项指标的极限值(如最大并发用户数、数据库记录数等),系统在其极限值状态下没有出现任何软件故障或还能保持主要功能正常运行。
- 容量测试是面向数据的,并且它的目的是显示系统可以处理目标内确定的数据容量。
答案:ABCD
测试方法可以分成哪几种?
- 个人复查
- 抽查和会审
- 黑盒测试
- 白盒测试
答案:ABCD
软件测试可以是人工测试:如个人复查,抽查和会审等
也可以是机器自动测试,又有不同的分类:
按照否关软件内部结构具体实现角度划分
A.白盒测试B.黑盒测试 C.灰盒测试
按照软件发程按阶段划分
A.单元测试 B.集成测试 C.确认测试 D.系统测试 E.验收测试
测试人员要坚持原则,缺陷未修复完坚决不予通过。请判断这句话的正确与否。
答案:错的
缺陷分两种:
1、完全影响软件的正常运行或者影响客户的正常体验。
这种当然不能予以通过
2、不影响产品运行及客户正常体验且此软件急于使用。
以公司利益为出发,应予以通过。但在时间不紧急的情况下应不予通过。
代码评审员一般由测试员担任。请判断这句话的正确与否。
答案:错的
一般都是开发人员评审
软件测试的目的是尽可能多的找出软件的缺陷。请判断这句话的正确与否。
答案:对的
- 测试的目的是为了发现尽可能多的缺陷,不是为了说明软件中没有缺陷。
- 成功的测试在于发现了迄今尚未发现的缺陷。所以测试人员的职责是设计这样的测试用例,它能有效地揭示潜伏在软件里的缺陷。
判断对错。系统测试计划属于项目阶段性关键文档,因此需要同行评审。
答案:对的
同行评审目的:发现小规模工作产品的错误,系统测试计划属于项目阶段性关键文档,同行评审是必须的
自底向上集成需要测试员编写驱动程序。请判断这句话的正确与否。
答案:对的
自底向上测试是从“原子”模块(即软件结构最低层的模块)开始组装测试,因测试到较高层模块时,所需的下层模块功能均已具备,所以不再需要桩模块。
自底向上集成方法不用桩模块,测试用例的设计亦相对简单,但缺点是程序最后一个模块加入时才具有整体形象,需要开发驱动模块。
项目立项前测试人员不需要提交任何工件。请判断这句话的正确与否。
答案:对的
工件是加工过程中的生产对象。项目立项前,测试人员是不需要提供任何工件的。
软件测试类型按开发阶段划分是?
- 需求测试、单元测试、集成测试、验证测试
- 单元测试、集成测试、确认测试、系统测试、验收测试
- 单元测试、集成测试、验证测试、确认测试、验收测试
- 调试、单元测试、集成测试、用户测试
答案:B
(1)单元测试: 单元测试又称为模块测试,是针对软件设计的最小单位程序模块进行正确性检查的测试工作,单元测试需要从程序内部结构出发设计测试用例,多个模块可以平行地独立进行单元测试。
(2)集成测试 又称为组装测试或联合测试,在单元测试的基础上,需要将所有模块按照概要设计说明书和详细设计说明书的要求进行组装。
(3)确认测试 确认测试的目标是验证软件的功能和性能以及其他特性是否与用户的要求一致。确认测试一般包括有效性测试和软件配置复查。一般有第三方测试机构进行。
(4)系统测试 软件作为计算机系统的一部分,与硬件、网络、外设、支撑软件、数据以及人员结合在一起,在实际或模拟环境下,对计算机系统进行测试, 目的在于与系统需求比较,发现问题
(5)验收测试 以用户为主的测试,软件开发人员和质量保证人员参加,由用户设计测试用例。 不是对系统进行全覆盖测试,而是对核心业务流程进行测试。
alpha测试与beta的区别,描述错误的是?
- alpha测试是在用户组织模拟软件系统的运行环境下的一种验收测试,由用户或第三方测试公司进行的测试,模拟各类用户行为对即将面市的软件产品进行测试,试图发现并修改错误。
- Beta测试是用户公司组织各方面的典型终端用户在日常工作中实际使用beta版本,并要求用户报告异常情况,提出批评意见。
- beta测试的环境是不受开发方控制的,谁也不知道用户如何折磨软件,用户数量相对比较多,时间不集中。
- beta测试先于alpha测试执行
答案:D
Alpha测试由用户在开发者的场所进行,并且在开发者对用户的“指导”下进行测试。Alpha测试是在受控的环境中进行的。
Beta测试由软件的最终用户们在一个或多个客房场所进行。与Alpha测试不同,开发者通常在Beta测试的现场,因Beta测试是软件在开发者不能控制的环境中的“真实”应用。
对手机软件的压力测试通常可以包括【多选】( )
- 存储压力
- 响应能力压力
- 网络流量压力
- 并发压力
答案:ABC
针对手机应用软件的系统测试,我们通常从如下几个角度开展:功能模块测试,交叉事件测试,压力测试,容量测试,兼容性测试,易用性/用户体验测试等.
对手机可以施加的压力测试类型主要有:存储压力、边界压力、 响应能力压力、网络流量压力
并发压力是针对服务器的,因为每次并发是一个客户端
以下对桩(stub)函数的描述正确的是?
- 在单元测试中调用其它模块
- 在单元测试中被其它模块调用
- 在自顶向下的集成过程中尤其有效
- 在自底向上的集成过程中尤其有效
答案:BC
桩模块(Stub)是指模拟被测试的模块所调用的模块,而不是软件产品的组成的部分。在自顶向下的集成过程中尤其有效。
对桩(stub)函数的描述: 在单元测试中被其它模块调用; 在自顶向下的集成过程中尤其有效
测试设计员的职责有哪些?
- 制定测试计划
- 设计测试用例
- 设计测试过程、脚本
- 评估测试活动
答案:BC
制定测试计划应是测试经理来做的,评估测试活动测试经理组织召集开发和测试的相关人员来做
下面关于软件测试,描述正确的是?
- 软件测试是使用人工操作或者软件自动运行的方式来检验它是否满足规定的需求或弄清预期结果与实际结果之间的差别的过程。
- 软件测试的测试目标是发现一些可以通过测试避免的开发风险。
- 软件测试的原则之一是测试应该尽早进行,最好在需求阶段就开始介入。
- 软件测试主要工作内容是验证(verification)和确认(validation)
答案:ABCD
做好文档测试需要注意的点有哪些?
- 仔细阅读,跟随每个步骤,检查每个图形,尝试每个示例
- 检查文档的编写是否满足文档编写的目的
- 内容是否齐全,正确,完善
- 标记是否正确
答案:ABCD
集成测试的过程包括有以下哪些?
- 构建的确认过程
- 系统集成测试测试组提交过程
- 测试用例设计过程
- Bug的报告过程
答案:ABCD
系统集成测试主要包括以下过程:
- 构建的确认过程。
- 补丁的确认过程。
- 系统集成测试测试组提交过程。
- 测试用例设计过程。
- 测试代码编写过程。
- Bug的报告过程。
- 每周/每两周的构建过程。
- 点对点的测试过程。
- 组内培训过程。