软件测试概述

七月的尾巴 七月的尾巴     2022-08-07     279

关键词:

• 不论软件的生产者还是软件的使用者,均生存在竞争的环境中:

软件开发商为了占有市场,必须把产品质量作为企业的重要目标之一,以免在激烈的竞争中被淘汰出局。

用户为了保证自己业务的顺利完成,当然希望选用优质的软件。

软件带来错误的原因很多,具体地说,主要有如下几点:

• 交流不够、交流上有误解或者根本不进行交流

• 软件复杂性

• 程序设计错误

• 需求变化

• 时间压力

• 代码文档贫乏

• 软件开发工具

什么是软件测试

软件测试就是在软件投入运行前,对软件需求分析、设计规格说明和编码的最终复审,是软件质量保证的关键步骤。

软件测试定义:

软件测试是为了发现错误而执行程序的过程。或者说,软件测试是根据软件开发各阶段的规格说明和程序的内部结构而精心设计一批测试用例(即输入数据及其预期的输出结果),并利用这些测试用例去运行程序,以发现程序错误的过程。

软件测试的目的

• 基于不同的立场,存在着两种完全不同的测试目的。

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

• 软件开发者的角度出发,则希望测试成为表明软件产品中不存在错误的过程,验证该软件已正确地实现了用户的要求,确立人们对软件质量的信心。

Myers软件测试目的

(1) 测试是程序的执行过程,目的在于发现错误;

(2) 一个好的测试用例在于能发现至今未发现的错误;

(3) 一个成功的测试是发现了至今未发现的错误的测试。

• 换言之,测试的目的是

– 想以最少的时间和人力,系统地找出软件中潜在的各种错误和缺陷。如果我们成功地实施了测试,我们就能够发现软件中的错误。

– 测试的附带收获是,它能够证明软件的功能和性能与需求说明相符合。

– 实施测试收集到的测试结果数据为可靠性分析提供了依据。

– 测试不能表明软件中不存在错误,它只能说明软件中存在错误。

软件测试的原则

1. 应当把“尽早地和不断地进行软件测试”作为软件开发者的座右铭。

2. 测试用例应由测试输入数据和对应的预期输出结果这两部分组成。

3. 程序员应避免检查自己的程序。

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

软件测试的原则

5. 充分注意测试中的群集现象。
经验表明,测试后程序中残存的错误数目与该程序中已发现的错误数目成正比

6. 严格执行测试计划,排除测试的随意性。

7. 应当对每一个测试结果做全面检查。

8. 妥善保存测试计划,测试用例,出错统计和最终分析报告,为维护提供方便。

测试生命周期

• 测试信息流

• 软件测试模型

• 软件开发周期

• 软件测试周期

测试信息流

• 软件配置:软件需求规格说明、软件设计规格说明、源代码等;

• 测试配置:测试计划、测试用例、测试程序等;

• 测试工具:测试数据自动生成程序、静态分析程序、动态分析程序、测试结果分析程序、以及驱动测试的测试数据库等等。

• 测试结果分析:比较实测结果与预期结果,评价错误是否发生。

• 排错(调试):对已经发现的错误进行错误定位和确定出错性质,并改正这些错误,同时修改相关的文档。

• 修正后的文档再测试:直到通过测试为止。

• 通过收集和分析测试结果数据,对软件建立可靠性模型

• 利用可靠性分析,评价软件质量:

– 软件的质量和可靠性达到可以接受的程度;

– 所做的测试不足以发现严重的错误;

• 如果测试发现不了错误,可以肯定,测试配置考虑得不够细致充分,错误仍然潜伏在软件中。

V模型

• 每个开发活动都有右边的测试活动相对应。

• 软件开发过程是一个自顶向下,逐步细化的过程.

• 测试过程是依相反顺序安排的自底向上,逐步集成的过程。

W模型

• 软件测试并不等于程序测试。软件测试应贯穿于软件定义与开发的整个期间。

• 需求分析、概要设计、详细设计以及程序编码等各阶段所得到的文档,包括需求规格说明、概要设计规格说明、详细设计规格说明以及源程序,都应成为软件测试的对象。

开发生命周期

测试生命周期

测试计划(test plan)

• 定义测试项目的过程,以便测试项目能被正确的度量和控制。

包括测试需求,测试策略,测试资源和测试计划。

• 确定测试需求

• 评估风险

• 制定测试策略

• 确定资源

• 创建时间表

• 生成测试计划

确定测试需求

• 确定测试需求是测试计划活动的开始。测试需求确定测试对象以及测试工作的范围和作用。测试需求还用来确定整个测试工作(如安排时间表、测试设计等)并作为测试覆盖的基础。

• 被确定的测试需求项必须是可核实的。即,它们必须有一个可观察、可评测的结果。无法核实的需求不是测试需求。

评估风险

• 确定并验证风险因子

• 确定并验证实施概要因子

• 确定并验证测试优先级因子

制定测试策略

• 要使用的测试技术和工具;

• 测试完成标准;

• 影响资源分配的特殊考虑;如测试与外部接口或者模拟物理损坏、安全性威胁。

确定测试资源

• 人力资源

– 测试经理

– 测试工程师—设计与开发

– 测试工程师—执行

– 测试系统管理者

• 系统资源

– 硬件和软件环境

– 数据库服务器

测试设计

• 为每个工作版本确定可验证的测试用例集。

• 确定如何实现测试用例的测试过程。

• 确定并说明测试用例

• 确立并结构化测试过程

• 复审并评估测试覆盖

测试开发

• 创建可以重用的测试过程和测试用例

• 维护测试过程、测试用例与相关测试需求的一一对应

– 设立开发环境

– 建立测试过程和测试用例

– 建立外部数据集合

测试执行

• 运行与被测试应用的软件构造相对应的测试过程集,并记录结果日志,包括缺陷报告和测试日志。

• 执行测试过程

• 评估测试的执行情况

• 核实测试结果

• 恢复暂停的测试

测试评估

• 分析测试结果,确定是否测试标准被覆盖的过程.

– 分析测试结果并提交变更请求

– 评估基于需求的测试覆盖

– 评估基于代码的测试覆盖

– 分析缺陷

– 确定是否达到了测试的完成标准和成功标准

– 生成测试评估摘要

• 为把握软件开发各个环节的正确性,需要进行各种确认和验证工作。

• 验证(Verification),是保证软件正确地实现了某一功能的一系列活动。

• 确认(Validation),指的是保证软件的实现满足了用户需求的一系列活动.

• 验证:“我们是否正确地完成了产品?”

• 确认:“我们是否完成了正确的产品?”

软件测试方法

• 两种常用的测试方法

– 黑盒测试

– 白盒测试

黑盒测试

• 这种方法是把测试对象看做一个黑盒子,测试人员完全不考虑程序内部的逻辑结构和内部特性,只依据程序的需求规格说明书,检查程序的功能是否符合它的功能说明。

• 黑盒测试又叫做功能测试或数据驱动测试。

• 黑盒测试方法是在程序接口上进行测试,主要是为了发现以下错误:

– 是否有不正确或遗漏了的功能?

– 在接口上,输入能否正确地接受? 能否输出正确的结果?

– 是否有数据结构错误或外部信息(例如数据文件)访问错误?

– 性能上是否能够满足要求?

– 是否有初始化或终止性错误? 

• 用黑盒测试发现程序中的错误,必须在所有可能的输入条件和输出条件中确定测试数据,来检查程序是否都能产生正确的输出。

• 但这是不可能的。

• 假设一个程序P有输入量XY及输出量Z。在字长为32位的计算机上运行。若XY取整数,按黑盒方法进行穷举测试:

• 可能采用的

测试数据组:

232×232

264

• 如果测试一组数据需要1毫秒,一年工作365× 24小时,完成所有测试需5亿年。

白盒测试

• 此方法把测试对象看做一个透明的盒子,它允许测试人员利用程序内部的逻辑结构及有关信息,设计或选择测试用例,对程序所有逻辑路径进行测试。

• 通过在不同点检查程序的状态,确定实际的状态是否与预期的状态一致。因此白盒测试又称为结构测试或逻辑驱动测试。

• 软件人员使用白盒测试方法,主要想对程序模块进行如下的检查:

– 对程序模块的所有独立的执行路径至少测试一次;

– 对所有的逻辑判定,取“真”与取“假”的两种情况都至少测试一次;

– 在循环的边界和运行界限内执行循环体;

– 测试内部数据结构的有效性,等。

• 对一个具有多重选择和循环嵌套的程序,不同的路径数目可能是天文数字。给出一个小程序的流程图,它包括了一个执行20次的循环。

• 包含的不同执行路径数达520条,对每一条路径进行测试需要1毫秒,假定一年工作365 × 24小时,要想把所有路径测试完,需3170年。

逻辑覆盖

– 语句覆盖

– 判定覆盖

– 条件覆盖

– 判定-条件覆盖

– 条件组合覆盖

– 路径覆盖。

语句覆盖 

• 语句覆盖就是设计若干个测试用例,运行被测程序,使得每一可执行语句至少执行一次。

• 在图例中,正好所有的可执行语句都在路径L1上,所以选择路径 L1设计测试用例,就可以覆盖所有的可执行语句。

• 测试用例的设计格式如下
【输入的(A, B, X),输出的(A, B, X)】

• 为图例设计满足语句覆盖的测试用例是:
【(2, 0, 4),(2, 0, 3)】 

覆盖 ace【L1】

判定覆盖

• 判定覆就是设计若干个测试用例,运行被测程序,使得程序中每个判断的取真分支和取假分支至少经历一次。

• 判定覆盖又称为分支覆盖。

软件测试概述基本介绍

目录1.软件测试概述1.1软件测试定义1.2软件缺陷的案例1.3Bug起源以及Bug类型1.4软件缺陷的严重程度和优先级1.5软件测试的目的和关键问题1.6软件测试的原则1.7软件开发与软件测试1.8.软件测试的过程模型1.9测试用例本课程主要介绍... 查看详情

软件工程导论软件工程学概述

软件工程学概述文章目录软件工程学概述一、软件危机1.1计算机系统的发展阶段1.2软件危机的介绍1.3软件危机典型表现1.4产生软件危机的原因1.4.1一方面与软件本身的特点有关1.4.2另一方面也和软件开发与维护的方法不正确有关1.... 查看详情

软件测试概述

 一.软件测试历史1972年举行第一次软件测试会议1979年给我软件测试经典定义1996年提出软件测试成熟度模型TMM,TDD2009年前谷歌/微软测试高管提出探索式测试理论 二.软件测试的定义1.早期定义:软件测试是对程序能够按预... 查看详情

软件开发概述编程语言概述

转载:http://www.cnblogs.com/hellokitty1/p/4032990.html程序语言的发展: 机器语言 汇编语言 高级语言   软件开发的基本步骤:分析问题,建立数学模型。 确定数据结构和算法。 编制程序。 调制程序。&n... 查看详情

软件开发概述编程语言概述

http://www.cnblogs.com/hellokitty1/p/4032990.html程序语言的发展: 机器语言 汇编语言 高级语言   软件开发的基本步骤:分析问题,建立数学模型。 确定数据结构和算法。 编制程序。 调制程序。  ... 查看详情

app测试1-app测试概述

App测试的分类1、UI测试2、功能测试安装:断网、弱网、安装后删除安装文件卸载、更新 3、兼容性测试  4、稳定性测试:monkey 5、极限测试耗电量测试:1)2)弱网环境测试:https://www.cnblogs.com/rookie-c/p/5753422.html6、... 查看详情

软件测试概述

• 不论软件的生产者还是软件的使用者,均生存在竞争的环境中:软件开发商为了占有市场,必须把产品质量作为企业的重要目标之一,以免在激烈的竞争中被淘汰出局。用户为了保证自己业务的顺利完成,当然希望选用... 查看详情

课程概述及团队简介

课程概述:软件工程是计算机专业的一门重要的专业基础课,它对于培养学生的软件素质,提高学生的软件开发能力与软件项目管理能力具有重要的意义。但是,软件的开发是一个很困难的活动,要求很仔细的计划和执行。课程... 查看详情

软件测试概述

1.缺陷的表现软件未实现产品说明书中要求实现的功能软件出现了产品说明书中制定不会出现的错误软件超出实现了产品说明书中提到的功能软件未实现产品说明书中虽未说明明确指出但应该实现的目标软件难以理解、不易使用... 查看详情

[接口测试概述]1.3http概述

一、http简介一个完整的http协议其实就两块内容,一个是发的请求,一个服务端给的响应。 1、http一般定义1)HTTP协议是HyperTextTransferProtocol(超文本传输协议)的缩写,是用于从万维网(WWW:WorldWideWeb)服务器传输超文本到本地... 查看详情

软件质量模型概述

软件质量模型简介软件测试的目的就是为了“验证产品质量是否满足用户的需求”。但是搞清楚,用户的需求并不是一件容易的事,因此在软件测试行业发展的漫长历史中,需要一种方式能够积累广大测试工程师的经验。这里的... 查看详情

软件质量模型概述

软件质量模型简介软件测试的目的就是为了“验证产品质量是否满足用户的需求”。但是搞清楚,用户的需求并不是一件容易的事,因此在软件测试行业发展的漫长历史中,需要一种方式能够积累广大测试工程师的经验。这里的... 查看详情

软件工程学概述

(1)什么是软件危机,具体表现,消除软件危机的途径(*)软件危机是指在计算机软件的开发和维护过程中所遇到的一系列严重问题答:“已完成”的软件不满足用户的需求;开发进度不能保障;软件开发成本和进度难以准确... 查看详情

第一节软件测试概述

  软件测试是软件质量保证的关键步骤,也是软件工程的重要组成部分,对软件产品的质量起着至关重要的作用。软件测试工作的目的就在于尽早找到软件缺陷,并保证其得到修复。1.软件及其特点  IEEEStd610.12给出了软件(So... 查看详情

软件测试的概述

   1,什么是软件测试       概念:在规定的条件下对程序 进行操作,以发现程序错误,衡量软件质量,并对其是否能满足设计要求进行评估的过程   2,软件测试的分类    按照开发阶段:... 查看详情

list集合的特有功能概述和测试

List集合的特有功能概述和测试A:List集合的特有功能概述voidadd(intindex,Eelement)Eremove(intindex)Eget(intindex)Eset(intindex,Eelement)packagecom.heima.list;importjava.util.ArrayList;importjava.util.List;publicclassDemo01_Li 查看详情

java面向对象编程概述

...言来编写程序代码,实现在设计阶段勾画出来的软件蓝图软件测试:测试软件是否能实现特定的功能,以及测试软件的运行性能软件部署:为用户安装软件系统,帮助用户正确使用软件软件维护:修复软件中已经存在的Bug,当用... 查看详情

软件测试概述结构化测试

一、软件测试的目的是在最小的成本和最短的时间内,通过设计良好的测试规程和测试用例,系统地发现不同类别的错误。 二、软件测试的基本原则设计好的测试用例、不可能进行穷举测试、尽早开展测试、重点测试、定期... 查看详情