软件测试理论知识学习

 什么是 软件测试,以及 软件测试的意义?
软件测试是软件 开发过程的重要组成部分,是用来确认一个 程序的品质或 性能是否符合开发之前所提出的一些要求。软件测试就是在软件投入 运行前,对软件 需求分析、 设计规格说明和编码的最终复审,是 软件质量保证的关键步骤。软件测试是为了发现错误而执行程序的过程。软件测试在软件生存期中横跨两个阶段:通常在 编写出每一个模块之后就对它做必要的测试(称为 单元测试)。编码和 单元测试属于软件生存期中的同一个阶段。在结束这个阶段后对软件 系统还要进行各种综合测试,这是软件生存期的另一个独立阶段,即测试阶段。
软件测试的意义:a.发现软件错误b.有效定义和实现软件成分由低层到高层的组装过程c.验证软件是否满足任务书和系统定义 文档所规定的 技术要求d. 为软件质量模型的建立提供依据;
2. 什么是软件测试静态分析,软件测试动态分析?
静态分析,是相对动态说的,即不运行程序。
白盒测试一般会用到静态分析和动态分析两类技术,常用的有:
静态分析:控制流分析、 数据流分析、信息流分析、 检查表、 代码走读,需求文档 评审
动态分析:逻辑覆盖测试(分支测试、路径测试等)、程序插装等。
静态测试和动态测试的区别在于是否需要运行被测软件。代码走读最主要的目标是要发现 缺陷,遗漏和矛盾的地方;改进产品;和考虑可替换的实现方法。 具体为:a.静态测试是用于预防的,动态测试是用于矫正的;b.多次的静态测试比动态测试要效率和效益高;c.静态测试综合测试程序代码;d.在相当短的 时间里,静态测试的覆盖度能达到100%,而动态测试经常是只能达到50%左右,原因动态测试发现的 bug大部分只是在测试实际执行的那部分代码;e.动态测试比静态测试更花时间;f.动态测试比静态测试更花时间;f.静态测试的执行可以在程序编码编译前,动态测试只能在编译后才能执行;g.静态测试能发现动态测试所不能发现的一些:"Syntax error,code that hard to maintain,code that hard to test,code that does not confirm to coding standard, and ANSI violations"。
3. 针对缺陷采取怎样的 管理措施?
1)         预测此缺陷会导致什么错误现象  属于几级严重度 (如果是一级/致命严重度 立即反馈研发人员,然他们有足够时间进行软件的修改)
2)         进行定位分析,分析是由哪个模块引起的
3)         建议如何进行修改
4)         考虑 其他缺陷是否因为这个缺陷所引起
5)         要更好的管理缺陷,必须引入缺陷管理 工具,商用的或者开源的都可。
6)         根据缺陷的生命周期,考虑缺陷提交的管理、缺陷状态的管理和缺陷分析的管理。
7)         所有发现的缺陷(不管是测试发现的还是走读代码发现的)都必须全部即时的、准确的提交到缺陷管理工具中,这是缺陷提交的管理。
8)         缺陷提交后,需要即时的指派给相应的开发人员,提交缺陷的人需要密切注意缺陷的状态,帮助缺陷的尽快 解决。缺陷解决后需要即时对缺陷的修复进行验证。这样的目的有两个:一个是让缺陷尽快解决;二是方便后面缺陷的分析(保证缺陷相关的信息准确,如龄期等),这是缺陷状态的管理。为了更好的改进开发过程和测试过程,需要对缺陷进行分析,总结如缺陷的类别、缺陷的龄期分布等信息,这是缺陷分析的管理。
4. 在测试生命周期,测试过程分为几个阶段,以及各个阶段的含义?  
大体上来说可分为单元测试,集成测试,系统测试,验收测试,每个阶段又分为以下五个步骤:
测试计划,测试设计, 用例设计,执行 结果,测试报告
初始测试集中在每个模块上,保证源代码的正确性,,该阶段成为单元测试,主要用白盒测试方法。
接下来是模块集成和集成以便组成完整的软件包。集成测试集中在证实和程序构成问题上。主要采用 黑盒测试方法,辅之以白盒测试方法。
软件集成后,需要完成确认和 系统测试。确认测试提供软件满足所有 功能、性能需求的最后保证。确认测试仅仅应用黑盒测试方法。
单元测试
单元测试是对软件中的基本组成单位进行的测试,如一个模块、一个过程等等。它是软件动态测试的最基本的部分,也是最重要的部分之一,其目的是检验软件基本组成单位的正确性。
集成测试
集成测试是在软件系统集成过程中所进行的测试,其主要目的是检查软件单位之间的接口是否正确。
系统测试
系统测试是对已经集成好的软件系统进行彻底的测试,以验证软件系统的正确性和性能等满足其规约所指定的要求,检查软件的行为和输出是否正确并非一项简单的任务,它被称为测试的“先知者问题”。
验收测试
验收测试旨在向软件的购买者展示该软件系统满足其 用户的需求。它的测试数据通常是系统测试的测试数据的子集.
回归测试  回归测试是在软件维护阶段,对软件进行修改之后进行的测试。其目的是检验对软件进行的修改是否正确。
5、 软件的缺陷等级应如何划分?
1)      致命错误(fatal):造成系统或 应用程序崩溃、死机、系统挂起,或造成数据丢失,主要功能完全丧失,导致本模块以及相关模块异常等问题。
2)      严重错误(critical):功能和特性没有实现导致严重的问题或致命的错误声明。问题局限在本模块,导致模块功能失效或异常退出
3)      一般错误(major):次要功能丧失, 提示信息不太准确,或用户界面差,操作时间长、模块功能部分失效等。
4)         建议问题(suggestion):由问题提出人对测试 对象的改进意见或测试人员提出的建议、质疑。
6、 如果能够执行完美的黑盒测试,还需要进行白盒测试吗?为什么?
黑盒测试:从用户角度出发,根据规格说明设计 测试用例,并不涉及程序的内部特性和内部结构,只依靠被测程序输入和输出之间的关系或程序的功能设计测试用例。黑盒测试有两个显著特点:
(1)黑盒测试与软件的具体实现过程无关,在软件实现的过程发生变化时,测试用例仍然可以用。
(2)黑盒测试用例的设计可以和软件实现同时进行,这样能够压缩总的开发时间。
  黑盒测试主要是为了发现以下几类错误:
1、是否有不正确、遗漏或额外的功能实现?
2、在接口上,输入是否能正确的接受?能否输出正确的结果?
3、是否有数据结构错误或外部信息(例如数据 文件)访问错误?
4、性能上是否能够满足要求?
5、是否有初始化或终止性错误?
白盒测试:已知程序的内部结构,检查内部操作是否按规定执行。主要对程序细节进行严密检验,针对特定条件和循环设计测试用例,对程序的逻辑路径进行测试。通过在程序的不同点检查程序状态,确定实际状态是否与预期的状态一致。
白盒测试主要是想对程序模块进行如下检查:
1、程序的所有语句至少执行一次。
2、对所有的逻辑条件都能至少执行一次。
3、在循环的边界和运行的界限内执行循环体。
4、测试内部数据结构的有效性,等等。
从以上可以看出就算执行了完美的黑盒测试也是无法测试程序内部特定部位,另外当规格说明本身有误,也不能发现问题。而白盒测试能对程序的内部特定部位进行覆盖测试,所以黑盒和白盒测试为互补关系,结合起来进行测试用例的设计更为合理。
经验表明,通常在进行单元测试时采用白盒测试方法,集成测试采用灰盒测试方法,系统测试采用黑盒测试方法。
8、 测试计划的目的是什么?
软件测试计划是指导测试过程的纲领性文件,包含了产品概述,测试策略,测试方法,测试区域,测试配置,测试周期,测试资源,风险分析等内容;借助软件测试计划,参与测试的 项目成员,可以明确测试任务和测试方法,保持测试实施过程的顺畅沟通,跟踪和控制测试进度,应对测试过程中的各种变更。
测试计划和测试用例间是战略和战术的关系,测试计划主要从宏观上规划测试活动的范围,方法和资源配置;而测试用例是完成测试任务的具体战术。
9、 针对缺陷采取怎样的管理措施?
1.要更好的管理缺陷,必须引入缺陷管理工具,商用的或者开源的都可。
2.根据缺陷的生命周期,考虑缺陷提交的管理、缺陷状态的管理和缺陷分析的管理。
3.所有发现的缺陷(不管是测试发现的还是走读代码发现的)都必须全部即时的、准确的提交到缺陷管理工具中,这是缺陷提交的管理。
4.缺陷提交后,需要即时的指派给相应的开发人员,提交缺陷的人需要密切注意缺陷的状态,帮助缺陷的尽快解决。缺陷解决后需要即时对缺陷的修复进行验证。这样的目的有两个:一个是让缺陷尽快解决;二是方便后面缺陷的分析(保证缺陷相关的信息准确,如龄期等),这是缺陷状态的管理。
5.为了更好的改进开发过程和测试过程,需要对缺陷进行分析,总结如缺陷的类别、缺陷的龄期分布等信息,这是缺陷分析的管理。
10、区别阶段评审的与同行评审
同行评审目的:发现小规模 工作产品的错误,只要是找错误;
阶段评审目的:评审模块 阶段作品的正确性 可行性 及完整性
同行评审人数:3-7人 人员必须经过同行评审会议的 培训,由SQA指导
阶段评审人数:5人左右 评审人必须是专家 具有系统评审资格
同行评审内容:内容小 一般文档 < 40页, 代码 < 500行
阶段评审内容: 内容多,主要看重点
同行评审时间:一小部分工作产品完成阶段评审时间: 通常是 设置在关键路径的时间点上!
11、简述集成测试的过程
系统集成测试主要包括以下过程:
1. 构建的确认过程。
2. 补丁的确认过程。
3. 系统集成测试测试组提交过程。
4. 测试用例设计过程。
5. 测试代码编写过程。
6. Bug的报告过程。
7. 每周/每两周的构建过程。
8. 点对点的测试过程。9. 组内培训过程。
12、怎么做好文档测试
仔细阅读,跟随每个步骤,检查每个图形,尝试每个示例。P142
检查文档的编写是否满足文档编写的目的
内容是否齐全,正确
内容是否完善标记是否正确
13、白盒测试有几种方法
总体上分为静态方法和动态方法两大类。
静态:关键功能是检查软件的表示和描述是否一致,没有冲突或者没有歧义动态:语句覆盖、判定覆盖、条件覆盖、判定条件覆盖、条件组合覆盖、路径覆盖。  
14、系统测试计划是否需要同行审批,为什么
需要,系统测试计划属于项目阶段性关键文档,因此需要评审。
15、Alpha测试与beta的区别
Alpha测试在系统开发接近完成时对应用系统的测试;测试后仍然会有少量的设计变更。这种测试一般由最终用户或 其它人员完成,不能由程序或测试员完成。
Beta测试当开发和测试根本完成时所做的测试,最终的错误和问题需要在最终发行前找到。这种测试一般由最终用户或其它人员完成,不能由程序员或测试员完成。
16、比较负载测试,容量测试和强度测试的区别
负载测试:在一定的工作负荷下,系统的负荷及响应时间。
强度测试:在一定的负荷条件下,在较长时间跨度内的系统连续运行给系统性能所造成的影响。
容量测试:容量测试目的是通过测试预先分析出反映软件系统应用特征的某项指标的极限值(如最大并发用户数、 数据库记录数等),系统在其极限值状态下没有出现任何软件故障或还能保持主要功能正常运行。容量测试还将确定测试对象在给定时间内能够持续处理的最大负载或工作量。容量测试的目的是使系统承受超额的数据容量来发现它是否能够正确处理。容量测试是面向数据的,并且它的目的是显示系统可以处理目标内确定的数据容量。
17、 请试着比较一下黑盒测试、白盒测试、单元测试、集成测试、系统测试、验收测试的区别与联系。 黑盒测试:把测试对象当成一个黑盒子,测试人员完全不考虑逻辑结构和内部特性,只依据程式的需求说明书来检查程式的功能是否满足它的功能说明。
白盒测试:把测试对象当成一个透明的盒子,允许测试人员利用程序内部逻辑结构及相关信息,设计或 选择测试用例,对程式所有逻辑路径进行测试。
单元测试:白盒测试的一种,对软件设计中的单元模块进行测试。
集成测试:在单元测试的基础上,对单元模块之间的连接和组装w进行测试。
系统测试:在所有都考虑的情况下,对系统进行测试。
验收测试:第三方进行的确认软件满足需求的测试。
18. 您所熟悉的测试用例设计方法都有哪些?请分别以具体的例子来说明这些方法在测试用例设计工作中的应用。
1.等价类划分
2.边界值分析法
3.错误推测法
4.因果图方法

你可能感兴趣的:(软件测试)