当前位置:网站首页>【软件测试】概念篇

【软件测试】概念篇

2022-08-02 14:14:00 零雨z

1.什么是需求

我们根据一个具体的例子,分析需求:

举例:在社交APP上发朋友圈,类似微信朋友圈、qq空间这种
需求(发送朋友圈)–> 分析/设计(产品经理列出出功能、权限)–> 开发(开发人员根据具体的功能实现细节,文字/图片形式进行开发)–> 测试 --> 上线

用户需求:让APP拥有发布朋友圈这项功能,总体看起来比较简单。

软件需求:对用户需求具体细化,是用户需求的具体实现细节,开发人员根据软件需求开发。

需求包含两个方面:一个是用户需求,另外一个是软件需求

用户需求:一般比较粗略概括,没有细节,难以实现。
软件需求:软件需求是从用户需求转化而来的,是用户需求的细化使用户需求的具体实现细节和规范;

需要注意的是:软件需求是用户需求转化而来的

软件开发中的需求一般指的是:满足用户的期望或者合同规定的的标准、规范、文档所需要的条件和权限。

需求是软件测试的依据

软件测试人员如何深入了解需求?

从需求分析阶段就开始介入了解需求,站在用户需求的角度

2.什么是测试用例

测试用例:向被测试系统发起的一组集合,这组集合包含测试数据、测试步骤、测试平台、预期结果。

3.什么是BUG

当且仅当,程序规格说明书(软件需求存在)存在并且合理,若软件功能和软件规格说明书不相符合,我们就说软件错误。

当软件需求不存在,用户需求存在并且合理,软件功能和用户功能不相符合,就说明软件错误。

4.软件开发的五大模型

3.1瀑布模型

优点:是一个串行的过程。阶段性强,每一个阶段比较独立;看重前期的需求分析和测试(最后一道把关)。

缺点:测试在编码后才开始介入,导致前期问题后期才发现,会错失补救的机会。

3.2增量/迭代模型(在迭代模型的基础上一点点增量)

优点:抗击风险的能力强

3.3螺旋模型

优点:抗风险模型最强,适合于项目庞大,并且前期风险大,不是很明确的项目。

缺点:风险管控人力、物理投入很多,成本很大。

3.4敏捷开发模型(scrum流程)注重质量


个体与交互重与过程的工具,可用软件重于完备文档。

优点:轻文档、轻流程、重目标、重产出、随时拥抱用户变化。

PO(产品经理)

SM(项目经理)

ST(scrum team)

scrum流程:(1)发布计划会议:产品经理收集用户需求形成user story。

(2)迭代计划会议:分析用户故事,把user story分解成一个个任务,分配给开发人员,制定开发计划。

(3)每日站会:总结昨天做的事遇到的问题,今天的计划。

(4)产品会议:甲方、用户演示产品,把不足的地方收集成user story,下一次迭代改进。

(5)产品回顾会议:目的优化迭代流程。

3.5软件开发的生命周期(即软件开发的流程)

需求分析—计划—设计—开发(编码)—测试—运行维护
 

四.测试模型

4.1V模型

 

特点:每一个阶段独立性强。

          左边每一个阶段是右边测试阶段的依据,和右边每一个测试阶段一一对应。

缺点:编码后才进行测试(也是瀑布模型的缺点)

4.2W模型

特点:每一个阶段独立性比较强,测试从一开始就介入了,测试和开发同时进行,可以保证          前期问题的发现和纠正,保证了可靠性和正确性。

缺点:每一个阶段都是串行的过程,一个阶段完了以后就进入下一个阶段。

         不支持敏捷开发(不拥抱变化)。

 

原网站

版权声明
本文为[零雨z]所创,转载请带上原文链接,感谢
https://blog.csdn.net/lxyzzzzzz0/article/details/126087113