软件测试介绍
软件测试:使用人工或自动的手段来运行或测定某个软件系统的过程
软件测试的目的:确认软件以正确的方式做了用户期望的事情
1 软件测试方法
以测试过程中程序执行状态可以分为:
- 静态测试:被测程序不运行,只依靠分析或检查源程序的语句、结构、过程等审查程序是否有错误,通过软件的需求规格说明书、设计说明书、以及源程序做结构分析和流程图分析找出错误,例如不匹配的参数、为定义的变量等。
- 动态测试:运行被测试程序,对得到的运行结果与预期的结果进行比较分析,同时分析运行效率和健壮性能等。测试步骤:构造测试实例、执行程序、分析结果
以测试时系统内部结构的差别分为:
- 黑盒测试:将被测程序看作黑盒,测试人员不考虑程序等内部结构和特性,根据需求规格说明书设计测试用例,并检测程序的功能是否能够按照规范说明准确无误的运行。
- 白盒测试:借助程序内部的逻辑和相关信息,通过检测程序内部动作是否按照设计规格说明书的设定进行,从程序结构出发色机测试用例,主要检查逻辑结构是否合理,每一条通路能否正常工作。常用的白盒测试手段:控制流分析、数据流分析、路径分析、程序变异,对测试用例的覆盖程度有:语句覆盖、判定覆盖、分支覆盖、路径覆盖。
- 灰盒测试;介于黑盒测试和白盒测试之间,灰盒测试除了重视输出相对于输入的正确性,也看重其内部的程序逻辑,但灰盒测试只是简单地靠一些象征性的现象或标志来判断其内部的运行情况,而不会像白盒测试那样详细和完整。因此,在程序内部结果出现错误,但输出结果仍然正确的情况下使用灰盒测试具有比白盒要高效,比黑盒适用性更广的优势。
以被测试程序执行的方式分为:
- 人工测试:测试人员通过手动运行测试程序得到测试结果
- 自动化测试:在预先设定的条件和规则下机器自动运行被测试结果,并分析测试结果
2 软件测试阶段
2.1 单元测试
单元测试主要是对软件的模块进行测试,发现该模块的功能不符合期望的情况和编码错误
首先通过静态测试方法,比如静态分析、代码审查等,按照程序的控制流图对该模块的源程序进行分析,以满足逻辑测试要求。
也可以采用黑盒测试提出一组基本的测试用例,再用白盒测试方法进行验证。
若黑盒产生的测试用例满足不了软件的测试要求,可采用白盒方法增补新的测试用例,以满足覆盖标准。
2.2 集成测试
集成测试通常对已经严格按照设计组装起来的模块同时进行测试,主要测试和接口有关的问题,一般采用白盒测试和黑盒测试结合的方法进行测试,验证程序设计的合理性以及对需求功能的实现性。
2.3 系统测试
系统测试主要检查系统是否符合软件需求,一般采用黑盒测试,主要测试内容包括
- 功能测试
- 性能测试
- 健壮性测试
- 安装或反安装测试
- 用户交互测试
- 压力测试
- 可靠性测试
- 安全性测试
为了保证系统测试的客观性,最好由不参与程序编码的独立测试小组来进行该阶段的测试。
由于不断变更的需求导致程序的更改,而程序在更改后可能出现新的问题,或者原本没有问题的功能由于程序更改导致程序出现问题,所以当程序发生变动时,测试人员还必须进行回归测试。
在进入下一阶段测试阶段前,还需要进行冒烟测试,冒烟测试通常会执行一组基本的测试用例,覆盖了应用程序的核心功能和主要功能点,通常是通过手动测试实现的。
2.3.1 性能测试
2.3.3 其它测试