自动化测试——从MySQL数据库中读取短信验证码

背景:前一段时间,为公司某系统进行自动化测试。系统的注册页面需要输入手机号,并点击获取验证码验证手机号。

当然,测试时的手机号是假的,而且验证码也可以随便填写,供测试所用的系统也没有对验证码的正确性进行校验。但是,最近提测的系统不知被调皮的程序员们做了什么手脚,居然不再允许随便填写验证码,而是需要在点击获取验证码后到数据库中查看生成的验证码是什么,再在注册页面填写该验证码。这对自动化测试实在不便(以前我都是让程序直接在验证码输入框中输入1的……),怎么办呢,总不能点击获取验证码后让程序sleep30秒,期间测试人员以迅雷不及掩耳盗铃之势到数据库中查看验证码,再手动填写吧,这样也太不符合自动化的意义了。于是,摸索了一下Python使用MySQL数据库,代码如下:

import MySQLdb

conn = MySQLdb.connect(host='172.16.20.217',port=3306,user='root',passwd='password',db='krd20150821')
cur = conn.cursor()
# 查询表中最后一条数据的验证码字段
cur.execute('SELECT MESSAGE_NOTE FROM SYS_TEL_MESSAGE ORDER BY ID DESC LIMIT 1')
message = str(cur.fetchone())
yzm = filter(lambda x:x.isdigit(), message)

cur.fetchone()执行后得到的是一个元组,将其转换为字符串,再过滤掉数字之外的字符后,就是最终所需要的验证码。
虽然,代码还有缺陷,如果有多人同时在测试,则得到的验证码便有可能是别人手机号的验证码。不过还好,只有我用它测试,够用就好。

转载于:https://www.cnblogs.com/desperado0807/p/5172076.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
获取验证码的测试用例可以包括以下几个方面的情况: 1. 手机号或验证码输入为空,点击获取验证码,应该提示手机号码或验证码不能为空。[3.1] 2. 输入不符合手机号规则的数字,例如10位或12位数字,或者11位非手机号码,点击获取验证码,应该提示手机号码不正确。[3.2] 3. 验证码长度应该符合设计要求,并且验证码的内容可以包含数字、字母等字符,是否区分大小写取决于设计要求。前端页面应该根据设计要求限制验证码的长度。[3.3] 4. 输入未注册过的手机号,点击发送短信,可以有两种情况:如果提示未注册,则说明手机号码未注册;如果自动注册并登陆成功,则需要检查数据库该用户信息是否已经落库。[3.4] 5. 输入错误的验证码,应该给予友好的提示,说明验证码输入错误。尝试输入多一位或少一位验证码,应该无法成功获取验证码。[3.5] 6. 如果输入错误的验证码,是否可以再次点击发送短信,以及是否可以正常发送和接收验证码。[3.6] 7. 如果存在失效时长,当验证码在失效时长外输入时,应该提示该验证码已失效,请重新获取验证码。[3.7] 8. 验证码已经使用后,不应该再次使用。如果存在失效时长,验证码应该在失效时长内有效。[3.8] 9. 输入正确验证码后,再更换另一个已注册过的手机号,应该能够登录成功。而输入正确验证码后,再更换另一个未注册过的手机号,不应该能够登录成功。[3.9] 10. 重复发送验证码时,前一个验证码应该会失效。[3.10] 11. 若用户重复点击发送验证码,是否会有限制次数及友好提示。[3.11]<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [手机验证码的测试用例梳理](https://blog.csdn.net/chenlei_525/article/details/119885088)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [短信登录功能测试用例](https://blog.csdn.net/xun_zhao_t521/article/details/119914148)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值