文档
All checks were successful
构建并部署到测试环境(无 SSH) / build-and-deploy (push) Successful in 6m2s

This commit is contained in:
2026-01-31 13:06:30 +08:00
parent b8dda7e62a
commit 62708892ec
29 changed files with 6568 additions and 31 deletions

View File

@@ -2,10 +2,14 @@
### Requirement: 订单支付后触发佣金计算
系统 SHALL 在订单支付成功后自动触发佣金计算。计算通过异步任务执行。
系统 SHALL 在订单支付成功后自动触发佣金计算。计算通过异步任务执行。代购订单和普通订单的佣金计算逻辑不同。
#### Scenario: 支付成功触发计算
- **WHEN** 订单支付状态变为已支付
#### Scenario: 普通订单支付成功触发计算
- **WHEN** 普通订单is_purchase_on_behalf = false支付状态变为已支付
- **THEN** 系统发送佣金计算异步任务
#### Scenario: 代购订单支付成功触发计算
- **WHEN** 代购订单is_purchase_on_behalf = true创建成功自动已支付
- **THEN** 系统发送佣金计算异步任务
#### Scenario: 重复支付不重复计算
@@ -48,35 +52,36 @@
### Requirement: 更新累计充值金额
订单支付成功后系统 SHALL 更新卡/设备的累计充值金额。
订单支付成功后系统 SHALL 更新卡/设备的累计充值金额,但代购订单除外
**关键修复**:每次支付成功都必须写回累计充值金额,确保累计值能正确用于一次性佣金的累计触发判断
**关键修复**:每次真实充值(个人客户充值或购买套餐)都必须写回累计充值金额,代购订单不更新
#### Scenario: 单卡订单更新累计充值
- **WHEN** 单卡订单支付成功,金额 100 元
#### Scenario: 普通单卡订单更新累计充值
- **WHEN** 普通单卡订单is_purchase_on_behalf = false支付成功金额 100 元
- **THEN** 系统读取 IotCard.accumulated_recharge 当前值
- **AND** 增加 10000 分100 元 = 10000 分)
- **AND** 将新值写回 IotCard.accumulated_recharge
- **AND** 使用更新后的累计值判断是否触发一次性佣金
#### Scenario: 设备订单更新累计充值
- **WHEN** 设备订单支付成功,金额 300 元
#### Scenario: 普通设备订单更新累计充值
- **WHEN** 普通设备订单is_purchase_on_behalf = false支付成功金额 300 元
- **THEN** 系统读取 Device.accumulated_recharge 当前值
- **AND** 增加 30000 分300 元 = 30000 分)
- **AND** 将新值写回 Device.accumulated_recharge
- **AND** 使用更新后的累计值判断是否触发一次性佣金
#### Scenario: 累计充值更新使用原子操作
#### Scenario: 代购订单不更新累计充值
- **WHEN** 代购订单is_purchase_on_behalf = true完成金额 100 元
- **THEN** 系统不更新卡/设备的 accumulated_recharge 字段
- **AND** accumulated_recharge 保持原值
#### Scenario: 累计充值更新使用原子操作
- **WHEN** 更新累计充值金额
- **THEN** 系统使用 SQL 原子操作(如 `accumulated_recharge = accumulated_recharge + ?`
- **OR** 使用 GORM 乐观锁version 字段)
- **AND** 确保并发场景下累计值不会丢失
#### Scenario: 更新失败不影响佣金计算
- **WHEN** 累计充值金额更新失败(数据库错误、并发冲突等)
- **THEN** 系统记录错误日志
- **AND** 继续执行后续的佣金计算流程(成本价差、一次性佣金等)
@@ -140,3 +145,48 @@
- **WHEN** 累计充值金额更新失败
- **THEN** 系统在日志中记录:订单 ID、资源 ID、失败原因错误信息、重试次数如适用
---
### Requirement: 代购订单佣金计算规则
代购订单 SHALL 计算差价佣金,但不触发一次性佣金。
#### Scenario: 代购订单计算差价佣金
- **WHEN** 代购订单is_purchase_on_behalf = true完成买家有上级代理
- **THEN** 系统计算差价佣金(买家成本价 - 上级成本价),发放给上级代理链
#### Scenario: 代购订单不触发一次性佣金
- **WHEN** 代购订单完成,佣金计算时检查订单类型
- **THEN** 系统跳过一次性佣金判断逻辑,不发放一次性佣金
#### Scenario: 代购订单示例
- **WHEN** 平台为三级代理代购,订单金额 100 元(三级成本价),各级成本价:一级 60 → 二级 70 → 三级 80
- **THEN** 二级获得 10 元80 - 70差价佣金一级获得 10 元70 - 60差价佣金
- **AND** 三级、二级、一级都不获得一次性佣金
---
### Requirement: 钱包充值触发一次性佣金
钱包充值成功后 SHALL 更新累计充值,并检查是否触发一次性佣金。
#### Scenario: 充值成功更新累计充值
- **WHEN** 卡钱包充值 100 元成功,当前累计充值 200 元
- **THEN** 系统更新卡的 accumulated_recharge 为 300 元
#### Scenario: 充值达到首次充值阈值
- **WHEN** 卡配置为首次充值触发,阈值 100 元,充值 100 元成功,未发放过佣金
- **THEN** 系统触发一次性佣金计算,发放佣金,标记 first_commission_paid = true
#### Scenario: 充值达到累计充值阈值
- **WHEN** 卡配置为累计充值触发,阈值 1000 元,充值后累计达到 1000 元,未发放过佣金
- **THEN** 系统触发一次性佣金计算,发放佣金,标记 first_commission_paid = true
#### Scenario: 充值未达阈值不触发
- **WHEN** 充值后累计充值未达到阈值
- **THEN** 系统不触发一次性佣金计算
#### Scenario: 已发放过不重复触发
- **WHEN** 卡的一次性佣金已发放过first_commission_paid = true
- **THEN** 系统不触发一次性佣金计算