解决问题的思路

最近测试的项目中,被测产品有一个功能是类似微信的长按输入语音的功能,不过我们的产品是输入语音后进行语音识别后返回文字。本来以为这个是没有办法做成自动化测试的,因为没有在 appium 的 api 文档中找到上传语音文件的方法。继续思考了一下是不是可以利用 python 其他的第三方库来实现呢,通过上网搜索后找到了方法。大的思路是利用 appium 在手机上对产品中的按钮进行长按操作,同时使用 pygame 的音频播放函数在电脑上播放录音。

代码片段

注意:下面不是完整的代码,大家可以做一下参考,如果要实际使用的话,请将相关配置替换为其他的被测 app 信息,还有需要提前用电脑录好要使用的录音文件,我这次使用的是 mp3 格式的音频文件。要是测试的功能是输入语音来查询北京天气。

from appium import webdriver
from nose.tools import *
from pygame import mixer  #导入pygame方法用来后台播放音频文件
import unittest

class MyTestCase(unittest.TestCase):

    @classmethod
    def setUpClass(self):
        desired_caps = {}
        desired_caps['platformName'] = 'Android' #设置操作平台
        --略--
        global driver
        driver = webdriver.Remote('http://127.0.0.1:4723/wd/hub', desired_caps)

    @classmethod
    def tearDownClass(self):
        driver.quit() #退出当前应用

    def test_11_voice_weather_beijing(self):
        driver.find_element_by_id('com.my.app.test:id/btn_set_mode_voice').click() #点击切换到语音模式
        el = driver.find_element_by_id('com.my.app.test:id/btn_press_to_speak') #选中“按住说话”按钮
        elx = el.location.get('x')  #获取按钮的x坐标
        ely = el.location.get('y')  #获取按钮的y坐标
        mixer.init() 
        mixer.music.load('testmp3.mp3')  #加载要播放的录音文件
        mixer.music.play()    #后台播放录音
        driver.swipe(elx,ely,elx,ely,10000)     #长按按钮10秒,开始接收语音,语音内容是“北京天气”
        weather_text = driver.find_element_by_id('com.my.app.test:id/weather_region').text
        assert_equal(weather_text, "北京")   #检查天气显示的区域是否正确

代码分析

上面的代码中,首先是导入 pygame 和 appium 和 unittest 等包,然后是做 appium 的启动设置。接下来找到 “按住说话” 按钮,然后是获取这个按钮在手机上的像素位置,这里的 x 和 y 组合在一起的像素点是在按钮的左上角的像素点。然后使用 pygame.mixer 的方法来在电脑上后台播放 mp3 录音文件。接下来是使用 appium 的 swipe 方法,我个人理解是如果在一个特别小的范围内滑动一定时间的话,效果是和长按一样的。代码最后一行就是在按钮的左上角一个像素点上滑动 10 秒钟,这样和长按这个按钮 10 秒钟是一样的。


↙↙↙阅读原文可查看相关链接,并与作者交流