chore: 归档fix-horse-racing-issues提案
This commit is contained in:
33
openspec/changes/archive/fix-horse-racing-issues/proposal.md
Normal file
33
openspec/changes/archive/fix-horse-racing-issues/proposal.md
Normal file
@@ -0,0 +1,33 @@
|
||||
## Why
|
||||
|
||||
赛马插件(group_horse_racing)代码审查发现多个影响稳定性、数据完整性和用户体验的问题,需集中修复以提升生产可靠性。
|
||||
|
||||
## What Changes
|
||||
|
||||
### P0 - 严重
|
||||
1. **SQLite 阻塞事件循环** (
|
||||
oom_store.py):每次操作同步连接 SQLite,在 async 上下文中阻塞 NoneBot 事件循环,高并发时可能卡死。
|
||||
2. **积分重试逻辑无意义** (points_service.py:17-20):spend_points 失败后立即重试无延时,余额不足时重试毫无意义,网络失败也无间隔。
|
||||
3. **消息发送静默吞异常** (commands.py:271-272):_send_to_scope 中 except Exception: pass,比赛进度发送失败完全无人知晓。
|
||||
|
||||
### P1 - 中等
|
||||
4. **赔率快照时机** (commands.py:492-493):下注时显示的赔率与结算时赔率可能不一致(其他用户同时下注导致动态变化),用户预期不符。
|
||||
5. **race_history 缺失积分变化** (
|
||||
oom_store.py:148-161):save_race_result 未存入 point_changes 和 point_change_summaries,历史查询无法追溯积分变化。
|
||||
6. **测试命令侵入生产数据** ( est_commands.py:5):直接导入生产
|
||||
oom_store 实例,测试误操作会污染真实数据。
|
||||
|
||||
### P2 - 低
|
||||
7. **马名大小写去重漏洞** (commands.py):_find_duplicate_horse 用 casefold() 但 dict key 是原始大小写,可能注册出仅大小写不同的同名马。
|
||||
|
||||
## Capabilities
|
||||
|
||||
### Modified Capabilities
|
||||
- horse-race-betting: 修复积分重试逻辑、赔率快照一致性
|
||||
- horse-race-room-flow: 修复 SQLite 阻塞、异常静默吞没
|
||||
- horse-race-test-mode: 修复测试数据隔离
|
||||
- horse-race-history: 补存积分变化到 race_history
|
||||
|
||||
## Impact
|
||||
|
||||
- **修改文件**: points_service.py,
|
||||
Reference in New Issue
Block a user