1.功能测试流程
1.1 功能测试流程

功能测试大致按照以下流程进行:

(1).需求分析与评审
(2).测试计划与测试方案
(3).测试用例设计
(4).测试用例评审
(5).执行用例
(6).缺陷跟踪及报告产出

1.2 功能测试流程详解
(1).需求分析与评审

功能测试应从需求出发, 功能测试就是尽量覆盖用户需求, 是软件能够最大程度满足用户的需求. 在开始功能测试之前, 技术人员应一起进行需求评审, 明确需求, 避免需求出现问题, 导致后面开发, 测试在错误的基础上进行.

测试人员在需求评审过程中要:

  • 确认自己对需求理解清晰, 不存在疑惑
  • 确认需求文档完整, 准确, 能够为后期测试工作所使用
  • 对需求中不合理的地方提出自己的修改建议
    (2).测试计划与测试方案

测试计划是指描述要进行测试活动的范围, 方法, 资源和进度的文档. 测试计划侧重在“计划”二字. 其核心内容包含但不限于以下:

  • 测试范围与目标
  • 角色与职责
  • 进度与资源
  • 风险与应对
  • 准入准出标准
    测试计划一般由测试组长, 测试经理负责编写, 也有可能有测试工程师编写.

测试方案是从技术的角度去分析需求, 在方向上明确要怎么测, 分析结果侧重点在于测试策略与技术实现. 测试方案侧重在“方案”二字, 其核心内容包含到不限于以下:

策略与方法

环境

工具的选择

(3).测试用例设计

测试用例(Test Case)是为了实施测试而向被测试的系统提供的一组集合,这组集合包括:测试环境、操作步骤、测试数据、预期结果等要素。

其实, 测试用例就是一份编写了要测哪些内容的文档. 测试用例表达要清除, 无二义性; 用例可操作性强; 用例的输入与输出明确.

用例是测试人员根据需求进行设计的, 设计方法有: 等价类划分法, 边界值法, 判定表法, 正交法, 场景法, 错误推测法, 基于需求设计.

(4).测试用例评审

测试用例评审是指, 测试人员测试好测试用例后, 需要进行评审, 检查用例设计是否合格, 是否能够最大程度上覆盖用户需求.

(5).执行用例

测试用例评审通过, 测试人员就可以根据测试用例对开发提交的代码进行测试了. 并将测试结果与用例中的预期结果进行对比, 并详细记录.

(6).缺陷跟踪及报告产出

缺陷跟踪, 是指测试未通过提交的Bug, 开发需要修复Bug, 再次提测. 测试人员要继续测试, 如果不通过还要再次提Bug, 知道测试通过. 这个过程就是缺陷跟踪. 最后产出报告.

2.等价类划分法
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

2.5 案例实战 --- 新浪邮箱登录

根据以下需求, 利用等价类划分法基于测试用例模板设计测试用例

需求:

新浪邮箱登录, 要求输入(邮箱名)@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位非字符_汉字 你好我的祖国
不输入密码
测试用例设计

测试用例设计:

由于存在两个输入框, 对两个输入框进行等价类划分, 每个输入框都有自己的有效等价类和无效等价类, 此时我们要考虑如何进行组合, 来设计测试用例
可能进行的组合如下:
用户名 密码 预期结果
有效 有效 登录成功
有效 无效 登录失败
无效 有效 登录失败
无效 无效 登录失败
但基于测试的原则, 我们想确定登录失败时, 是由于用户名和密码之间谁的非等价类导致的登录失败, 所有最后一种组合(用户名无效,密码无效)不需要进行测试, 即使结果为登录失败, 也无法确定是谁导致的登录失败. 所以采用以上三种进行测试用例设计.
3.边界值法
3.1边界值法概念及存在的意义

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凭借经验, 需要保留

结论(重点):

上点: 必选(不考虑区间开闭)
内点: 必选(建议选择中间范围)
离点: 开内闭外(考虑开闭区间, 开区间选择内部离点, 闭区间选择外部离点)

最后修改:2021 年 08 月 16 日
如果觉得我的文章对你有用,请随意赞赏