软件测试理论

news2025/1/12 21:38:02

测试理论

一 测试定义及原则

1 软件定义

一些列按着特定顺序组织的计算机数据和指令的集合:

软件 = 数据 + 指令 + 文档

2 软件分类

  • 工具类软件
  • 游戏类软件
  • 电商类软件
  • 社交类软件
  • 教育类软件等

3. 软件架构分类

  • 单机软件: office、红警等
  • 分布式软件
    • C/S 架构

      C指的是客户端软件(Client),S指的服务器端软件(Server)

    • B/S 架构

      B指的是浏览器(Brower), S指的是服务器端软件(Server),B/S模式,是Web兴起后的一种网络结构模式。Web浏览器(Brower)是客户端最主要的应用软件。这一种模式统一了客户端,将系统功能实现的核心部分集中在服务器上,简化了系统的开发、运维和使用。客户机上秩序只需安装一个浏览器,服务器上安装SQL Server,Oracle或Mysql等数据库;浏览器通过Web Server同数据库进行交互。

4. 软件测试的定义

通过人工或者自动化的方式来验证软件的实际结果与用户需求是否一致的过程

5. 软件测试的原则

  • 原则一: 测试显示软件存在缺陷

    测试只能证明软件存在缺陷,但不能证明软件不存在缺陷。软件测试是为了降低软件存在缺陷的可能性,即便没有找到缺陷,也不能证明软件是完美的。

  • 原则二:穷尽测试是不可能的

    现在的软件规模越来越大,复杂性越来越高,想做到完全性的测试是不可能的。在测试阶段,测试人员可以依据风险和优先级来进行集中和高强度的测试,从而保证软件的质量

  • 原则三:测试今早介入

    为什么测试要尽早介入呢?简单的说是保证软件的质量,降低风险和成本。测试人员一般从需求阶段开始介入,使缺陷在需求或设计阶段就被发现,缺陷发现越早,修复成本越小。

  • 原则四:测试集群性(2/8原则)

    缺陷集群性表明小部分模块包括大部分缺陷。软件测试中存在Pareto原则:80%的缺陷发现在20%的模块中。

    一个功能模块发现缺陷率越高,那存在的未发现的缺陷概率也越高,故发现缺陷和未发现缺陷成正比。

  • 原则五:杀虫剂悖论

    反复使用相同的杀虫剂会导致害虫对杀虫剂产生免疫而无法杀死害虫,软件测试也一样。如果一直使用相同的测试方法和手段,可能无法发现新的bug。

    为了解决这个问题,测试用例应该定期修订和评审,增加新的或者不同的测试用例帮助发现更多的缺陷。

    测试人员不能一直依赖现有的测试技术,而要不断的提升测试方法以提高测试效率。

  • 原则六:测试活动依赖测试内容

    根据业务的不同,软件测试内容也分不同的行业,比如游戏行业、电商行业、金融行业。不同的行业,测试活动的开展也有不同,比如测试技术、测试工具的选择、测试流程不仅相同,所以软件测试的活动开展依赖于所测试的内容。

  • 原则七:没有错误是好,是谬论

    有可能99.9%没有bug的软件也是不能使用的。如果对错误的需求进行测试的测试,这种情况发生了。软件测试不仅找不出缺陷,同时也需要确认软件是否满足需求。如果开发出来的产品满足不了用户的需求,即便找到和修复了缺陷也作用不大。

二 测试模型

2.1 开发模型

2.1.1 瀑布模型

瀑布模型是一个经典的软件生命周期模型,也叫预测型生命周期、完全计划驱动型生命周期。在这个模型里,在项目生命周期的尽早时间,要确定项目范围及交付此范围所需的时间和成本。瀑布模型是将软件生存周期的各项活动规定为按固定顺序而连接的若干阶段工作,形如瀑布流水,最终得到软件产品
在这里插入图片描述

  • 特点:是线性模型的一种,每一个阶段只执行一次
  • 优点:开发的各个阶段比较清晰,当前阶段完成后,只需关注后续阶段;有利于大型软件开发过程中人员的组织、管理,有利于软件开发方法和工具的研究,从而提高了大型软件项目开发的质量和效率****。可在迭代模型中应用瀑布模型
  • 缺点:很难清楚地给出所有的需求,不能响应需求的变化,风险往往在后期才显露;各阶段划分比较固定,阶段之间会产生大量文档,增大工作量。

2.1.2 原型模型

在需求分析阶段对软件的需求进行初步而非完全的分析和定义,用户与开发者在过程中加强反馈,快速设计开发出软件系统可以实际运行的模型;用户在运行使用整个原型的基础上,通过对其评价,提出改进意见,对原型进行修改,统一使用,评价过程反复进行,使原型逐步完善,直到完全满足用户的需求为止。

原型还分为两类:

  • 抛弃型原型,此类原型在系统真正实现以后就抛弃不用了
  • 进化型原型,此类原型的构造从目标系统的一个或多个基本需求出发,通过修改和追加的过程逐渐丰富,演化成为最终的系统

在这里插入图片描述

  • 特点:

    实际可行;具有最终系统的基本特征;构造方便、快速、造价低。

  • 优点:增加用户与开发人员的交流;用户在项目开发中占主导作用;满足用户的动态需求;降低开发风险。

  • 缺点:因为用户的参与,使得忽视原型对实际环境的适应性等技术问题,所以不适合大型、复杂项目开发;对于技术层面远大于其分析层面的问题不宜使用原型法。

2.1.3 增量模型

增量模型是把待开发的软件系统模块化,第1个增量往往是产品的核心,将每个模块作为一个增量组件,从而分批次地分析、设计、编码和测试这些增量组件。运用增量模型的软件开发过程是递增式的过程。相对于瀑布模型而言,采用增量模型进行开发,开发人员不需要一次性地把整个软件产品提交给用户,而是可以分批次进行提交。

在这里插入图片描述

  • 特点:最大特点就是将待开发的软件系统模块化和组件化;增量模型是瀑布模型和原型进化模型的综合;如同原型进化模型一样,增量模型逐步地向用户交付软件产品,但不同于原型进化模型的是,增量模型在开发过程中所交付的不是完整的新版软件,而只是新增加的构件。
  • 优点:将待开发的软件系统模块化,可以分批次地提交软件产品,使用户可以及时了解软件项目的进展;以组件为单位进行开发降低了软件开发的风险。一个开发周期内的错误不会影响到整个软件系统;开发顺序灵活。开发人员可以对组件的实现顺序进行优先级排序,先完成需求稳定的核心组件。当组件的优先级发生变化时,还能及时地对实现顺序进行调整。
  • 缺点:待开发的软件系统可以被模块化,如果待开发的软件系统很难被模块化,那么将会给增量开发带来很多麻烦;对项目管理人员管理全局水平有较高要求;对开发人员也有要求。

2.1.4 敏捷模型

先选择产品,再进行开会、对产品计划,然后对任务进行分工,分工后开始按照计划执行,然后就做出了新的功能模块,然后再进行演示、回顾,最后再领取新的任务,依次循环。

在这里插入图片描述

  • 特点:适应变化,注重反馈,灵活性强,快速迭代;适用于需求不明确,期限紧迫;
  • 优点:频繁交货;与客户面对面的交流;高效的设计并满足业务需求;随时可以接受更改;它减少了总的开发时间。
  • 缺点:由于缺少正式文件, 因此会造成混乱, 并且各个团队成员随时可能会误解贯穿各个阶段做出的重要决定;由于缺乏适当的文档, 一旦项目完成并且开发人员被分配到另一个项目, 完成的项目的维护就会变得很困难。

2.2 测试模型

2.2.1 V模型

在这里插入图片描述

  • 优点:
    • 包含了底层测试(单元测试)和高层测试(系统测试);
    • 清楚的标识了开发和测试的各个阶段;
    • 自上而下逐步求精,每个阶段分工明确,便于整体项目的把控。
  • 缺点:
    • 自上而下的顺序导致了,测试工作在编码之后,就导致错误不能及时的进行修改;
    • 实际工作中,需求经常变化,导致v模型步骤,反复执行,返工量很大,灵活度较低。改良:每个步骤都可以进行小的迭代工作。

2.2.2 W模型

定义:开发一个v;测试一个v组合起来的模型(w模型也叫双v模型)

在这里插入图片描述

  • 优点:
    • 开发伴随着整个开发周期,需求和设计同样要测试;
    • 更早的介入测试,可以发现初期的缺陷,修复成本低;
    • 分阶段工作,方便项目整体管理。
  • 缺点:
    • 开发和测试依然是线性的关系,需求的变更和调整,依然不方便;
    • 如果没有文档,根本无法执行w模型;对于项目组成员的技术要求更高.

三 软件测试的流程

在这里插入图片描述

四 测试分类

4.1 按技术分类

  • 黑盒测试: 把被测试的软件看做一个黑盒子,我们不去关心盒子里边的结构是什么样子,只关心软件的输入数据和输出结果
  • 白盒测试: 是一种按照程序内部逻辑结构和编码结构设计测试数据并完成测试的测试方法
  • 灰盒测试: 一种基于程序运行时的外部表现同时又结合程序内部结构来设计测试数据的测试方法

4.2 按阶段分类

  • 单元测试:对一个模块、一个函数或者一个类来进行正确性检验的测试方法;
  • 集成测试:单元测试后,将单独的模块按照设计要求组装成为子系统或系统,作为整体进行测试的测试方法;
  • 系统测试:集成测试后,将硬件、软件看作一个整体,对系统的功能及性能的总体测试;
  • 验收测试:系统测试后以用户测试为主,或有测试人员共同参与检验软件质量的测试方法。

在这里插入图片描述

4.3 按内容分类

4.3.1 功能测试

  • 功能测试:根据产品操作描述和需求文档,测试一个产品的特性和可操作行为是否满足用户需求的测试方法
  • 界面测试:测试用户界面的功能模块的布局是否符合客户使用习惯,界面操作便捷性、导航简单易懂性的测试
  • 冒烟测试:验证系统的核心功能是否能够正常运行的测试方法
  • 回归测试:指修改了旧代码后,重新进行测试以确认修改没有引入新的错误或导致其他代码产生错误的测试方法
  • 业务逻辑测试:在基本的功能点都已合格的基础上,准备多种测试数据,来驱动各种约束条件下业务流程,确定最终输出的结果是否符合预期的测试
  • 易用性测试:指用户使用软件时是否感觉方便的测试

4.3.2 性能测试:

  • 性能测试:通过自动化的测试工具模拟多种正常、峰值以及异常负载条件来对系统的各项性能指标进行校验的测试方法
  • 压力测试:通过逐步增加系统负载,测试系统性能的变化,并确定在什么条件下系统性能处于失效状态
  • 负载测试:通过逐步增加系统负载,测试系统性能的变化,在满足性能指标的情况下,系统所能承受的最大负载量的测试
  • 并发测试:是一个负载测试和压力测试的过程,即逐渐增加并发用户数负载直到系统的瓶颈,通过分析资源监控指标等来确定系统并发性能

4.3.3 兼容性测试:

  • app
    • Android/IOS版本
    • 厂商
    • 型号
    • 分辨率
    • 屏幕:全屏、水滴屏、刘海屏、曲面屏、折叠屏、双面屏
  • web
    • 浏览器:四类,根据浏览器内核(78)

4.4 其他分类

  • 随机测试:随机测试主要是根据测试者的经验无需测试用例对软件进行功能和性能抽查的测试方法;
  • 安全性测试:通过不同的测试方法,检验程序、网络、数据库安全性的测试方法;
  • 探索性测试:碰到问题时能随机应变,强调测试人员的主观能动性明确整体的测试计划的测试方法
  • Alpha测试:俗称内测,α测试。内部环境下的测试;开发人员或测试人员在现场
  • Beta测试:俗称外测、公测,β测试。生产环境下的测试;开发人员和测试人员都不在现场

五 测试分析及用例设计

5.1 用例分析方法

5.1.1 质量模型分析法

针对每个功能使用软件质量模型进行分析,分析应测特性,确认各功能的测试点以及测试项;

5.1.2 功能交互分析法

针对不同的功能确认各功能之间的交互操作,分析各功能交互时的测试特性,测试注意点,确认测试项;

5.1.3 用户场景分析法

针对所有功能,站在用户的角度考虑用户会怎么操作和使用这个功能,分析确认测试点以及测试项;

用例设计方法

5.2 测试用例的格式

用例编号测试项测试标题用例属性重要级别预置条件测试输入操作步骤预期结果实际结果
高中低

5.3 用例设计方法

5.3.1 等价类

  1. 等价类定义

  2. 等价类划分

  3. 等价类划分规则

  4. 进行等价类用例设计

  5. 案例

5.3.2 边界值

  1. 边界值的三个点

  2. 边界值应用场景

  3. 边界值的应用步骤

5.3.3 判定表

  1. 判定表定义

  2. 重要概念

  3. 判定表应用步骤

  4. 案例

5.3.4 因果图

  1. 输入与输入的关系

  2. 输入与输出的关系

  3. 案例

5.3.5 正交试验

  1. 因子和水平的定义

  2. 特点

  3. 设计流程

  4. 注意点

  5. 案例

5.3.6 状态转移

  1. 定义

  2. 状态

  3. 状态流程

  4. 案例

5.3.7 流程分析法(场景分析法)

  1. 设计三个流程

  2. 使用方法

  3. 注意点

  4. 案例

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

煤矿井下定位设备,实现特殊环境下人员安全管理

煤矿、金属矿山等地下作业场所的安全管理工作要求高、难度大,矿用人员定位系统通过实时定位等功能,可以帮助企业随时掌握作业人员的位置安全,提高生产和安全管理效率,并可在紧急情况时迅速采取措施,减少事故损失&#…

云原生容器安全检测有多难?安全狗云原生安全新版六招“泰酷辣”

想借助大规模部署和使用容器应用来提升业务系统开发速度?那你一定会发现,大量的数据对象、多种安全风险都需要检测,容器的安全检测难度增加了! 安全狗发现众多企业用户对安全的要求不再停留在“能用就好”的程度,于是新…

5种超超超实用的TikTok选品方法

是不是有很多人在做TikTok Shop时不知道该如何选品,面对琳琅满目的产品纠结该上哪款产品呢?今天就给大家介绍5种超实用的TikTok选品方法。 一、选品方法 1.从用户需求方面入手 做TikTok面向的是国外,所以选品时不能以国内的市场需求做参考&…

深入剖析SQL JOIN原理,助你掌握数据连接的奥秘!

大家好,我是小米,在技术的海洋中畅游的小编。今天,我要带你探索SQL JOIN的神奇原理,为你解锁高效数据查询的技巧!无论你是初学者还是资深开发者,相信这篇文章都能给你带来新的启发。废话不多说,…

算法技巧-双指针

欢迎关 Android茶话会 回 pdf 取阿里&字节经典面试题、Android、算法、Java等系列武功秘籍 在技术学习、个人成长的道路上,让我们一起前进! 前言 双指针技巧在算法题中算是常用技巧了,让我们省去for循环,降低复杂度&#xff…

第二十章_Redis分布式锁Redlock算法和底层源码分析

当前代码为8.0版接上一步 自研一把分布式锁,面试中回答的主要考点 按照JUC里面java.util.concurrent.locks.Lock接口规范编写 lock()加锁关键逻辑 加锁的Lua脚本,通过redis里面的hash数据模型,加锁和可重入性都要保证 加锁不成,…

NLP面经集结 | 达摩院、腾讯、微软、美团、百度

作者 | Codle 整理 | NewBeeNLP 面试锦囊之面经分享系列,持续更新中 赶紧后台回复"面试"加入讨论组交流吧 写在前面 本人情况:双非本末流985研二,爱奇艺NLP日常实习经历,无论文,投的都是 NLP 算法岗。 目前…

Ansible基础5——条件语句、循环语句、handlers、任务失败处理

文章目录 一、 循环语句1.1 单量循环1.2 多量循环1.3 老版本用法1.4 loopregister 二、条件判断2.1 根据变量状态判断2.2 根据变量是否存在判断2.3 根据事实判断2.4 多条件判断2.4.1 and用法2.4.2 or用法 2.5 循环判断2.6 根据上个任务结果判断 三、handlers处理程序四、任务失…

CDGA 认证:第十二章 元数据管理(重点章节)习题集解析

1. 以下内容不属于元数据综合解决方案功能需求点的是 ( ) A 历史信息 B 存储容量 C 运维要求 D 安全要求 【答案解析】DAMA-DMBOK2 P334 2. 关于 ISO/IEC 11179 元数据注册标准的说法正确的是:( ) A 该标准由 6 个部分组成 B 该标准用于定义元数据注册的框架 C 该标准包含…

Express+vue.js+nodejs银行排队取号系统

开发语言 node.js 框架:Express 前端:Vue.js 数据库:mysql 数据库工具:Navicat 开发软件:VScode 系统主要包括系统用户中心、显示管理、用户管理、排队管理、服务业务管理、用户评价管理、等候区管理等功能模块。 (a) 管理员&am…

00后求你善良,不要这么卷了...

前几天我们公司一下子也来了几个新人,这些年前人是真能熬啊,本来我们几个老油子都是每天稍微加会班就打算走了,这几个新人一直不走,搞得我们也不好走。 2023年春招结束了,最近内卷严重,各种跳槽裁员&#x…

Studio One6新生代DAW数字音频工作站

提到编曲软件,就不得不说这款水果编曲软件。它对新手和老手都比较友好,是一款较为经典的编曲软件。 这款软件提供了强大而全面的音符、音效编辑器,可以在其中插入各种乐器声音,如果内置乐器无法满足编曲需求,还可以外…

数据结构-递归

递归 概述 定义 计算机科学中,递归是一种解决计算问题的方法,其中解决方案取决于同一类问题的更小子集 In computer science, recursion is a method of solving a computational problem where the solution depends on solutions to smaller instan…

Web大前端时代之:HTML5+CSS3入门系列

Old: 联系源码:GitHub - dunitian/LoTHTML5: LoT家族的一员~HTML5系列 文档下载:https://github.com/dunitian/LoTDotNet/ 思维导图(不断更新): 图片:http://dnt.dkill.net/DNT/HTML5/index.jpg 源码&#…

超级全面的100个思维导图模板

思维导图是一款有效提升生活以及工作的效率工具。使用思维导图有非常多的好处。 思维导图可以用在我们生活的方方面面,以及各种各样的学科中。 接下来给大家分享不同的思维导图模板,希望可以帮助到大家。 一、读书笔记类 1、西游记 2、《战胜拖拉》读…

RabbitMQ - 简单案例

RabbitMQ - 简单案例 Hello worldWork Queues轮训分发消息消息应答自动应答手动消息应答的方法消息自动重新入队消息手动应答代码 RabbitMQ 持久化不公平分发 预取值分发 Hello world 我们将用 Java 编写两个程序。发送单个消息的生产者和接收消息并打印出来的消费者 在下图中…

Java实现Mqtt收发消息

Java实现Mqtt收发消息 文章目录 Java实现Mqtt收发消息windows mqtt 平台服务搭建mqtt 客户端工具:mqttbox整体代码结构mqtt基础参数配置类mqtt客户端连接mqtt接收的消息处理类对应的MqttService注解和MqttTopic注解 MqttGateway 发送消息指定topic接收处理方法 java…

基于Hive的数据应用实践总结

百分位数(percentile)计算 百分位数含义:统计学术语,如果将一组数据从小到大排序,并计算相应的累计百分位,则某一百分位所对应数据的值就称为这一百分位的百分位数。可表示为:一组n个观测值按数值大小排列。如&#x…

如何实现Java类隔离加载

一 什么是类隔离技术 只要你 Java 代码写的足够多,就一定会出现这种情况:系统新引入了一个中间件的 jar 包,编译的时候一切正常,一运行就报错:java.lang.NoSuchMethodError,然后就哼哧哼哧的开始找解决方法…

弹性盒子中的flex

flex属性是flex-grow&#xff0c;flex-shrink和flex-basis的缩写 flex是用在盒子中的子组件的&#xff0c;充分体现了弹性盒子的弹性二字。 例如现在的情况是&#xff1a; <div class"container"><div class"item1">Item1</div><d…