开发如何避免遗漏业务逻辑?

业务逻辑分类

  • 流程控制性的逻辑
  • 具体的字段数据约束逻辑

避免遗漏流程控制性的逻辑

通过状态迁移图找到所有流程

涉及业务实体状态转换的流程,则通过测试分析方式中的状态迁移图找出所有流程

  1. 分析需求,获取节点、状态信息
  2. 画状态迁移图(各个节点是如何流转的)
  1. 画状态迁移树(根据迁移图画出迁移树)
  1. 抽取规则,每个起始点的连线就是一条流程,共计 4 个流程
  • 预定-已取消
  • 预定-已支付-已取消
  • 预定-已支付-已出票-已取消
  • 预定-已支付-已出票-已使用

19 用例设计方法-状态迁移 - wsh1995 - 博客园 (cnblogs.com)

通过流程图找到所有流程

对于复杂的需求描述,可以通过将需求描述转换为流程图,然后找出所有流程

需求描述

流程分析图

20 测试用例设计 流程分析 - wsh1995 - 博客园 (cnblogs.com)

通过判定树或判定表找到所有流程

对于复杂的需求描述或业务逻辑,可以通过将需求描述转换为判定表或判定树,然后找出所有流程

需求描述

复制代码
订购单的检查:
如果金额 > 500, 又未过期,发批准单和提货单
如果金额 > 500, 但过期了,则不发批准单
如果金额 < 500,不论是否过期,都发批准单和提货单,在过期的情况下,还需要发出通知单。

根据需求描述归纳为判定表

判定表法有个注意点是,如何列出所有条件的组合,一种是自己计算所有的排列组合,一种是正交表计算

自己计算所有排列组合示例:

js 复制代码
let ageArr = ['少年','中年','老年']
let hobbyArr = ['打篮球','踢足球','打羽毛球']
let maleArr = ['男','女']

const arrArr = []
for(let age of ageArr){
    for(let hobby of hobbyArr){
        for(let male of maleArr){
            arrArr.push([age,hobby,male])
        }
    }
}
console.log(arrArr.length)
console.log(arrArr.join('\n'))

通过Allpairs工具,计算所有正交组合

学会Allpairs工具,让用例设计变得简单高效 - 知乎 (zhihu.com)

根据需求描述归纳为判定树

16 用例设计方法-判定表 - wsh1995 - 博客园 (cnblogs.com)

常用测试用例设计方法3-判定表法-CSDN博客

判定表和判定树-CSDN博客

详细设计的工具------判定表与判定树-CSDN博客

测试用例设计方法六脉神剑------第四剑:石破天惊,功能图法攻阵| 京东物流技术团队 - 掘金 (juejin.cn)

测试用例题(状态迁移图法)_状态迁移图法题目-CSDN博客

避免遗漏具体的字段数据约束逻辑

用思维导图描述每个字段的约束

相关推荐
Moment1 小时前
腾讯终于对个人开放了,5 分钟在 QQ 里养一只「真能干活」的 AI 😍😍😍
前端·后端·github
比尔盖茨的大脑1 小时前
AI Agent 架构设计:从 ReAct 到 Multi-Agent 系统
前端·人工智能·全栈
天才熊猫君1 小时前
使用 Vite Mode 实现客户端与管理端的物理隔离
前端
HelloReader1 小时前
React Hook 到底是干嘛的?
前端
用户60572374873081 小时前
OpenSpec 实战:从需求到代码的完整工作流
前端·后端·程序员
寅时码1 小时前
React 正在演变为一场不可逆的赛博瘟疫:AI 投毒、编译器迷信与装死的官方
前端·react.js·设计模式
忆江南2 小时前
HTTP 各版本演进与 HTTPS 原理详解
前端
忆江南2 小时前
对组件化与模块化的思考与总结
前端
小码哥_常2 小时前
从0到1:Android组件化架构搭建秘籍
前端