如何讀取redis的手機(jī)號(hào)驗(yàn)證碼數(shù)據(jù),實(shí)現(xiàn)自動(dòng)化登錄測(cè)試
1、案例描述
- 用户选择短信登录 !
- 发送短信后,后端接口逻辑已把验证码缓存在redis, !
- 在
apifox
上定义对应下发登录短信接口
,短信登录接口
- 下载地址:www.apifox.cn
- 这时候问题就来了,怎么样才能让
apifox
自动获取下发登录短信接口
对应的手机号的验证码,自动填充到短信登录接口
的code
字段?
2、解决思路
- 方案一:后端通过接口返回验证码,下发短信接口后再调用该接口去获取验证码(正式环境需要屏蔽该接口,没办法自动化正式环境接口)
- 方案二:
apifox
直接访问redis获取数据;这需要在apifox
添加扩展操作redis的jar包,参考:https://www.apifox.cn/help/app/scripts/api-references/external-programs/ (该方案比较可行)
3、开始动手
- 编写操作redis扩展jar包(可参考https://github.com/Atoms-Cat/apifox-code的apifox-redis模块)
- 创建自动化测试用例,我是从
接口管理
的接口用例
直接导入(这个工具真香,重用性强👍)
- 把
phone
、code
请求参数给为临时变量{{phone}}
、{{code}}
- 新建
短信登录用例
前置自定义脚本,这里的apifox-redis-1.0-SNAPSHOT.jar
,就是第一步生成好的jar;脚本编写可以参考:https://www.apifox.cn/help/app/scripts/pre-request-script/#使用示例
try {
// redis 连接配置
var redisConfig = "{"host":"192.168.181.130","password":"123456","database":0}";
// 获取当前登录的手机号
var phone = pm.variables.get("phone");
// 后端服务缓存验证码在redis的key
var key = "DEFAULT_CODE_KEY:" + phone;
console.log("redis key:", key);
// 执行jar包获取redis缓存数据
var jarResult = pm.execute('apifox-redis-1.0-SNAPSHOT.jar', [redisConfig, "GET", key]);
console.log("redis 缓存数据:", jarResult);
// 反序列化异常处理
var code = jarResult.substr(jarResult.length-7, 6);
// 自动填充验证码到登录接口的`code`字段
pm.variables.set("code", code);
console.log("验证码:", code);
} catch (e) {
console.error(e.message);
}
- 新增
测试数据
,这里新增手机号对应临时变量{{phone}}
注意
: 需要打开测试数据
开关,后点击运行
- 查看结果 !
4、总结
apifox提供了非常好的自动化测试接口的功能
参考demo源码
# 后端接口服务源码
https://github.com/Atoms-Cat/softswitch-system
# apifox 扩展操作 redis jar源码
https://github.com/Atoms-Cat/apifox-code
點(diǎn)擊查看更多內(nèi)容
為 TA 點(diǎn)贊
評(píng)論
評(píng)論
共同學(xué)習(xí),寫下你的評(píng)論
評(píng)論加載中...
作者其他優(yōu)質(zhì)文章
正在加載中
感謝您的支持,我會(huì)繼續(xù)努力的~
掃碼打賞,你說多少就多少
贊賞金額會(huì)直接到老師賬戶
支付方式
打開微信掃一掃,即可進(jìn)行掃碼打賞哦