下单支付异常场景与测试场景
一、功能异常场景1. 订单创建阶段异常场景测试方法预期结果实际发现的问题商品库存不足下单时商品库存为0提示“库存不足”订单创建失败✅ 正常商品已下架下单时商品状态为“已下架”提示“商品已下架”订单创建失败✅ 正常商品价格异常价格字段为0或负数提示“价格异常”订单创建失败❌ 发现价格0时订单创建成功应拦截用户未登录未登录状态下单跳转登录页登录后返回下单页✅ 正常用户被限制用户账号被风控异常行为提示“账号异常请联系客服”✅ 正常收货地址为空未填写收货地址提示“请填写收货地址”无法下单✅ 正常收货地址无效地址不存在或被封禁提示“地址无效”下单失败✅ 正常优惠券无效使用已过期/已使用的优惠券提示“优惠券无效”不抵扣✅ 正常优惠券不适用使用不适用当前商品的优惠券提示“优惠券不适用”不抵扣✅ 正常优惠券叠加超限使用超过限制数量的优惠券提示“优惠券使用数量超限”❌ 发现可叠加3张应限制购买数量超限下单数量超过单次购买上限提示“购买数量超限”下单失败✅ 正常购买数量为0下单数量为0提示“请选择购买数量”✅ 正常重复下单相同订单号相同订单号请求两次第二次返回已存在订单不创建新订单❌ 发现重复创建订单2. 支付阶段异常场景测试方法预期结果实际发现的问题余额不足支付时账户余额不足提示“余额不足”支付失败✅ 正常支付密码错误输入错误支付密码提示“密码错误”支付失败✅ 正常支付密码锁定连续输错5次账户锁定提示“账户已锁定请稍后再试”✅ 正常银行卡异常银行卡已过期/被冻结提示“银行卡异常”支付失败✅ 正常第三方支付超时调用支付宝/微信超时提示“支付超时请稍后重试”❌ 发现无提示一直加载第三方支付返回失败第三方支付返回失败码提示“支付失败”订单状态不变✅ 正常第三方支付返回未知状态返回状态未知需轮询系统轮询查询最终更新状态❌ 发现未轮询订单状态一直为“支付中”支付成功后回调失败支付成功回调接口失败系统自动重试最终更新订单状态❌ 发现无重试订单状态未更新支付金额不匹配实际支付金额与订单金额不符拒绝支付提示“金额不一致”✅ 正常订单已支付对已支付订单再次支付提示“订单已支付”不重复扣款✅ 正常订单已取消对已取消订单支付提示“订单已取消”支付失败✅ 正常订单已过期超过30分钟未支付订单自动取消支付失败✅ 正常3. 订单状态流转异常场景测试方法预期结果实际发现的问题支付成功前取消订单待支付用户主动取消订单状态变为“已取消”可重新下单✅ 正常支付成功后取消支付成功后申请退款进入退款流程订单状态变为“退款中”✅ 正常退款成功后重新支付退款成功对同一订单支付提示“订单已退款”不允许支付✅ 正常支付成功但库存未扣减模拟回调失败场景系统自动补偿最终扣减库存❌ 发现库存未扣减导致超卖支付成功但优惠券未核销模拟回调失败场景系统自动补偿核销优惠券❌ 发现优惠券未核销用户可重复使用订单状态并发更新同时两个请求更新同一订单只有一方成功避免数据错乱❌ 发现出现状态混乱订单状态被覆盖二、接口异常场景1. 请求参数异常异常场景测试方法预期结果实际发现的问题必填字段缺失不传order_id返回错误码1001提示“订单号不能为空”✅ 正常字段类型错误order_id传字符串应为整数返回错误码1002提示“参数类型错误”✅ 正常字段长度超限order_id超过50个字符返回错误码1003提示“订单号过长”✅ 正常非法字符order_id包含SQL注入字符返回错误码1004提示“非法字符”✅ 正常参数为空字符串order_id传空字符串返回错误码1001提示“订单号不能为空”✅ 正常参数为nullorder_id传null返回错误码1001提示“订单号不能为空”✅ 正常2. 接口响应异常异常场景测试方法预期结果实际发现的问题接口返回500Mock服务返回500客户端提示“系统繁忙请稍后重试”✅ 正常接口返回超时Mock延迟10秒响应客户端超时后提示“网络异常请重试”❌ 发现一直等待无超时处理接口返回空数据返回{}客户端提示“数据异常请联系客服”✅ 正常接口返回错误码返回{code:5001,msg:库存不足}客户端展示错误提示✅ 正常接口返回格式错误返回HTML而不是JSON客户端提示“系统异常”✅ 正常3. 安全异常异常场景测试方法预期结果实际发现的问题签名错误篡改请求参数不重新签名返回401提示“签名错误”✅ 正常签名过期使用5分钟前的时间戳返回401提示“请求已过期”✅ 正常重放攻击重复发送相同请求第二次返回401提示“重复请求”✅ 正常越权访问用户A支付用户B的订单返回403提示“无权操作”✅ 正常SQL注入参数中注入SQL语句被过滤正常返回错误✅ 正常XSS攻击参数中注入脚本被转义不影响系统✅ 正常篡改支付金额修改请求中的金额服务端校验返回401✅ 正常篡改商品ID修改请求中的商品ID服务端校验返回401✅ 正常三、性能异常场景异常场景测试方法预期结果实际发现的问题高并发下单100用户同时下单同一商品库存扣减准确无超卖❌ 发现超卖2件高并发支付50用户同时支付支付成功率≥99.9%无重复扣款✅ 正常接口响应慢接口响应时间从200ms上升到2s客户端展示loading超时后提示重试✅ 正常数据库连接池耗尽模拟100并发连接池20接口返回503提示“系统繁忙”❌ 发现接口卡死无响应Redis缓存雪崩大量缓存同时过期数据库压力增大但系统仍可用✅ 正常Redis缓存击穿热点数据缓存过期系统正常处理无崩溃✅ 正常长时间压测100并发持续1小时无内存泄漏响应时间稳定✅ 正常四、弱网异常场景异常场景测试方法预期结果实际发现的问题下单时断网Charles模拟断网提示“网络异常请检查网络”订单未创建✅ 正常下单时弱网2G模拟2G网络下单请求超时提示重试❌ 发现无重试提示一直loading支付时断网支付请求发出后断网系统轮询支付结果最终更新状态❌ 发现未轮询订单状态一直为“支付中”支付时弱网模拟3G网络支付成功但响应慢用户等待✅ 正常回调时断网支付成功回调接口断网系统自动重试最终更新订单状态❌ 发现无重试订单状态未更新网络切换支付过程中WiFi切4G支付流程继续最终成功✅ 正常弱网下重复点击弱网下快速点击支付按钮只发起一次请求避免重复支付❌ 发现发起多次请求导致重复支付五、UI交互异常场景异常场景测试方法预期结果实际发现的问题快速点击支付按钮连续快速点击5次只发起一次支付请求❌ 发现发起5次请求导致重复支付支付页面后退支付页面点击后退返回订单确认页订单状态不变✅ 正常支付成功后后退支付成功后退回订单页显示“已支付”状态✅ 正常支付过程中杀进程支付过程中杀App重启进入订单页显示支付中或已支付❌ 发现显示“待支付”实际已支付支付过程中接电话支付时接听电话支付流程继续最终成功✅ 正常支付过程中低电量弹窗支付时弹出低电量提示支付流程继续✅ 正常横竖屏切换支付页面横竖屏切换页面布局正常支付流程继续✅ 正常多端同时支付同一账号在两个设备上支付同一订单只有一个成功另一个提示“订单已支付”✅ 正常六、支付超时场景超时场景测试方法预期结果实际发现的问题30分钟内未支付下单后等待31分钟订单自动取消✅ 正常30分钟边界第30分钟00秒支付支付成功✅ 正常30分钟边界1秒第30分钟01秒支付提示“订单已过期”支付失败✅ 正常支付页面停留超时进入支付页面停留31分钟提示“订单已过期”返回订单页✅ 正常超时前弹窗提醒下单后25分钟弹窗提示“即将过期请尽快支付”❌ 发现无提醒超时后重新支付订单取消后重新下单可正常支付✅ 正常七、退款异常场景异常场景测试方法预期结果实际发现的问题支付成功后申请退款用户主动申请退款进入退款流程订单状态变为“退款中”✅ 正常退款审核通过商家审核通过退款成功金额原路返回✅ 正常退款审核拒绝商家审核拒绝提示“退款失败原因xxx”✅ 正常退款金额错误退款金额与实际支付不符服务端校验返回错误✅ 正常重复申请退款同一订单申请两次退款第二次提示“退款申请已提交”✅ 正常退款时余额不足商家账户余额不足提示“退款失败请稍后重试”✅ 正常退款回调失败退款成功回调失败系统自动重试最终更新状态❌ 发现无重试订单状态一直为“退款中”退款超时退款处理超过7天自动退款成功或人工介入✅ 正常八、测试用例设计示例用例支付密码错误项目内容用例编号PAY-001测试模块支付模块优先级P1测试类型功能测试 / 异常场景前置条件详细说明1用户已登录2用户已创建待支付订单3用户已设置支付密码4用户余额充足步骤操作预期结果1进入待支付订单详情页页面正常展示订单信息2点击“去支付”弹出支付密码输入框3输入错误支付密码密码输入框接收输入4点击“确认支付”提示“密码错误请重新输入”支付失败订单状态仍为“待支付”密码输入框清空可重新输入验证点是否通过错误提示正确☐订单状态未变☐可重新输入密码☐连续5次错误后锁定账户☐九、支付异常场景矩阵阶段异常类型具体场景预期行为自动化覆盖下单参数异常数量超限提示错误✅下单业务异常库存不足提示错误✅下单安全异常越权下单拒绝操作✅支付网络异常支付超时提示重试✅支付第三方异常微信支付失败提示失败✅支付业务异常余额不足提示错误✅回调网络异常回调失败自动重试✅回调数据异常金额不匹配拒绝处理✅退款业务异常重复退款拒绝操作✅退款网络异常回调失败自动重试✅十、核心缺陷案例案例1快速点击导致重复支付问题在支付页面快速连续点击“确认支付”按钮系统发起多次支付请求导致重复扣款。发现方式UI自动化模拟快速点击。根因前端未做防抖处理后端未做幂等性校验。解决方案前端点击后按钮置灰响应返回后再恢复后端增加幂等性校验相同订单号只处理一次案例2支付超时无提示问题弱网下调用第三方支付接口响应超时前端一直显示loading无任何提示。发现方式弱网自动化测试。根因前端未设置超时时间未处理超时异常。解决方案设置接口超时时间10秒超时后提示“网络异常请重试”提供“重试”按钮案例3回调失败导致订单状态未更新问题支付成功后回调接口因网络问题失败订单状态一直为“待支付”用户被重复扣款。发现方式接口自动化模拟回调失败。根因回调接口无重试机制无补偿任务。解决方案回调接口增加重试机制3次间隔5秒增加定时补偿任务扫描状态不一致的订单案例4超卖问题问题100用户同时下单同一商品库存100实际下单成功102单超卖2件。发现方式性能压测。根因库存扣减使用“读-改-写”模式存在并发问题。解决方案使用数据库原子操作UPDATE inventory SET stock stock - 1 WHERE id x AND stock 0使用Redis分布式锁十一、自动化覆盖策略接口自动化覆盖场景类型覆盖数量自动化脚本示例正常支付流程3个创建订单 → 支付 → 验证订单状态参数异常10个必填字段缺失、类型错误、长度超限业务异常8个余额不足、库存不足、优惠券无效安全异常6个签名错误、越权访问、重放攻击回调异常4个回调失败、回调超时、回调数据错误UI自动化覆盖场景类型覆盖数量自动化脚本示例正常支付流程2个点击支付 → 输入密码 → 支付成功UI异常5个快速点击、页面后退、横竖屏切换弱网场景4个2G/3G网络下支付、断网重连中断场景3个杀进程、接电话、低电量弹窗性能自动化覆盖场景类型覆盖数量自动化脚本示例并发下单1个100用户同时下单并发支付1个50用户同时支付长时间压测1个100并发持续1小时峰值压测1个500并发持续5分钟十二、总结发现问题统计问题类型数量严重等级重复支付2个P0超卖问题1个P0回调失败未重试2个P1支付超时无提示1个P1订单状态未同步2个P1弱网处理缺失3个P2UI防抖缺失2个P2核心收益拦截资金风险重复支付、超卖等P0缺陷被拦截提升用户体验弱网提示、超时处理、防抖机制保障数据一致性回调重试、补偿任务、幂等性校验降低线上故障上线后支付模块故障率为0
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2441590.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!