功能测试
1.1 功能测试流程
# 功能测试大致按照以下流程进行:
(1).需求分析与评审
(2).测试计划与测试方案
(3).测试用例设计
(4).测试用例评审
(5).执行用例
(6).缺陷跟踪及报告产出
1.2 功能测试流程详解
(1).需求分析与评审
功能测试应从需求出发, 功能测试就是尽量覆盖用户需求, 是软件能够最大程度满足用户的需求. 在开始功能测试之前, 技术人员应一起进行需求评审, 明确需求, 避免需求出现问题, 导致后面开发, 测试在错误的基础上进行.
测试人员在需求评审过程中要:
- 确认自己对需求理解清晰, 不存在疑惑
- 确认需求文档完整, 准确, 能够为后期测试工作所使用
- 对需求中不合理的地方提出自己的修改建议
(2).测试计划与测试方案
测试计划是指描述要进行测试活动的范围, 方法, 资源和进度的文档. 测试计划侧重在“计划”二字. 其核心内容包含但不限于以下:
- 测试范围与目标
- 角色与职责
- 进度与资源
- 风险与应对
- 准入准出标准
测试计划一般由测试组长, 测试经理负责编写, 也有可能有测试工程师编写.
测试方案是从技术的角度去分析需求, 在方向上明确要怎么测, 分析结果侧重点在于测试策略与技术实现. 测试方案侧重在“方案”二字, 其核心内容包含到不限于以下:
-
策略与方法
-
环境
-
工具的选择
(3).测试用例设计
测试用例(Test Case)是为了实施测试而向被测试的系统提供的一组集合,这组集合包括:测试环境、操作步骤、测试数据、预期结果等要素。
其实, 测试用例就是一份编写了要测哪些内容的文档. 测试用例表达要清除, 无二义性; 用例可操作性强; 用例的输入与输出明确.
用例是测试人员根据需求进行设计的, 设计方法有: 等价类划分法, 边界值法, 判定表法, 正交法, 场景法, 错误推测法, 基于需求设计.
(4).测试用例评审
测试用例评审是指, 测试人员测试好测试用例后, 需要进行评审, 检查用例设计是否合格, 是否能够最大程度上覆盖用户需求.
(5).执行用例
测试用例评审通过, 测试人员就可以根据测试用例对开发提交的代码进行测试了. 并将测试结果与用例中的预期结果进行对比, 并详细记录.
(6).缺陷跟踪及报告产出
2.1 等价类概念与分类
# 等价类
在所有测试数据中, 具有某种共同特征的数据子集即为等价类
# 等价类分类
- 有效等价类
- 无效等价类
2.2 等价类划分法解决的问题
# 解决的问题
划分等价类可以将测试集合科学的从无穷大减少到有限小, 让测试工作从穷举测试中解放出来, 大大减少测试用例数量, 提升测试效率.
2.3 等价类划分法设计测试用例步骤与应用场景
# 步骤:
1.需求分析
2.划分等价类
(1).有效等价类
(2).无效等价类
- 规则(需求本身出发)
- 长度需求
- 类型规定
- 是否为空(必填项检查)
- 是否可重复输入
3.设计用例
# 典型应用场景: 带有输入框的测试
2.4 案例实战 --- QQ号注册网站账号
# 根据以下需求, 利用等价类划分法基于测试用例模板设计测试用例
# 需求:
使用QQ号注册网站账号, QQ号要求: 6-10位自然数, 同一QQ号不能重复注册
# 用例设计步骤
1.分析需求
2.等价类划分(见下表)
- 有效等价类
- 无效等价类
3.设计用例(见下图)
有效等价类 | 有效数据 | 无效等价类 | 无效数据 |
---|---|---|---|
6-10位自然数 | 1234567 | 小于6位自然数 | 12345 |
大于10位自然数 | 12345678912 | ||
6-10位字母 | abcdefg | ||
6-10位汉字 | 你好我好他也好 | ||
6-10位符号 | !@#$%^& | ||
不填写 | |||
重复输入 | 1234567 |
# 根据以下需求, 利用等价类划分法基于测试用例模板设计测试用例
# 需求:
新浪邮箱登录, 要求输入(邮箱名)@sina.cn和密码进行登录
邮箱名要求:4-16位字符, 支持英文, 数字, 下划线(不能全是数字或者下划线)
密码: 6-18位字符
# 等价类划分法设计测试用例步骤:
1.需求分析
2.等价类划分:(见下表)
- 有效等价类
- 无效等价类
有效等价类 | 有效数据 | 无效等价类 | 无效数据 |
---|---|---|---|
4-16位英文 | abcd | 小于4位英文 | abc |
4-16位英文数字组合 | abc1 | 大于16位英文 | AbcdefAbcdefAbcdefg |
4-16位英文下划线组合 | abc_ | 4-16位纯数字 | 1234 |
4-16位数字下划线组合 | 123_ | 4-16位纯下划线 | |
4-16位英文数字下划线组合 | ab1_ | 4-16位汉字 | 你好中国 |
4-16位符号 | !@#$ | ||
不输入邮箱 | |||
输入未注册正确邮箱 | abcd0820@sina.com |
有效等价类 | 有效数据 | 无效等价类 | 无效数据 |
---|---|---|---|
6-18位字符 | abcdef | 小于6位字符 | abcde |
大于18位字符 | Abcdefabcdefabcdefg | ||
6-18位非字符_符号 | !@#$%& | ||
6-18位非字符_汉字 | 你好我的祖国 | ||
不输入密码 |
测试用例设计
# 测试用例设计:
由于存在两个输入框, 对两个输入框进行等价类划分, 每个输入框都有自己的有效等价类和无效等价类, 此时我们要考虑如何进行组合, 来设计测试用例
可能进行的组合如下:
用户名 密码 预期结果
有效 有效 登录成功
有效 无效 登录失败
无效 有效 登录失败
无效 无效 登录失败
但基于测试的原则, 我们想确定登录失败时, 是由于用户名和密码之间谁的非等价类导致的登录失败, 所有最后一种组合(用户名无效,密码无效)不需要进行测试, 即使结果为登录失败, 也无法确定是谁导致的登录失败. 所以采用以上三种进行测试用例设计.
# 1.边界值法概念
边界值法设计测试用例, 是对输入或输出的边界值(有效等价类和无效等价类的界限)进行测试的一种黑盒测试方法.
# 2.边界值法存在的意义:
测试经验表明错误往往会发生在输入或输出范围的边界上, 所以边界值法是对这些边界进行测试, 是对划分等价类法的一种补充.
# 3.边界值的概念(如下图:)
- 上点: 边界上的点(符合条件的边界点)
- 内点: 边界内的点
- 离点: 离边界最近的左右两点
3.2两位数加法计算器案例
# 需求:
一个可以计算两位数内的加法计算器
# 确定边界值(如下图):
两位数取值范围 | 数学区间表示 | 上点 | 内点 | 离点 |
---|---|---|---|---|
x >= -99, y <= 99 | [-99, 99] | -99, 99 | 20 | -100,-98, 98, 100 |
x > -99, y <= 99 | (-99, 99] [-98,99] | -98, 99 | 10 | -99, -97, 98, 100 |
x >= -99, y < 99 | [-99, 99) [-99,98] | -99, 98 | 0 | -100, -98, 97, 99 |
x > -99, y < 99 | (-99, 99) [-98,98] | -98, 98 | 5 | -99, -97, 97, 99 |
3.3 设计测试用例的步骤与边界值法应用场景
# 设计测试用例的步骤
1.需求分析
2.划分等价类
3.确定边界
- 上点
- 内点
- 离点
4.设计测试用例
# 边界值法应用场景:
- 在等价类的基础上针对有边界范围的测试数据输入的地方
- 确定测试条件时, 明显存在(>, <, >=, <=)等的分析中.
- 典型代表: 有边界范围的输入框类测试
3.4 QQ号注册网站案例补充
# 需求
使用6-10位的QQ号注册网站, QQ号要求6-8位自然数
# 边界分析(边界分析如图所示)
上点:6, 10
内点:8
离点:5,7, 9, 11
# 通过边界分析法补充的用例:
- 输入6位自然数, QQ号正确
- 输入10位自然数, QQ号正确
- 输入8位自然数, QQ号正确
- 输入5位自然数, QQ号错误
- 输入7位自然数, QQ号正确
- 输入9位自然数, QQ号正确
- 输入11位自然数, QQ号错误
# 重复用例消除:
- 输入6位自然数, QQ号正确(重复)
- 输入10位自然数, QQ号正确(✅)
- 输入8位自然数, QQ号正确(✅)
- 输入5位自然数, QQ号错误(重复)
- 输入7位自然数, QQ号正确(✅)
- 输入9位自然数, QQ号正确(✅)
- 输入11位自然数, QQ号错误(重复)
# 补充测试用例文档:(如下图所示)
3.5 边界值分析法拓展
# 边界值优化(7变5)
从上面分析的边界值[5, 6, 7, 8, 9, 10, 11]来看:
1.值5是一个无效点是左侧最小的点, 6和7均是有效点, 所以测一个6就可以了, 7可以去掉.
2.值9, 10, 11中, 11是右侧最大的无效点, 需要保留, 而9, 10都是有效点, 9可以去掉.
3.内点8凭借经验, 需要保留
# 结论(重点):
上点: 必选(不考虑区间开闭)
内点: 必选(建议选择中间范围)
离点: 开内闭外(考虑开闭区间, 开区间选择内部离点, 闭区间选择外部离点)