自动化-Appium-微信公众号(Python版)

2022-07-25 13:30:35 浏览数 (1)

微信公众号

微信公众号其实也是正常的webview,但需要在微信里打开X5调试页面进行设置,脚本添加androidProcess参数才可以执行自动化测试。

本章示例为微信Android版本进行讲解(Windows与Mac环境下操作基本一致,此次示例为在Windows环境)。

1、编写脚本

1、首先获取真机设备标识,命令行输入命令 adb devices

2、真机设备里安装微信应用程序,输入安装命令 adb install -r 进行安装,或者使用手机助手进行安装。本章示例微信版本6.6.5

3、打开X5调试页面

打开微信,在任何聊天窗口内输入debugx5.qq.com,之后点击打开。

或者,通过微信扫一扫,扫描下面的二维码,进入X5调试页面。

4、信息页中,勾选“打开TBS内核Inspector调试功能”。

5、接下来开始使用查找元素定位工具来获取元素的属性值等信息,微信应用程序的原生例如可以使用Android SDK的uiautomatorviewer工具查找元素。

公众号页面识别不到webview中的元素,例如显示android.webkit.WebView,那么要用什么工具查找定位呢?例如:进入国美管家公众号,点击预约服务,跳转到管家服务页面,此页面为webview页面。

接下来打开PC的Chrome浏览器,输入访问地址chrome://inspect/

如图所示,当前打开的公众号界面就是Webview。

点击页面链接(链接有多个,要挨个点击查看哪个是),弹出新窗口,显示当前页面的Webview元素信息(由于国内网络问题,第一次页面加载可能需要FANQIANG)。元素定位方法同Selenium WebDriver一致。

6、获取当前公众号的进程

微信打开公众号(例如:国美管家,点击进入要测试的webview页面),查看当前运行在哪个进程中。

(1)查询pid,命令行输入 adb shell dumpsys activity top | findstr ACTIVITY

(2)查询当前公众号进程,命令行输入 adb shell ps 查询的pid

脚本参数添加:

代码语言:javascript复制
# 启动微信公众号,要设置这里
# 查询pid,命令行输入 adb shell dumpsys activity top | findstr ACTIVITY
# 查询当前公众号进程,命令行输入 adb shell ps 查询的pid
desired_caps['chromeOptions'] = {'androidProcess': 'com.tencent.mm:tools'}

7、切换NATIVE_APP还是WEBVIEW_com.tencent.mm:tools,使用switch_to.context方法。

8、脚本代码:

代码语言:javascript复制
#!/usr/bin/env python
# -*- coding: utf-8 -*-
from appium import webdriver
import time
"""
微信公众号
"""
# 定义启动设备需要的参数
desired_caps = {}

# 使用哪个自动化测试引擎
# 默认为Appium,或Selendroid或UiAutomator2或Espresso用于Android;或XCUITest用于IOS
desired_caps['automationName'] = 'Appium'

# 使用哪个移动操作系统平台 iOS, Android, FirefoxOS
desired_caps['platformName'] = 'Android'

# 移动操作系统版本
desired_caps['platformVersion'] = '6.0'

# 使用的移动设备或模拟器的类型
# iPhone Simulator, iPad Simulator, iPhone Retina 4-inch, Android Emulator, Galaxy S4 等等
# 在IOS上,这个关键字的值必须是使用`instruments -s devices`得到的可使用的设备名称之一
# 在Android上,这个关键字目前不起作用
desired_caps['deviceName'] = 'honor'

# 连接的物理设备的唯一设备标识
desired_caps['udid'] = 'MYV0215825000026'

# 要运行Android应用的包名
desired_caps['appPackage'] = 'com.tencent.mm'

# 要从包中启动的Android activity的活动名称
desired_caps['appActivity'] = 'com.tencent.mm.ui.LauncherUI'

# 启用Unicode输入法,设置为true可以输入中文字符,默认为false
desired_caps['unicodeKeyboard'] = True

# 在设定了`unicodeKeyboard`关键字运行Unicode测试结束后,将键盘重置为其原始状态
# 如果单独使用,将会被忽略,默认值`false`
desired_caps['resetKeyboard'] = True

# 在此会话之前不要重置应用程序状态
# Android 不要停止应用程序,不要清除应用程序数据,也不要卸载apk
# IOS 测试后不要销毁或关闭SIM卡。开始测试运行在任何模拟运行,或设备插入
desired_caps['noReset'] = True

# 执行完整的重置
# Android 停止应用程序,清除应用程序数据并在测试后卸载apk
# IOS 在真机设备测试后卸载应用程序,在模拟器测试后摧毁模拟器
desired_caps['fullReset'] = False

# 设置命令超时时间,单位:秒
# 达到超时时间仍未接收到新的命令时Appium会假设客户端退出然后自动结束会话
desired_caps['newCommandTimeout'] = 60

# 启动微信公众号,要设置这里
# 查询pid,命令行输入 adb shell dumpsys activity top | findstr ACTIVITY
# 查询当前公众号进程,命令行输入 adb shell ps 查询的pid
desired_caps['chromeOptions'] = {'androidProcess': 'com.tencent.mm:tools'}

driver = webdriver.Remote('http://localhost:4723/wd/hub', desired_caps)
print("启动微信应用程序")
time.sleep(10)

# 点击国美管家
driver.find_element_by_xpath("//*[@text='国美管家']").click()

time.sleep(5)

# 点击预约服务
driver.find_element_by_xpath("//*[contains(@text, '预约服务')]").click()

time.sleep(5)

contexts = driver.contexts
for context in contexts:
    # 打印出来看看有哪些context
    print(context)
# 切换到webview模式以便查找web元素
driver.switch_to.context("WEBVIEW_com.tencent.mm:tools")

# 获取当前窗口的句柄
Handle = driver.current_window_handle
print("当前句柄: "   Handle)

# 获取所有窗口的句柄
Handles = driver.window_handles
for h in Handles:
    if h == Handle:
        print("忽略句柄: "   h)
    else:
        driver.switch_to.window(h)
        print("跳到句柄: "   h)
        # 打印当前网页源码
        print("句柄 "   h   " 网页源码:"   driver.page_source)
        break

time.sleep(2)

# 点击手机回收
driver.find_element_by_xpath("//a[text()='手机回收']").click()

time.sleep(10)

# 返回
driver.keyevent(4)

time.sleep(5)

# 返回
driver.keyevent(4)

time.sleep(5)

# 切换到App模式
driver.switch_to.context("NATIVE_APP")

# 点击返回
driver.find_element_by_xpath("//android.widget.ImageView[@content-desc='返回']").click()

time.sleep(2)
driver.quit()

2、执行脚本

1、开启Appium服务(任选一种即可)

方式一:开启Appium Server

打开命令行,输入 appium --address 127.0.0.1 --port 4723 --no-reset --session-override

如图所示,Appium服务开启。

方式二:开启Appium Desktop

打开Appium Desktop

如服务IP和端口默认的情况下,直接点击Start Server v1.8.0来开启Appium服务,如图所示。

2、选中脚本鼠标右键Run,执行测试脚本。

脚本执行步骤:

(1)启动微信应用程序

(2)点击国美管家

(3)点击预约服务

(4)打印出被测App的NATIVE_APP和WEBVIEW

代码语言:javascript复制
NATIVE_APP
WEBVIEW_com.huawei.wifiprobqeservice
WEBVIEW_com.tencent.mm:appbrand0
WEBVIEW_com.tencent.mm:tools
WEBVIEW_com.iflytek.ringdiyclient
WEBVIEW_com.tencent.mm:support

(5)切换到WEBVIEW_com.tencent.mm:tools(webview模式)以便查找web元素

(6)获取当前窗口的句柄

(7)获取所有窗口的句柄

因为有多个句柄,要跳到正确的句柄才可以操作页面元素,并且每次执行的时候,句柄值都是变化的,不固定。

第一次执行:

当前句柄: CDwindow-385a779c-77c1-4d29-915c-d1f5e0c5d3d2

忽略句柄: CDwindow-385a779c-77c1-4d29-915c-d1f5e0c5d3d2

跳到句柄: CDwindow-2d8c2079-6e9b-441d-a524-3092494f443c

第二次执行:

当前句柄: CDwindow-71f733f6-34f8-4476-a5b6-498ab61ca8c9

忽略句柄: CDwindow-71f733f6-34f8-4476-a5b6-498ab61ca8c9

跳到句柄: CDwindow-b2ad0ac9-3b82-49fb-ba54-17d69df4e68e

(8)打印当前网页源码

(9)点击手机回收

(10)返回

(11)返回

(12)切换到NATIVE_APP(App模式)

(13)点击返回

(14)关闭微信应用程序

3、在执行测试脚本切换到WebView模式操作中,可能多多少少会遇到一些报错,排除元素定位不对的情况,大部分报错都是WebView与驱动的版本不匹配所产生的。

例如以下报错,提示An unknown server-side error occurred while processing the command. Original error: session not created exception

from unknown error: Runtime.executionContextCreated has invalid 'context': {"auxData":{"frameId":"22596.1","isDefault":true},"id":1,"name":"","origin":"://"}

解决方法就是让WebView版本与驱动版本匹配,让驱动进行降级或者升级。

那如何知道WebView与驱动是否匹配呢?

打开PC的Chrome浏览器,输入访问地址chrome://inspect/

在udid为MYV0215825000026的真机里,打开要操作的微信公众号webview页面,此时在PC的Chrome浏览器中可以看到访问链接,如图所示,真机里的WebView版本号为57.0.2987.132

被测应用的WebView版本号知道了,接下来开始确定要匹配的驱动版本,与chromedriver版本是否匹配。

chromedriver历史版本下载地址:https://chromedriver.storage.googleapis.com/index.html

chromedriver版本支持的Chrome版本对应列表:

选择指定的chromedriver版本(如图:WebView版本为57.0.2987.132,所以chromedriver版本选为2.28),可根据不同的平台(Win、Mac、Linux)下载指定的chromedriver。

指定的chromedriver下载完成后,双击可看此驱动版本号。

chromedriver应该放在哪里呢?根据所要使用的Appium服务,拷贝到Appium Server或者Appium Desktop的相应目录下即可。拷贝完成后,就可以正常使用了。

在Windows环境下:

Appium Server的chromedriver路径,例如:

C:UsersadminAppDataRoamingnpmnode_modulesappiumnode_modulesappium-chromedriverchromedriverwinchromedriver.exe

Appium Desktop的chromedriver路径,例如:

C:UsersadminAppDataLocalProgramsAppiumresourcesappnode_modulesappium-chromedriverchromedriverwinchromedriver.exe

在Mac环境下:

注意,当Appium服务用的是Appium Server时,执行脚本报错为An unknown server-side error occurred while processing the command. Original error: Trying to use a chromedriver binary at the path /usr/local/lib/node_modules/appium/node_modules/appium-chromedriver/chromedriver/mac/chromedriver, but it doesn't exist!

说明没有找到chromedriver驱动,按报错提示创建相应目录,并把chromedriver驱动拷贝到指定位置里。

Appium Server的chromedriver路径,例如:

/usr/local/lib/node_modules/appium/node_modules/appium-chromedriver/chromedriver/mac/chromedriver

Appium Desktop的chromedriver路径,例如:

/Applications/Appium.app/Contents/Resources/app/node_modules/appium-chromedriver/chromedriver/mac/chromedriver

0 人点赞