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

业务逻辑分类

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

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

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

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

  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博客

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

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

相关推荐
skywalk81631 分钟前
请学习kotti的前端(kotti其实是没有分离的前端的)实现,做到形似kotti那样的前端页面。
前端·学习
UI设计兰亭妙微14 分钟前
兰亭妙微加载体验设计白皮书:从骨架屏到后台加载的全场景优化策略
前端·b端界面设计·ui设计公司
逆光如雪18 分钟前
移动端卡片边框怎么做高级?我用 CSS 实现了设计师的刁钻要求
前端·css·vue.js
scan72420 分钟前
龙虾读取session历史消息
java·前端·数据库
莹宝思密达25 分钟前
地图显示西安经济开发区边界线-2023.12
前端·vue.js·数据可视化
lizhongxuan40 分钟前
LLM Wiki:让大模型替你打理知识库的完整指南
前端·后端·面试
宇擎智脑科技1 小时前
Claude Code 源码分析(七):终端 UI 工程 —— 用 React Ink 构建工业级命令行界面
前端·人工智能·react.js·ui·claude code
dragon7251 小时前
Flutter错误处理机制
前端·flutter
数据知道1 小时前
claw-code 源码详细分析:Bootstrap Graph——启动阶段图式化之后,排障与扩展为什么会变简单?
前端·算法·ai·bootstrap·claude code·claw code
悟空瞎说1 小时前
深度解析:Vue3 为何弃用 defineProperty,Proxy 到底强在哪里?
前端·javascript