前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >自动化-Appium-​第一个Demo-混合(Python版)

自动化-Appium-​第一个Demo-混合(Python版)

作者头像
wangmcn
发布2022-07-25 12:58:55
2.5K0
发布2022-07-25 12:58:55
举报
文章被收录于专栏:AllTests软件测试

第一个Demo-混合

什么是Hybrid(混合)?

App是移动混合应用程序,即在移动应用程序中嵌入了Webview,通过Webview访问网页。

移动应用和Webview分别属于两个不同的上下文,移动应用默认的Context为”NATIVE_APP”,Webview默认的Context为”WEBVIEW_被测进程名称”。测试Webview中的网页内容时,需要切换到Webview的Context下。

第1章 Android

1.1创建项目

1、启动PyCharm,创建My_Appium_Demo项目。创建demo包,之后创建脚本文件。例如:模拟器示例为Android_Hybrid_Simulator,真机示例为Android_Hybrid_RealMachine

如图所示:

2、创建app文件夹,用来存放应用程序。把应用程序Bangbang.apk、Qunar.apk拷贝到文件夹里。

3、打开项目解释器(File--->Settings...--->Project:--->Project Interpreter),确保Appium-Python-Client包已经被项目引用。

1.2编写脚本

1.2.1模拟器

1、本章示例模拟器使用的是Genymotion,首先打开Genymotion模拟器,打开指定的Android版本。

2、首先获取模拟器设备标识,命令行输入命令 adb devices

如图所示,只查询到1台此模拟器,在脚本里可以不用添加此参数

desired_caps['udid'] = '192.168.176.101:5555'

就可以指定此台模拟器执行。

如果是多台设备,如图所示,查询到2台(1台模拟器192.168.176.101:5555、1台真机MYV0215825000026),在脚本就要添加此参数

desired_caps['udid'] = '192.168.176.101:5555'

测试执行的时候来指定这台模拟器执行。

3、模拟器里没有要测试的应用程序,可以在执行自动化测试前先安装到模拟器里,输入安装命令 adb install -r 进行安装,或者使用手机助手进行安装,或者直接将.apk应用程序拖拽到模拟器上进行安装。

4、模拟器里没有要测试的应用程序,想在自动化测试执行的时候自动安装。则需要在脚本里添加如下代码:

代码语言:javascript
复制
# `.ipa`或`.apk`文件所在的本地绝对路径或者远程路径,也可以是一个包括两者之一的`.zip`
# Appium会先尝试安装路径对应的应用在适当的真机或模拟器上
# 针对Android,如果你指定`app-package`和`app-activity`的话,那么就可以不指定`app`
# 例如/abs/path/to/my.apk or http://myapp.com/app.ipa
desired_caps['app'] = os.path.abspath('C:\\PycharmProjects\\My_Appium_Demo\\app\\Bangbang.apk')

5、当模拟器里有要测试的应用程序,每次执行测试脚本可以不用安装被测应用,只要指定appPackage和appActivity就可以了。

6、接下来开始使用查找元素定位工具来获取元素的属性值等信息,那怎么知道所要测试的应用程序是否是混合型的呢?例如使用Android SDK的uiautomatorviewer工具查找元素,有时识别不到webview中的元素,并且显示android.webkit.WebView,如下图:打开帮帮应用,点击帮助中心页面。

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

如图所示,可以检测到当前应用程序界面是Webview,则可以确定此应用程序是混合的。

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

7、切换NATIVE_APP还是WEBVIEW_被测进程名称,使用switch_to.context方法。

8、脚本代码:

代码语言:javascript
复制
#!/usr/bin/env python
# -*- coding: utf-8 -*-
from appium import webdriver
import os
import time
"""
Android-混合-模拟器
"""
# 定义启动设备需要的参数
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'] = '192.168.176.101:5555'

# `.ipa`或`.apk`文件所在的本地绝对路径或者远程路径,也可以是一个包括两者之一的`.zip`
# Appium会先尝试安装路径对应的应用在适当的真机或模拟器上
# 针对Android,如果你指定`app-package`和`app-activity`的话,那么就可以不指定`app`
# 例如/abs/path/to/my.apk or http://myapp.com/app.ipa
desired_caps['app'] = os.path.abspath('C:\\PycharmProjects\\My_Appium_Demo\\app\\Bangbang.apk')

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

# 要从包中启动的Android activity的活动名称
desired_caps['appActivity'] = 'com.xiaoV.BWallet.yklogin.YkSplashActivity'

# 启用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

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

# 点击左侧菜单
driver.find_element_by_id("com.xiaoV.BWalletBeta:id/iv_left_image").click()

time.sleep(2)

# 点击帮助中心
driver.find_element_by_id("com.xiaoV.BWalletBeta:id/helpcenter").click()

time.sleep(5)

contextNames = driver.contexts
for contextName in contextNames:
    # 打印出被测App是NATIVE_APP还是WEBVIEW,如果两者都有就是混合型App
    print(contextName)
    if contextName == "WEBVIEW_com.xiaoV.BWalletBeta":
        # 切换到webview模式以便查找web元素
        driver.switch_to.context(contextName)
        print("切换到webview:" + driver.current_context)

time.sleep(2)

# 打印当前网页源码
print(driver.page_source)

time.sleep(2)

# 切换到App模式
driver.switch_to.context("NATIVE_APP")
print("切换到App:" + driver.current_context)

time.sleep(2)

# 点击返回
driver.find_element_by_id("com.xiaoV.BWalletBeta:id/iv_left_image").click()

time.sleep(2)
driver.quit()

1.2.2真机

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

2、真机设备里没有要测试的应用程序,可以在执行自动化测试前先安装到设备里,输入安装命令 adb install -r 进行安装,或者使用手机助手进行安装。

3、真机设备里没有要测试的应用程序,想在自动化测试执行的时候自动安装。则需要在脚本里添加如下代码:

代码语言:javascript
复制
# `.ipa`或`.apk`文件所在的本地绝对路径或者远程路径,也可以是一个包括两者之一的`.zip`
# Appium会先尝试安装路径对应的应用在适当的真机或模拟器上
# 针对Android,如果你指定`app-package`和`app-activity`的话,那么就可以不指定`app`
# 例如/abs/path/to/my.apk or http://myapp.com/app.ipa
desired_caps['app'] = os.path.abspath('C:\\PycharmProjects\\My_Appium_Demo\\app\\Qunar.apk')

4、当真机设备里有要测试的应用程序,每次执行测试脚本可以不用安装被测应用,只要指定appPackage和appActivity就可以了。

5、接下来开始使用查找元素定位工具来获取元素的属性值等信息,那怎么知道所要测试的应用程序是否是混合型的呢?例如使用Android SDK的uiautomatorviewer工具查找元素,有时识别不到webview中的元素,并且显示android.webkit.WebView,如下图:打开去哪儿应用,点击我的页面。

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

如图所示,可以检测到当前应用程序界面是Webview,则可以确定此应用程序是混合的。

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

6、切换NATIVE_APP还是WEBVIEW_被测进程名称,使用switch_to.context方法。

7、脚本代码:

代码语言:javascript
复制
#!/usr/bin/env python
# -*- coding: utf-8 -*-
from appium import webdriver
import os
import time
"""
Android-混合-真机
"""
# 定义启动设备需要的参数
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'

# `.ipa`或`.apk`文件所在的本地绝对路径或者远程路径,也可以是一个包括两者之一的`.zip`
# Appium会先尝试安装路径对应的应用在适当的真机或模拟器上
# 针对Android,如果你指定`app-package`和`app-activity`的话,那么就可以不指定`app`
# 例如/abs/path/to/my.apk or http://myapp.com/app.ipa
desired_caps['app'] = os.path.abspath('C:\\PycharmProjects\\My_Appium_Demo\\app\\Qunar.apk')

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

# 要从包中启动的Android activity的活动名称
desired_caps['appActivity'] = 'com.mqunar.splash.SplashActivity'

# 启用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

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

# 点击我的
driver.find_element_by_id("com.mqunar.atom.alexhome:id/atom_alexhome_uc_default").click()

time.sleep(2)

contextNames = driver.contexts
for contextName in contextNames:
    # 打印出被测App是NATIVE_APP还是WEBVIEW,如果两者都有就是混合型App
    print(contextName)
    if contextName == "WEBVIEW_com.Qunar":
        # 切换到webview模式以便查找web元素
        driver.switch_to.context(contextName)
        print("切换到webview:" + driver.current_context)

time.sleep(2)

# 打印当前网页源码
print(driver.page_source)

time.sleep(2)

# 返回
driver.keyevent(4)

time.sleep(2)

# 切换到App模式
driver.switch_to.context("NATIVE_APP")
print("切换到App:" + driver.current_context)

time.sleep(2)

# 点击首页-机票
driver.find_element_by_id("com.mqunar.atom.alexhome:id/atom_alexhome_mod_flight").click()

time.sleep(8)
driver.quit()

1.3执行脚本

1.3.1模拟器

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,如果两者都有就是混合型App,打印出来的结果:可以看到是混合型App

NATIVE_APP

WEBVIEW_com.xiaoV.BWalletBeta

(5)切换到WEBVIEW_com.xiaoV.BWalletBeta(webview模式)以便查找web元素

(6)打印当前网页源码

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

(8)点击返回

(9)关闭帮帮应用程序

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为192.168.113.101:5555的模拟器

在udid为192.168.113.101:5555的模拟器里,打开要操作的应用程序webview页面,本章示例为打开帮帮应用-帮助中心页面,此时在PC的Chrome浏览器中可以看到帮助中心页的访问链接,如图所示,模拟器里的WebView版本号为44.0.2403.119

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

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

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

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

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

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

在Windows环境下:

Appium Server的chromedriver路径,例如:

C:\Users\admin\AppData\Roaming\npm\node_modules\appium\node_modules\appium-chromedriver\chromedriver\win\chromedriver.exe

Appium Desktop的chromedriver路径,例如:

C:\Users\admin\AppData\Local\Programs\Appium\resources\app\node_modules\appium-chromedriver\chromedriver\win\chromedriver.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

1.3.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)打印出被测App是NATIVE_APP还是WEBVIEW,如果两者都有就是混合型App,打印出来的结果:可以看到是混合型App

NATIVE_APP

WEBVIEW_com.Qunar

WEBVIEW_com.iflytek.ringdiyclient

WEBVIEW_com.huawei.wifiprobqeservice

(4)切换到WEBVIEW_com.Qunar(webview模式)以便查找web元素

(5)打印当前网页源码

(6)返回

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

(8)点击首页-机票

(9)关闭去哪儿应用程序

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的真机

在udid为MYV0215825000026的真机里,打开要操作的应用程序webview页面,本章示例为打开去哪儿应用-我的页面,此时在PC的Chrome浏览器中可以看到我的页面访问链接,如图所示,真机里的WebView版本号为55.0.2883.91

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

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

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

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

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

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

在Windows环境下:

Appium Server的chromedriver路径,例如:

C:\Users\admin\AppData\Roaming\npm\node_modules\appium\node_modules\appium-chromedriver\chromedriver\win\chromedriver.exe

Appium Desktop的chromedriver路径,例如:

C:\Users\admin\AppData\Local\Programs\Appium\resources\app\node_modules\appium-chromedriver\chromedriver\win\chromedriver.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

第2章 IOS

2.1创建项目

1、启动PyCharm,创建My_Appium_Demo项目。创建demo包,之后创建脚本文件。例如:模拟器示例为IOS_Hybrid_Simulator,真机示例为IOS_Hybrid_RealMachine

如图所示:

2、创建app文件夹,用来存放应用程序。把应用程序UICatalog.app、VWallet.ipa拷贝到文件夹里。

3、打开项目解释器(PyCharm--->Preferences...--->Project:--->Project Interpreter),确保Appium-Python-Client包已经被项目引用。

2.2编写脚本

2.2.1模拟器

1、使用Xcode创建模拟器,例如:本章示例模拟器名iPhone 8,IOS版本11.3。

2、关于测试的应用程序:

(1)如果是在模拟器上运行,需要装.app的应用程序文件。

要想在IOS模拟器中运行应用,则必须在Xcode中编译时选择模拟器类型,编译生成的文件后缀为.app

(2)如果是在真机上运行,需要装.ipa的应用程序文件。分为正式版和开发版。

正式版(已经发布到App Store上),可以直接在App Store上下载安装或者可以获取.ipa应用程序文件用命令安装到真机上。

开发版(没有发布到App Store上),只能获取.ipa应用程序文件,并且苹果开发者账号添加此真机的UDID,才可以用命令安装到此真机上。

3、模拟器里没有要测试的应用程序,直接将.app应用程序拖拽到模拟器上进行安装即可。

4、模拟器里没有要测试的应用程序,想在自动化测试执行的时候自动安装。则需要在脚本里添加如下代码:

代码语言:javascript
复制
# `.ipa`或`.apk`文件所在的本地绝对路径或者远程路径,也可以是一个包括两者之一的`.zip`
# Appium会先尝试安装路径对应的应用在适当的真机或模拟器上
# 针对Android,如果你指定`app-package`和`app-activity`的话,那么就可以不指定`app`
# 例如/abs/path/to/my.apk or http://myapp.com/app.ipa
desired_caps['app'] = os.path.abspath('/Users/admin/PycharmProjects/My_Appium_Demo/app/UICatalog.app')

5、当模拟器里有要测试的应用程序,每次执行测试脚本可以不用安装被测应用,只要指定bundleId就可以了。

6、在模拟器里测试应用程序,需要指定应用程序的bundleId,因为.app为测试版应用程序,所以bundleId可以询问开发人员提供。

例如:本章UICatalog应用bundleId为com.example.apple-samplecode.UICatalog。

代码语言:javascript
复制
# 被测应用的bundle ID
# 用于在真实设备中启动测试,也用于使用其他需要bundle ID的关键字启动测试
# 在使用bundle ID在真实设备上执行测试时,你可以不提供`app`关键字,但你必须提供`udid`
desired_caps['bundleId'] = 'com.example.apple-samplecode.UICatalog'

7、接下来开始使用查找元素定位工具来获取元素的属性值等信息,那怎么知道所要测试的应用程序是否是混合型的呢?例如使用Appium Desktop的Inspector工具查找元素,有时识别不到webview中的元素,并且显示XCUIElementTypeWebView。

首先打开Appium Desktop,点击Start Server v1.8.0来开启Appium服务。

点击放大镜(Start Inspector Session)。

输入Desired Capabilities相关参数信息。例如:

代码语言:javascript
复制
{
  "platformName": "iOS",
  "platformVersion": "11.3",
  "deviceName": "iPhone 8",
  "automationName": "XCUITest",
  "bundleId": "com.example.apple-samplecode.UICatalog"
}

之后点击Start Session。

获取指定的元素信息。

如图所示显示Webview页面,XCUIElementTypeWebView。

8、接下来开始使用查找元素定位工具来获取Webview元素的属性值等信息。

获取Webview元素方式有2种(任选一种即可),元素定位方法同Selenium WebDriver一致。

方式一:通过Mac上的Safari

首先将模拟器上的应用程序打开,之后打开此应用显示的Webview页面;之后打开Mac上的Safari,选择开发--->模拟器,可以看到此时模拟器打开的Webview页面,例如:苹果首页。

点击苹果首页的链接,会弹出新窗口,显示苹果首页的html源码信息,则可以获取相应的Webview元素信息。

方式二:通过ios_webkit_debug_proxy工具

首先将模拟器上的应用程序打开,之后打开此应用显示的Webview页面;

之后在Mac上打开终端,输入启动代理命令

ios_webkit_debug_proxy -f chrome-devtools://devtools/bundled/inspector.html

Mac上打开Chrome浏览器,在地址栏输入http://localhost:9221/,这里会显示所有已连接的设备清单,选择一个设备并点击打开。例如:模拟器

此时检测到模拟器上打开的Webview页面,例如苹果首页

选中后,鼠标右键点击转到……

打开选中的页面,将Chrome的开发者工具打开,显示html源码信息,则可以获取相应的Webview元素信息。

或者,选中后,鼠标右键复制链接地址

例如:

chrome-devtools://devtools/bundled/inspector.html?ws=localhost:9222/devtools/page/1

打开Chrome新窗口,将复制的地址粘贴后访问

显示html源码信息,则可以获取相应的Webview元素信息。

9、切换NATIVE_APP还是WEBVIEW_被测进程名称,使用switch_to.context方法。

10、脚本代码:

代码语言:javascript
复制
#!/usr/bin/env python
# -*- coding: utf-8 -*-
from appium import webdriver
from appium.webdriver.common.touch_action import TouchAction
import os
import time
"""
IOS-混合-模拟器
"""
# 定义启动设备需要的参数
desired_caps = {}

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

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

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

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

# `.ipa`或`.apk`文件所在的本地绝对路径或者远程路径,也可以是一个包括两者之一的`.zip`
# Appium会先尝试安装路径对应的应用在适当的真机或模拟器上
# 针对Android,如果你指定`app-package`和`app-activity`的话,那么就可以不指定`app`
# 例如/abs/path/to/my.apk or http://myapp.com/app.ipa
desired_caps['app'] = os.path.abspath('/Users/admin/PycharmProjects/My_Appium_Demo/app/UICatalog.app')

# 被测应用的bundle ID
# 用于在真实设备中启动测试,也用于使用其他需要bundle ID的关键字启动测试
# 在使用bundle ID在真实设备上执行测试时,你可以不提供`app`关键字,但你必须提供`udid`
desired_caps['bundleId'] = 'com.example.apple-samplecode.UICatalog'

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

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

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

# Appium中使用IWDP,指的就是ios-webkit-debug-proxy
desired_caps['startIWDP'] = True

# 当IOS的个人信息访问警告(如:位置、联系人、图片)出现时,自动选择接受(Accept),默认值`false`
desired_caps['autoAcceptAlerts'] = False

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

# 向下滑动
TouchAction(driver).press(x=170, y=430).wait(1000).move_to(x=170, y=230).release().perform()

time.sleep(2)

# 向下滑动
TouchAction(driver).press(x=170, y=430).wait(1000).move_to(x=170, y=230).release().perform()

time.sleep(2)

# 点击Web View
driver.find_element_by_name("Web View").click()

time.sleep(5)

contextNames = driver.contexts
for contextName in contextNames:
    # 打印出被测App是NATIVE_APP还是WEBVIEW,如果两者都有就是混合型App
    print(contextName)
    if "WEBVIEW" in contextName:
        # 切换到webview模式以便查找web元素
        driver.switch_to.context(contextName)
        print("切换到webview:" + driver.current_context)

time.sleep(2)

# 打印当前网页源码
print(driver.page_source)

time.sleep(2)

# 切换到App模式
driver.switch_to.context("NATIVE_APP")
print("切换到App:" + driver.current_context)

time.sleep(2)

# 点击返回
driver.find_element_by_name("UICatalog").click()

time.sleep(2)
driver.quit()

2.2.2真机

1、首先获取真机udid设备标识,终端输入 idevice_id -l

如图所示:显示该真机的udid信息。

2、关于测试的应用程序:

(1)如果是在模拟器上运行,需要装.app的应用程序文件。

要想在IOS模拟器中运行应用,则必须在Xcode中编译时选择模拟器类型,编译生成的文件后缀为.app

(2)如果是在真机上运行,需要装.ipa的应用程序文件。分为正式版和开发版。

正式版(已经发布到App Store上),可以直接在App Store上下载安装或者可以获取.ipa应用程序文件用命令安装到真机上。

开发版(没有发布到App Store上),只能获取.ipa应用程序文件,并且苹果开发者账号添加此真机的UDID,才可以用命令安装到此真机上。

3、本章示例使用的是真机,测试开发版帮帮应用(通过访问非App Store渠道下载帮帮应用安装到真机上)。

4、真机设备里没有要测试的应用程序,可以在执行自动化测试前先安装到设备里,输入安装命令ideviceinstaller -i [xxx.ipa] -o [设备udid] 进行安装,或者使用手机扫描应用程序二维码进行下载安装。例如:

ideviceinstaller -i /Users/automation/test/VWallet.ipa -o c5dc675bddf7d1ac6d91783d5224d72b427f8d04

5、真机设备里没有要测试的应用程序,想在自动化测试执行的时候自动安装。则需要在脚本里添加如下代码:

代码语言:javascript
复制
# `.ipa`或`.apk`文件所在的本地绝对路径或者远程路径,也可以是一个包括两者之一的`.zip`
# Appium会先尝试安装路径对应的应用在适当的真机或模拟器上
# 针对Android,如果你指定`app-package`和`app-activity`的话,那么就可以不指定`app`
# 例如/abs/path/to/my.apk or http://myapp.com/app.ipa
desired_caps['app'] = os.path.abspath('/Users/admin/PycharmProjects/My_Appium_Demo/app/VWallet.ipa')

6、真机设备里有要测试的应用程序,每次执行测试脚本可以不用安装被测应用,只要指定bundleId就可以了。

7、获取应用程序的bundleId,打开终端,输入 ideviceinstaller -l

如图所示:本章示例帮帮应用的bundleId为com.xiaoV.BangWalletBeta。

代码语言:javascript
复制
# 被测应用的bundle ID
# 用于在真实设备中启动测试,也用于使用其他需要bundle ID的关键字启动测试
# 在使用bundle ID在真实设备上执行测试时,你可以不提供`app`关键字,但你必须提供`udid`
desired_caps['bundleId'] = 'com.xiaoV.BangWalletBeta'

8、因测试开发版应用,在Appium执行的时候,要加

"xcodeOrgId": "< Apple开发者账户中的Team ID >",

"xcodeSigningId": "< 打包时证书的名字 >"

这两个参数。

如何获取TeamID?

登录https://developer.apple.com/account/ 里左侧的 Membership 中找到。

脚本添加如下参数:

代码语言:javascript
复制
# Apple开发者帐户中的Team ID
desired_caps['xcodeOrgId'] = '69XXXXXXXX'
# 打包时证书的名字
desired_caps['xcodeSigningId'] = 'iPhone Developer'

9、接下来开始使用查找元素定位工具来获取元素的属性值等信息,那怎么知道所要测试的应用程序是否是混合型的呢?例如使用Appium Desktop的Inspector工具查找元素,有时识别不到webview中的元素,并且显示XCUIElementTypeWebView。

首先打开Appium Desktop,点击Start Server v1.8.0来开启Appium服务。

点击放大镜(Start Inspector Session)。

输入Desired Capabilities相关参数信息。例如:

代码语言:javascript
复制
{
  "platformName": "iOS",
  "platformVersion": "11.1",
  "deviceName": "test",
  "automationName": "XCUITest",
  "bundleId": "com.xiaoV.BangWalletBeta",
  "udid": "c5dc675bddf7d1ac6d91783d5224d72b427f8d04",
  "xcodeOrgId": "69XXXXXXXX",
  "xcodeSigningId": "iPhone Developer"
}

之后点击Start Session。

获取指定的元素信息。

如图所示显示Webview页面,XCUIElementTypeWebView。

10、接下来开始使用查找元素定位工具来获取Webview元素的属性值等信息。

获取Webview元素方式有2种(任选一种即可),元素定位方法同Selenium WebDriver一致。

方式一:通过Mac上的Safari

首先将真机设备上的应用程序打开,之后打开此应用显示的Webview页面;之后打开Mac上的Safari,选择开发--->真机设备(如图:设备名为test),可以看到此时真机设备打开的Webview页面,例如:帮帮应用的帮助中心页面。

点击帮助中心页面的链接,会弹出新窗口,显示帮助中心页面的html源码信息,则可以获取相应的Webview元素信息。

方式二:通过ios_webkit_debug_proxy工具

首先将真机设备上的应用程序打开,之后打开此应用显示的Webview页面;

之后在Mac上打开终端,输入启动代理命令

ios_webkit_debug_proxy -f chrome-devtools://devtools/bundled/inspector.html

Mac上打开Chrome浏览器,在地址栏输入http://localhost:9221/,这里会显示所有已连接的设备清单,选择一个设备并点击打开。例如:真机设备(test)

此时检测到真机设备上打开的Webview页面,例如:帮助中心页面

选中后,鼠标右键点击转到……

打开选中的页面,将Chrome的开发者工具打开,显示html源码信息,则可以获取相应的Webview元素信息。

或者,选中后,鼠标右键复制链接地址

例如:

chrome-devtools://devtools/bundled/inspector.html?ws=localhost:9223/devtools/page/1

打开Chrome新窗口,将复制的地址粘贴后访问

显示html源码信息,则可以获取相应的Webview元素信息。

11、切换NATIVE_APP还是WEBVIEW_被测进程名称,使用switch_to.context方法。

12、脚本代码:

代码语言:javascript
复制
#!/usr/bin/env python
# -*- coding: utf-8 -*-
from appium import webdriver
import os
import time
"""
IOS-混合-真机
"""
# 定义启动设备需要的参数
desired_caps = {}

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

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

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

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

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

# `.ipa`或`.apk`文件所在的本地绝对路径或者远程路径,也可以是一个包括两者之一的`.zip`
# Appium会先尝试安装路径对应的应用在适当的真机或模拟器上
# 针对Android,如果你指定`app-package`和`app-activity`的话,那么就可以不指定`app`
# 例如/abs/path/to/my.apk or http://myapp.com/app.ipa
desired_caps['app'] = os.path.abspath('/Users/admin/PycharmProjects/My_Appium_Demo/app/VWallet.ipa')

# 被测应用的bundle ID
# 用于在真实设备中启动测试,也用于使用其他需要bundle ID的关键字启动测试
# 在使用bundle ID在真实设备上执行测试时,你可以不提供`app`关键字,但你必须提供`udid`
desired_caps['bundleId'] = 'com.xiaoV.BangWalletBeta'

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

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

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

# Apple开发者帐户中的Team ID
desired_caps['xcodeOrgId'] = '69XXXXXXXX'

# 打包时证书的名字
desired_caps['xcodeSigningId'] = 'iPhone Developer'

# Appium中使用IWDP,指的就是ios-webkit-debug-proxy
desired_caps['startIWDP'] = True

# 当IOS的个人信息访问警告(如:位置、联系人、图片)出现时,自动选择接受(Accept),默认值`false`
desired_caps['autoAcceptAlerts'] = False

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

# 点击左侧菜单
driver.find_element_by_name("logout Sidebar").click()

time.sleep(2)

# 点击帮助中心
driver.find_element_by_name("帮助中心").click()

time.sleep(5)

contextNames = driver.contexts
for contextName in contextNames:
    # 打印出被测App是NATIVE_APP还是WEBVIEW,如果两者都有就是混合型App
    print(contextName)
    if "WEBVIEW" in contextName:
        # 切换到webview模式以便查找web元素
        driver.switch_to.context(contextName)
        print("切换到webview:" + driver.current_context)

time.sleep(2)

# 打印当前网页源码
print(driver.page_source)

time.sleep(2)

# 切换到App模式
driver.switch_to.context("NATIVE_APP")
print("切换到App:" + driver.current_context)

time.sleep(2)

# 点击返回
driver.find_element_by_name("btn back").click()

time.sleep(2)
driver.quit()

2.3执行脚本

2.3.1模拟器

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,执行测试脚本。

脚本执行时,Appium Desktop或Appium Server自动将WDA(WebDriverAgent)安装到模拟器上。

脚本执行步骤:

(1)启动UICatalog应用程序

(2)向下滑动

(3)向下滑动

(4)点击Web View

(5)打印出被测App是NATIVE_APP还是WEBVIEW,如果两者都有就是混合型App,打印出来的结果:可以看到是混合型App

NATIVE_APP

WEBVIEW_6650.1(每次执行时WEBVIEW值是变化的,不是固定的)

(6)切换到WEBVIEW_6650.1(webview模式)以便查找web元素

(7)打印当前网页源码

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

(9)点击返回

(10)关闭UICatalog应用程序

2.3.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,如果两者都有就是混合型App,打印出来的结果:可以看到是混合型App

NATIVE_APP

WEBVIEW_20(每次执行时WEBVIEW值是变化的,不是固定的)

(5)切换到WEBVIEW_20(webview模式)以便查找web元素

(6)打印当前网页源码

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

(8)点击返回

(9)关闭帮帮应用程序

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-12-09,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 AllTests软件测试 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 第1章 Android
  • 1.2编写脚本
    • 1.2.1模拟器
      • 1.2.2真机
      • 1.3执行脚本
        • 1.3.1模拟器
          • 1.3.2真机
          • 第2章 IOS
          • 2.2编写脚本
            • 2.2.1模拟器
              • 2.2.2真机
              • 2.3执行脚本
                • 2.3.1模拟器
                  • 2.3.2真机
                  相关产品与服务
                  NAT 网关
                  NAT 网关(NAT Gateway)提供 IP 地址转换服务,为腾讯云内资源提供高性能的 Internet 访问服务。通过 NAT 网关,在腾讯云上的资源可以更安全的访问 Internet,保护私有网络信息不直接暴露公网;您也可以通过 NAT 网关实现海量的公网访问,最大支持1000万以上的并发连接数;NAT 网关还支持 IP 级流量管控,可实时查看流量数据,帮助您快速定位异常流量,排查网络故障。
                  领券
                  问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档