【软件测试】软件测试的基本概念和开发模型

1. 前言

在进行软件测试的学习之前,我们要了解软件测试一些基本概念. 这些基本概念将帮助我们更加明确工作的目标以及软件测试到底要做什么.

2. 软件测试的基本概念

软件测试的基本概念有3个,分别是需求,测试用例和BUG.

2.1 需求

这里的需求还可以分为 用户需求和软件需求,用户需求: 简单理解为甲方提出的需求. 软件需求: 开发人员要实现的软件功能. 软件也会作为开发和测试的依据.

一般来说 用户需求不能直接作为软件需求. 我们要对用户需求进行分析,这里的分析可能是从技术上分析(看技术是否可行). 从市场上分析(市场需求量),从成本上分析(成本与收益占比).

2.2 测试用例

测试用例意义就是:测什么,怎么测. 明确出要测试的要素,测试用例的要素包括标题,测试环境,操作步骤,测试数据和预期结果这五大要素.

标题: 简要说明这个测试用例是干什么的

测试环境: 不同的环境测试出来的结果可能不同

操作步骤: 不同的操作步骤测试出来的结果也可能不同

测试数据: 根据测试环境和测试步骤得出的结果

预期结果: 期望得到的结果

2.3 BUG

与产品规格说明书(需求文档)不符就算的上是BUG

主要有以下几点:

当且仅当产品规格说明书(需求文档)存在且正确的时候,程序实现地功能与产品规格说明书(需求文档)要求不匹配时,那就是软件错误.

当产品规格说明书(需求文档)没有提出的功能时,以用户为准.当程序没有实现用户合理预期(需要测试人员具有良好的产品思维)的需求时,这也是软件错误

3. 开发模型

开发模型(Software Development Model)是指软件开发全部过程、活动和任务的结构框架

3.1 软件/软件开发 的生命周期

软件/软件开发 的生命周期一般分为6个阶段: 需求分析->计划->设计->编码->测试->运行维护

需求分析: 这里的分析与前面一致,要进行市场分析,技术分析(站在技术的角度上看技术是否支持),成本和收入占比分析.

计划: 什么时候开始,什么时候结束.耗时多久

设计: 将大的需求拆分成一个个小的可执行任务

编码: 开发人员参考测试文档和开发文档等进行功能实现

测试: 测试人员进行测试

运行维护: 运行维护要具有完善性,修复性和预防性.当产品上线之后,用户开始使用.当用户发现了测试人员没有发现的BUG,后面测试开发人员对BUG进行修复,同时也对可能出现的BUG进行处理

软件测试贯穿软件的整个生命周期

3.2 软件测试的生命周期

软件测试分为以下几个阶段: 需求分析->测试计划->测试设计与开发->测试执行->测试评估

需求分析: 1. 站在用户角度上思考问题: 判断软件需求是否合理. 2. 站在技术的角度上思考问题:技术上是否可行,还有没有优化空间. 3. 站在测试的角度上思考问题: 判断当前的业务逻辑是否存在冗余/冲突

测试计划: 什么时候开始测试,什么时候结束测试,测试耗时多久

测试设计与开发:1.写测试文档,明确标注测试方法,测试工具,测试形式等等. 2. 编写测试用例

测试执行:充分利用测试用例和其它工具对项目尽可能的全覆盖测试

测试评估: 评估产品是否有其它质量问题,功能演示

项目测试完成之后,需要进行项目上线.项目上线之后,测试人员也需要及时关注产品是否出现了问题.

如果出现了问题:

尝试复现,判断这个问题是普遍出现的还是个别情况.

尝试定位问题出现的原因,帮助开发人员定位尽快定位问题并解决问题

反思问题:为什么会出现问题,如何解决,今后如何避免问题.

3.3 瀑布模型

瀑布模型在软件工程中占有重要地位,是所有其他模型的基础框架。瀑布模型的每一个阶段都只执行一次,因此是线性顺序进行的软件开发模式。

瀑布模型流程图:

主要就是以下几个步骤:

瀑布模型的特点:

1.线性结构,每个结构只执行一次

2.是所有其他模型的基础框架

瀑布模型的缺点:

1.测试后置.(1)测试前的各阶段遗留的风险推迟到测试阶段才会被发现,这会导致项目大规模返工,失去了早点发现解决问题的机会. (2) 必须留足够的时间给测试阶段,如果测试不充分,缺陷就会暴露给用户.

2.周期太长,产品很迟才能被看到和使用,可能导致需求过时.

瀑布模型的适用场景: 需求固定的小项目

3.4 螺旋模型

螺旋模型流程图:

上面这张图不太好看,接下来我们用瀑布模型的方式来理解这张图.

看这张图:

螺旋模型与瀑布模型相比增加了 风险分析和原型. 在需求分析,计划和设计之后要进行风险分析,每次风险分析之后就会得到一个新的原型.而在经过设计之后的风险分析之后就会得到一个可执行原型.

螺旋模型的特点: 增加了 风险分析和原型

螺旋模型的缺点:

项目中可能存在的风险性和风险管理人才的技能水平有直接关系

需要人员,资金,时间的成本增加和投入,项目的成本太高

螺旋模型的适用场景: 规模庞大,复杂度高,风险大的项目

3.5 增量模型

增量模型流程图:

增量模型把一个大的需求分成了一个个可独立开发上线的功能.

例如一个项目里面要实现很多功能,可以先开发里面的一部分功能,开发完成之后就可以先进行上线,等其它也开发完成之后,再去上线其它功能. 这就是增量模型的流程

3.6 迭代模型

迭代模型就是先完成基本的功能,然后在根据需求不断地取改善优化这些基本的功能

3.7 敏捷模型

敏捷开发有很多种方式,其中scrum是比较流行的一种。

scrum模型中有三个角色: 产品经理,项目经理和研发团队.

五个重要会议:发布计划会议,迭代计划会议,每日例会,演示会议和回顾会议

发布计划会议: 确定最终的需求

迭代计划会议: 任务拆解,确定责任人,工时评估

每日例会: 了解当前项目的进度,每日会议后要给出"可交付的软件"

演示会议: 产出用户需求

回顾会议:总结当前迭代周期中的不足,并在下一次迭代中进行优化

敏捷模型的特点:1. 轻流程 2. 轻文档 3. 重目标 4. 重产出

4. 测试模型

以上都是开发模型,测试模型有V模型和W模型

4.1 V模型

V模型特点: 1.测试过程中存在不同类型的测试 2.测试阶段的参考标准以前面对应阶段为准

缺点: 测试后置(与前面相同)

4.2 W模型

W模型也称"双V模型"

W模型增加了软件各开发阶段中应同步进行的验证和确认活动。

W模型特点:测试的对象不仅是程序,需求、设计等同样要测试,测试与开发是同步进行的

W模型优点:1.有利于尽早地全面的发现问题。2. 对需求的测试也有利于及时了解项目难度和测试风险,及早制定应对措施,显著减少总体测试时间,加快项目进度。

W模型的缺点:1. W模型重流程,不适应与敏捷模型. 2.测试和开发活动也保持着一种线性的前后关系,前一项工作完成才能开展后一项工作

5. 总结

本文主要讲解了软件测试的三个基本概念,开发模型和测试模型的特点,缺点和适用场景. 概念较多,看起来也很枯燥乏味,但是掌握基本概念才能更好地学习软件测试.

 

总结:

感谢每一个认真阅读我文章的人!!!

作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。

  1. 文档获取方式:

  2. 加入我的软件测试交流群:680748947免费获取~(同行大佬一起学术交流,每晚都有大佬直播分享技术知识点)

这份文档,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!

以上均可以分享,只需要你搜索vx公众号:程序员雨果,即可免费领取

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/543684.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Docker使用(二)Docker安装和常见典型操作

Docker使用(二)Docker安装和常见典型操作 二、软件安装 1、Docker安装 (1)环境准备 [rootlocalhost ~]# uname -r 3.10.0-327.el7.x86_64 # cat /etc/os-release (2)卸载旧版本 $ sudo yum remove docker \ ​ docker-cli…

数学建模--MATLAB基本使用

1.线性方程组 这个是一个线性方程组(属于线性代数的范畴),Axb类型的方程,如果使用MATLAB进行求解,就需要分别表示A矩阵(线性方程组未知数前面的系数),b矩阵(表示等式右边…

什么是资源子网和通信子网有什么特点

资源子网和通信子网是计算机网络中常见的两种子网类型,它们分别承担着资源管理和数据传输的重要功能。资源子网以共享资源为核心,通过集中管理和高效共享提高了资源利用率,而通信子网则负责连接不同资源子网,实现数据的传输和通信…

【拓扑空间】可分性2

可分拓扑空间 如果拓扑空间有可数的稠密子集,则称是可分拓扑空间。 可分:有可数子集A, 拓扑空间: 1., 2.任意并 3.有限交 稠密: 闭包 导集:所有聚点的集合 聚点:任意去心领域&am…

电商系统秒杀一 秒杀的各种解决方案以及存在的问题

一 业务场景介绍 1.1 正常电商流程 1.2 活动和场次关系 秒杀活动表:sms_flash_promotion DROP TABLE IF EXISTS sms_flash_promotion; CREATE TABLE sms_flash_promotion (id bigint(20) NOT NULL AUTO_INCREMENT,title varchar(200) CHARACTER SET utf8 COLLAT…

hcia复习总结7

1,AR2发送2.0网段的信息给AR1,如果,AR1本身并不存在该网段的路由 信息,则将直接 刷新 到本地的路由表中。 Destination/Mask Proto Pre Cost Flags NextHop Interface 2.2.2.0/24 RIP 100…

有什么好赚钱的副业可以做吗?盘点6个互联网搞钱项目

网上互联网赚钱的项目千千万,每个博主都说自己赚到钱了。很多人既羡慕又慌张,特别幻想自己也月入几万,又怕错过赚钱的机会。那么今天就先为大家简单盘点6个互联网搞钱项目,帮助大家了解一下,也避避坑。这些项目收入可能…

关于Camera出图,有竖线问题的排查步骤

1、问题背景 之前调试的一个项目,在生产过程中,工厂反馈有台设备出图有明显的规则竖条纹,现象如下附件图所示: 遇到此类图像异常的问题该如何去分析呢,这是本文要总结的内容。 2、问题分析 1)首先要从客户…

【yocto2】利用yocto工具构建嵌入式Linux系统

1.定制化嵌入式linux系统 在实际项目中,一款嵌入式产品往往具有不同的硬件平台和软件需求,因此需要对嵌入式Linux系统进行定制,以满足不同的产品需求。之前的章节中基于Freescale官方提供的例程,构建了运行于imx6ull14x14evk硬件…

18.古今成大事者,必以多选替身为第一要义——代理模式详解

“杏市而外,尚有何人可以分统?亦须早早提拔。办大事者以多多选替手为第一义,满意之选不可得,姑节取其次,以待徐徐教育可也。 ——曾国藩同治元年四月十二日” 一言 代理模式核心思想是为对象提供一个替身,以控制对这…

029—pandas 遍历行非向量化修改数据

前言 在 pandas 中,向量化计算是指利用 pandas 对象的内置方法和函数,将操作应用到整个数据结构的每个元素,从而在单个操作中完成大量的计算。 但在一些需求中,我们无法使用向量化计算,就需要迭代操作,本例…

汽车电子零部件(4):行泊一体ADAS

前言: 现阶段智能汽车行业正在大规模力推无限接近于L3的L2++或L2.9自动驾驶量产落地,类似于当初智能手机替换传统手机的行业机会期。智能汽车常见的智能驾驶功能包括: 行车场景:自适应巡航控制ACC;自动变道辅助ALC;交通拥堵辅助TJA;车道居中LCC;领航辅助NOA; 泊车场…