当前位置:网站首页>测试基础整合-测试分类、软件质量模型、测试流程、测试用例、测试点划分方法、缺陷、例子

测试基础整合-测试分类、软件质量模型、测试流程、测试用例、测试点划分方法、缺陷、例子

2022-08-03 14:50:00 理不尽的神之手

content1:该阶段的目标-能独立完成软件的功能测试,注重测试思路的养成

  • 目标达成路线:测试基础(软件及测试相关知识)->测试设计(如何进行测试,设计测试点,编写测试用例)->缺陷管理(测试发现缺陷如何处理)->项目实战

  • web项目请求和响应
    在这里插入图片描述

  • 工作流程
    在这里插入图片描述

  • 软件测试定义:使用技术手段验证软件是否满足需求

  • 测试主流技术
    1.功能测试:验证软件功能是否满足需求
    2.自动化测试:使用代码或工具代替手工,对项目进行测试
    3.接口测试:使用代码或工具对接口进行测试
    4.性能测试:模拟多人使用软件,查看性能缺陷

  • 就业方向:
    1.功能测试+接口测试
    2.功能测试+性能测试
    3.功能测试+web自动化测试
    4.我的目标:功能测试+接口测试+自动化测试+性能测试

content2:测试分类

  • 按测试阶段划分:
    1.单元测试:针对程序源代码进行测试
    2.集成测试:主要测试接口,针对模块之间访问地址进行测试
    3.系统测试:对系统整体进行测试,包括功能、性能、兼容、易用、安全等(功能和非功能)。
    4.验收测试:内测、公测,使用不同人群来发掘项目缺陷

  • 按代码可见度划分:
    1.黑盒测试:源代码不可见,UI、功能可见
    2.白盒测试:源代码全部可见
    3.灰盒测试:部分源代码可将(接口)

  • 其他划分:
    1.性能测试:归属专项测试
    2.自动化测试:属于功能测试

content3:软件质量模型

  • 质量模型:这是测试关注的地方,测试方向也往质量模型中套,质量模型是衡量优秀软件的维度。
    在这里插入图片描述
  • 可靠性:
    1.程序出现无响应
    2.卡顿:响应时间慢
    3.死机:程序崩溃
    在这里插入图片描述
  • 常考虑的测试项:
    1.功能
    2.性能
    3.兼容
    4.易用
    5.信息安全性

content4:软件测试流程

  • 测试整体测试流程:需求评审->计划编写->用例设计->用例执行->缺陷管理->测试报告
  • 个人拿到单模块的测试任务的工作流程:
    1.熟悉模块需求
    2.测试需求分析
    3.测试计划
    4.设计功能点
    5.编写测试用例
    6.缺陷管理
    7.个人总结

content5:测试用例

  • 测试用例:测试用例的本质就是模仿用户的操作

  • 测试用例的作用
    1.防止漏测
    2.实施测试的标志
    3.评估工作量

  • 用例编写格式(用例的要素):
    1.用例编号:项目简称_模块_编号,例如:wx_login_001
    2.用例标题:期望结果(测试点),例如:登陆成功(11位已注册手机号)
    3.项目/模块
    4.优先级:例如P1,像是登录成功一定是P1,优先级最高。P1-P4,用例优先级的划分文章后面详细讲解。
    5.前置条件:换位思考,测试用例是给测试执行人员看的,测试执行人员该怎样做,写关键的前置条件,言简意赅。
    6.测试步骤:测试步骤可与测试数据分离,形成简洁明了的测试步骤
    7.测试数据:用例执行的关键数据
    8.预期结果

  • 测试用例excel的格式建议:
    1.冻结首行
    2.首行文字居中,加粗,比一般文字大2字号
    3.首行背景为科技蓝
    4.表格有所有框线
    在这里插入图片描述

content5:等价类划分

  • 用例编写方法(其实是测试点设计的方法)
    1.对穷尽场景设计测试点:等价类划分
    需求:验证QQ账号的合法性,QQ账号合法:6-10位自然数
    在这里插入图片描述

  • 实际工作数据涉及的方面无非是:长度、类型、规则,然后从正向、逆向思考,配合质量模型思考(功能、性能、兼容、易用、信息安全性)

  • 等价类用例的注意事项:
    1.等价类的正向用例:一条用例尽可能多的覆盖有效等价类
    2.等价类的逆向用例:一条用例只能覆盖一个无效等价类

  • 等价类的适用场景:
    1.需要大量数据输入的测试,但无法穷举测试:输入框、下拉框、单选、复选(其实等价类常常配合边界值划分法)
    2.典型代表:页面输入框类测试

content6:边界值

  • 边界值划分,对限定边界规则设计测试点,通常采用5点法、或者7点法

  • 例子:长度(取值范围)使用边界,例如6-10位 [6,10],边界值:5,6,7,8,9,10,11(7点法)但这样划分用例太冗余,那么就采用5点法,5,6,8,10,11;类型和规则可采用等价类,例如6-10位自然数,类型:自然数、非自然数

  • 边界值的节点引出了:专业说法(上点、离点、内点)
    1.上点:边界上的点
    2.离点:离边界值最近的点
    3.内点:边界值范围内的点

  • 上点必须测试,内点必须测试,选择中间数(为什么选中间数,可以测试代码连续性范围),离点选择开内,闭外的原则,开区间就选最近的内部离点,闭区间选择最近的外部离点

  • 例如[6,10],选择5,6,8,10,11

  • 例如(6,10],选择6,7,8,10,11

  • 边界值最多划分7条用例

  • 边界值划分的应用场景:有边界范围的输入框,例如6-10位账号,9-10位用户名

  • 延伸:一般情况下,像是账号测试,还会考虑账号为空,账号未注册等方面

content7:判定表

  • 判定表:解决多条件的依赖

  • 判定表引入:

  • 案例:验证”用户欠费或关机,则不允许主被叫“功能的测试

  • 说明:等价类边界值主要关注单输入条件的测试,没有考虑多条输入条件之间的组合、输入条件与输出结果之间的制约关系
    在这里插入图片描述
    在这里插入图片描述

  • 判定表的组成:
    条件桩:列出问题的所有条件
    动作桩:列出可能采取的操作
    条件项:列出条件对应的取值,真价值
    动作项:列出条件项组合下的动作项采取的结果
    判定表上贯穿条件项和动作项的一列就是一条规则,如果有n个条件,每个条件的取值只有真假,那么有2^n条规则

  • 判定表适合输入条件组合比较少的情况,一般建议4个条件之下(软件设计会解耦,减少依赖,条件组合情况就比较少)

content8:场景法

  • 场景法:解决业务场景的覆盖,前提就需要流程图
    在这里插入图片描述

  • 流程图的作用:
    1.根据流程图设计业务用例
    2.当需求文档信息不全,能根据需求,梳理流程

在这里插入图片描述

  • 场景法也叫流程图法,用流程图描述用户的使用场景,通过覆盖路径来设计测试用例

  • 场景法的意义:
    1.用户平时使用的不是单个功能而是多个功能的组合
    2.测试人员常关注单功能的测试,容易忽略多个功能组合测试

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 验证程序能否跑通一般叫做冒烟测试

  • 场景法的意义就是验证用户的使用场景,包括正确场景和错误场景

  • 批量测试之前,正式测试之前应该怎么做?面试题
    做冒烟测试,跑主要业务流程,测试重要的功能,看软件是否具备可测性,执行业务正向用例(用例一般由测试人员提供)

  • 错误推测法:根据经验,列出可能出现问题的清单,根据清单去测试;适用于:时间任务紧(今天测试组长就给你分配某模块的测试任务,让你明天给结论),可以根据之前项目类似经验找出易错模块重点测试;时间宽裕,列出之前问题出现多的模块再次测试

content9:缺陷

  • 缺陷的定义:软件在使用过程中存在的任何问题都叫做

  • 注意:这里指的是任何问题,而不是软件的任何错误

  • 缺陷判定的标准:
    1.软件未实现需求明确要求的功能 少功能
    2.软件出现需求说明书指明的不应该出现的错误 功能错误
    3.软件实现的功能超出需求说明书的范围 多功能(相当于你娶媳妇,媳妇还带个前夫的孩子(只是举例子哈,没有歧视的意思,如果是因为爱,我觉得没啥问题))
    4.软件未实现需求规格说明书虽未明确指明但应该要实现的要求隐性功能缺少这里有个延伸,实际测试中像是修改数据,新增数据,操作后应该测试是否有提示,能否查看到操作结果
    5.测试人员认为软件难以理解,不宜使用,运行缓慢,用户体验度不好 不易使用

  • 缺陷产生的原因:
    1.需求阶段:需求描述不易理解,有歧义,错误(需求一般由产品来写)
    2.设计阶段:设计文档存在错误(架构师设计软件架构错误等;架构师设计软件架构,设计数据库结构,表字段,甚至软件中的方法,方法的作用都给你写好,让你编码填空)
    3.编码阶段:编码出现问题
    4.运行阶段:软硬件系统本身故障导致软件缺陷

  • 缺陷的生命周期
    在这里插入图片描述

  • 故障分类:前端Bug还是后端Bug

  • 为什么要引入自动化:缺陷的修复可能引入BUG,就需要进行回归测试

  • 软件缺陷的核心内容
    1.缺陷的标题(标题要写好,让开发看出来是哪里错误,很难写,但套模板写就很轻松,模板:测试数据+实际结果(预期:预期结果))
    2.预置条件
    3.复现步骤
    4.预期结果
    5.实际结果
    6.附件

  • 缺陷提交要素:
    1.缺陷报告编号:缺陷的唯一性标识
    2.严重程度(servious): 严重(S1):主要功能;一般(S2):次要功能;微小(S3):易用性、界面;建议(S4):建议性问题。
    3.优先级(priority):P0:24小时内解决,P1;发布前解决,P2:下个版本中修复
    4.BUG类型(厉害的测试人员能发现缺陷是代码错误还是设计错误还是什么问题):代码错误、兼容性错误、设计缺陷、性能问题;这里就有个面试题:你发现的BUG如何判断是前端还是后端的问题?一般通过抓包,看请求数据是否正确,请求数据不正确就是前端问题,反之就是后端问题;还有前端发送正确数据,后端无响应就是后端问题;还有后端代码是正确的,返回给前端的数据也是对的,但前端数据显示错误,就是前端问题
    5.缺陷的状态:new(新建),open(打开),closed(关闭),postponed(延期)

  • 缺陷类型:
    1.功能错误
    2.UI错误
    3.兼容性错误
    4.数据错误
    5.易用性错误
    6.改进意见
    7.架构错误

    其中UI错误、易用性错误、兼容性错误一定属于前端

  • 缺陷的标题:缺陷标题想达到的效果
    1.直到问题出在哪儿?
    2.与预期的差距
    那么缺陷标题可以写成:测试数据+实际结果(预期:预期结果)

  • 缺陷的流程
    在这里插入图片描述

  • 这里判断缺陷是否重复,不是判断提交的缺陷内容是否重复,而是判断这一类缺陷产生的原因是否重复->例子:测试人员发现一个缺陷,开发人员发现这个BUG是长度计算错误导致的,测试人员下一个提交的缺陷也是相同的原因(长度计算错误)导致的,开发人员就认为这个缺陷提价重复了,这就隐性要求测试人员最好懂开发

  • 这里提交缺陷,判断是否是BUG就又引出一个面试题:你认为这个问题是BUG,开发认为这个问题不是BUG怎么解决->例子:用户登录,密码错误,提示“密码错误”,测试人员你认为这是个BUG,应该提示“账号或密码错误”,你是处于安全角度考虑,但开发认为这不是BUG,他说自己一直是这样的写法,提示给用户的信息十分明确,能让用户明白自己错误的是账户还是密码,从易用性的角度考虑的。这该怎么解决?

  • 解决办法:测试和开发产生歧义,是因为没有衡量标准,拉测试、开发、产品开个会,站在测试角度阐述自己的观点,如果都认可的话就这样做。

  • 提交缺陷注意事项;
    1.可重现:缺陷可以复现
    2.唯一性:一个缺陷上报一个问题(例如,你发现几个问题都是因为后台没进行判空处理导致额,提交一个缺陷就行了)
    3.规范性

  • 缺陷编写规范:
    1.准确
    2.简洁易懂
    3.具体
    4.次序清晰

  • 缺陷管理工具:国内最常用的缺陷管理工具:禅达,JIRA(同时也是项目管理工具)

禅道特点:三权分立,四角协同
1.产品、研发、测试都可以用
2.产品经理、项目经理、研发团队、测试团队协同工作

在这里插入图片描述
在这里插入图片描述

  • 为什么改变版本:如果团队有十个开发,开发修改一次就要改变版本,目的是为了版本控制

在这里插入图片描述

  • 注册测试点分析:测试点一般用Xmind写,或者在线思维导图工具

  • 测试流程(针对项目):
    1.需求评审
    2.测试计划
    个人实施:个人测试计划
    * 熟悉自己负责模块的需求
    * 根据需求设计测试点:(设计方法:边界值、等价类、判定表、场景法)
    * 编写用例覆盖测试点
    * 执行用例
    * 缺陷管理
    * 测试总结
    3.用例设计
    4.用例执行
    5.缺陷管理
    6.测试报告

就拿注册来设计测试点(功能的):
手机号:手机号码11位
密码:6-16位,不能纯数字、不能纯字母、字母+数字
图片验证码:
短信验证码:
邀请人:
勾选协议:

在这里插入图片描述

  • 非功能:
    1.兼容(兼容关注功能是否正确,布局是否和原型图一致,图片文字是否正确)
    • Edge:最新版本
    • 用例标题:注册页面显示是否正确,功能是否正确
    • 操作:打开注册页面,输入所有正确信息,点击注册
    • 预期:注册成功,登录并跳转到个人主页;显示布局与原型图一致;文字,图片等页面元素正确无误
    • IE:开发者工具->仿真->切换版本 ie8、ie9、ie10、ie11
    • 谷歌:最新版本
    • 火狐:官网查看使用版本用户画像,哪个版本使用的人多
    • 苹果:官网查看使用版本的用户画像
      2.易用(软件的易用性怎样衡量一般没有标准,但UI布局可以测试,看UI布局是否与原型图一致)

面试题:1.什么是缺陷?软件使用过程中存在的各种问题
== 2.你们公司的缺陷优先级怎样划分的?1级冒烟正向业务用例;2级冒烟逆向业务用例、单功能正向;3级但功能逆向、UI布局;4级建议和意见==
== 3.发现缺陷怎么办?确保缺陷能复习,然后提交,验证,回归,关闭==
== 4.缺陷类型:代码、UI、兼容、功能、性能、易用==

content10:HTML认识

面试题:前端页面注释这里有个测试点:有个现实的例子,虾米音乐的注释
在这里插入图片描述
前端注释测试点:上线前对前端页面注释进行检查或者进行去除

  • Hbuilder复制当前行:ctrl+c
  • 使用a标签,href属性的值要写http,代表http协议
<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
	</head>
	<body>
		<a href="http://www.baidu.com" target="_blank">baidu</a>
		<!--如果traget的属性错误,默认_blank方式打开,这体现了代码的健壮性-->
		<!--如果targe属性的值http后写中文冒号:,前端网页点击标签,提示未找到文件,这报错信息“未找到文件/front_end/http%EF%BC%9A//www.baidu.com”,请检查访问路径是否正确”就能提示我们是不是冒号写错了-->
	</body>
</html>
  • 前端图片测试点:必须有titile,用户体验度好
    在这里插入图片描述
  • img标签的src属性的值引出来的问题:相对路径
    1.同级./
    2.上一级…/

表单的method属性的面试题:get和post的区别
get:
1.明文提交,所有参数在url可见
2.速度快
3.提交的内容长度有限制
4.产生一个TCP的数据包
post:
1.非明文提交,数据在request body中
2.速度慢
3.提交内容长度无限制
4.产生2个TCP的数据包
对于GET方式的请求,浏览器会把http header和data一并发送出去,服务器响应200(返回数据);
而对于POST,浏览器先发送header,服务器响应100 continue,浏览器再发送data,服务器响应200 ok(返回数据)。
其实get和post提交选择:看数据是否敏感,像是查询数据用get提交速度快,像是登陆输入的个人数据用post提交,密码采用加密传输。
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

content11:测试例子

  • 登录测试点
    在这里插入图片描述
    在这里插入图片描述

  • 面试题:下拉框测试点:
    在这里插入图片描述
    1.显示内容是否正确(文字这些)
    2.每页显示条数是否正确
    3.下拉框选项排序是否正确

  • 面试题:文章标题的逆向思考,会有黑字典(敏感词)的过滤,还有就是用户输入信息,常在输入信息前后加上空格,出于信息安全性的角度考虑还可能有黑客进行SQL注入,写入前端代码之类的

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 面试题:练习功能测试花瓶用例
    思路:从质量模型出发,功能,性能,兼容,易用,安全等角度出发
    在这里插入图片描述

解:
功能性:

  1. 插花
  2. 装水
  3. 养鱼
  4. 种菜…

性能:

  1. 防摔
  2. 耐高温、耐低温
  3. 使用最大时长多久

易用性:

  1. 是否便携
  2. 是否容易使用
  3. 是否耐摔

兼容性:
1、能否在屋内、室外使用
2、能否插各种不同的花
3、高温、低温情况下能否正常使用

安全:
1、是否安全无毒
2、破摔的块片是否安全
3、是否防盗

content12:缺陷例子

在这里插入图片描述

content13:延伸思考

  • 易用性:有些网址的注册页面,用户要填写的所有信息都在一个页面,一些用户看见要填写这么多的信息,顺手就关掉了网页;但一些网址的注册页面还用来“心理学的知识”,将要填写的注册信息分不到几个页面,这样用户填完第一个页面的信息,点击下一步来到第二个页面,发现还要填写信息。如果退出的话,前面填写的信息就浪费掉了,然后进行填写注册信息。
    在这里插入图片描述
    面试题:对朋友圈进行用例设计
    1.从功能、性能、兼容、易用、安全角度出发:
    2.从功能角度:能否发图片、能否发文字、点赞、留言、收藏、删除、隐藏
    3.性能角度:10个好友同时访问朋友圈,能否快速响应等
    4.从兼容性角度:4G、WiFI情况下验证发图片
    5.易用性角度:图片发一半,应用切换后返回微信,是否还在之前的页面,图片是否上传完成,相关内容是否存在
    6.安全角度:不是好友能否看见朋友圈信息,能否留言

自己写的用例一般都是交给其他测试人员执行:原因是,思维定式,可能产生漏测,其实就是偷懒思维。

面试题:为什么有边界值的测试?
程序员写边界判断代码经常出错,比如一个程序是两个数的求和,需求是<99 and >-99,但开发写代码可能写成 if number>=-99 and number<=99: 这就与需求不符合了,所以边界值是要测试的。

原网站

版权声明
本文为[理不尽的神之手]所创,转载请带上原文链接,感谢
https://blog.csdn.net/weixin_44378507/article/details/126102151