Android 系统采用了内容提供器(ContentProvider)
机制来管理不同应用的数据访问。内容提供器为不同应用间的数据共享提供了接口,它们像是一个中央数据仓库,各个应用可以通过内容 URI 来存取数据。
每条短信都会被存储在内容提供器的SMS ContentProvider
中。SMS ContentProvider
的内容 URI 地址是content://sms/inbox
。所以通过操作这个内容 URI,我们可以获取存储在系统中的短信信息。
获取短信验证码主要有两种方式:
cssadb shell 进入adb命令行模式
content query --uri <内容URI> 查询内容提供器的内容
--projection <列名> 指定查询返回的列
--where <条件> 指定查询的条件
--sort <排序方式> 指定结果排序方式
--limit <数量> 指定返回数据的最大行数
所以,我们可以通过组合这些参数,写入 adb 命令,直接查询取得短信验证码。 例如:
adb shell "content query --uri content://sms/inbox --projection body --where "address='135XXXXXXXX'"
这条命令的作用是:
--uri content://sms/inbox
指定查询短信内容提供器的收件箱--projection body
只查询短信的 body,也就是内容列--where "address='135XXXXXXXX'"
指定过滤条件,地址等于发验证码的手机号这样我们就可以直接取得该手机号发送过来的短信验证码了。
在自动化测试中,我们可能需要频繁获取短信验证码,以实现某些测试用例。 例如注册账号和重置密码时,都需要验证短信验证码。每运行一遍测试用例,都需要获取新的验证码。 为了简化这部分的处理,我们可以编写一个获取验证码的公共函数。利用 adb 命令查询短信内容提供器,获取到最近的一条短信,然后通过正则表达式解析出 6 位数字验证码。这样就可以实现一个通用的获取验证码组件。 示例代码:
pythonimport re
import subprocess
def get_verification_code(phone_number):
# 构建adb命令
adb_command = f'adb shell "content query --uri content://sms/inbox --projection body --where "address=\'{phone_number}\'"'
# 执行命令,取得输出
output = subprocess.check_output(adb_command).decode('utf-8')
# 解析验证码
match = re.search(r'(\d{6})', output)
if match:
return match.group(1)
return None
这样,在任意测试用例里,我们就可以直接调用该函数来获取验证码,而不需要每次都写 adb 查询的代码。
adb shell
的 root
权限,才能查询短信内容提供器本文介绍了如何通过 adb 命令查询内容提供器的方式来自动化获取短信验证码,并给出了一个示例代码实现。相比每次编写 adb 命令,封装成函数可以提高代码复用率,也使自动化测试用例的实现更简洁。同时,加入一定校验与优化,可以使获取验证码更稳定可靠。
随着测试需求的变更,我们也可以轻松调整内部实现逻辑。总之,合理利用内容提供器机制,可以帮助我们将测试用例的自动化做到更彻底。
本文作者:李佳玮
本文链接:
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!