本文首发于: 行者AI
Appium是一个自动化开源工具,支持iOS、Android和Windows桌面平台上的原生、移动Web和混合应用的自动化。Appium是跨平台的:它允许你用同样的API对多平台(iOS、Android、Windows)写测试。做到在iOS、Android和Windows测试套件之间复用代码。
1. 下载安装及环境配置
1.1 安装python安装Appium-Python-Client库
可以使用pip命令进行安装pip install Appium-Python-Client
,安装完成后在python中运行此段代码from appium import webdriver
校验是否安装成功 。
1.2 安装Android SDK
(1)在官网上下载Android Studio,其中包含了Android SDK,网页下拉到底部的Command line tools only,下载其中的windows版本,下载完成后解压,CMD命令行中cd到bin目录下,输入sdkmanager "platfrom-tools" "platforms;android-28" "build-tools;28.0.3"
执行安装组件,过程中弹出Accept?(y/N),输入y回车即可。
(2)组件安装完成之后,执行以下步骤将Android SDK加入到环境变量中。
- 在系统环境变量中创建ANDROID_HOME变量,值为SDK安装的根目录路径,例如:E:\android_sdk
- 将%ANDROID_HOME%\platform-tools加入到环境变量Path中
- 验证设置成功否:CMD命令行下输入
adb version
回车,可以看到当前adb的版本信息,说明Android SDK已经安装并配置成功
1.3 安装JDK
(1)在oracle官网下载安装JDK,安装JDK8及以上的版本。
(2)安装完成后,设置JDK的环境变量。
- 在系统环境变量中创建JAVA_HOME变量,值为JDK安装的跟目录路径,例如:C:\Program Files\Java\jdk1.8.0_231
- 在系统环境变量中创建CLASSPATH变量,值为 .;%JAVA_HOME%\lib;%JAVA_HOME%\lib\tools.jar
- 在Path变量中添加%JAVA_HOME%\bin;%JAVA_HOME%\jre\bin
- 验证JDK环境配置是否成功,CMD命令行下输入
java -version
回车,可以看到当前JDK的版本信息,说明JDK已经安装并配置成功
1.4 安装appium server
(1)在appium官网上下载Appium Desktop进行安装,找到与自己使用的系统对应的版本,本次所有操作都是在windows上进行的。
(2)安装完成后,启动appium,host和port默认即可,在Edit Configuration中将Android SDK和Java JDK加到环境变量中。
(3)设置好后保存并重启Appium,然后启动服务,出现以下画面,说明你的appium server已经正常启动了,可以开始真机测试了。
2. 真机测试
2.1 真机设置
USB连接手机,打开手机开发者模式,打开开发者选项中的USB调试、USB安装,小米手机还需要打开USB调试(安全设置),然后在CMD命令行输入adb devices
回车,如果出现了手机的设备号,说明连接成功。
2.2 设置Appium
(1)点击Start Inspector Session对进行Desired Capabilities的配置,在JSON Representation中输入以下json数据点击保存进行快速的配置,也可以在左边一项一项的添加。platformName、platformVersion、deviceName、appPackage、appActivity这五个参数是必填项。
{
"platformName": "Android", # 声明是ios还是Android系统
"platformVersion": "8.1.0", # Android内核版本号
"deviceName": "MI_5X", # 连接的设备名称
"appPackage": "com.tencent.qqmusic", # apk的包名
"appActivity": ".activity.AppStarterActivity", # apk的launcherActivity
"resetKeyboard": True,
"noReset": True # 在开始会话之前不要重置应用程序状态
}
以上数据通过adb命令获取,获取appPackage与appActivity时需要将app启动,获取命令如下:
(2)配置好Desired Capabilities后,点击Start Session,app启动运行之后可以在界面上点击选择查看当前页面所有元素控件的详细信息,右侧Selected Element下方有三个按钮。
- Tap:执行选中元素的点击操作
- Send Keys:为文本框等input对象传值
- Clear:清除输入框中的文本
2.3 编写自动化脚本
启动session成功运行app之后,点击你想要操作的元素,在右边可以看到这个元素的相关信息,这里我们可以通过id对该元素进行操作,在python中使用find_element_by_id()方法定位该元素,还有很多方法可以定位元素。
如:find_element_by_xpath()、driver.find_element_by_name()、driver.find_element_by_partial_link_text()等,使用click()方法对元素进行点击操作,使用swip()方法对屏幕进行滑动操作。
下面是python实现操作的源码展示,运行之后可以看到手机自动完成了启动app、点击、滑动和退出的操作后,说明python脚本运行成功。需要注意的是在完成上一步操作之后由于手机性能的差异,app的响应速度不同,建议等待几秒后再进行下一步操作。
import time
from appium import webdriver
caps = {
"platformName": "Android", # 声明是ios还是Android系统
"platformVersion": "8.1.0", # Android内核版本号
"deviceName": "MI_5X", # 连接的设备名称
"appPackage": "com.tencent.qqmusic", # apk的包名
"appActivity": ".activity.AppStarterActivity", # apk的launcherActivity
"resetKeyboard": True,
"noReset": True # 在开始会话之前不要重置应用程序状态
}
driver = webdriver.Remote("http://localhost:4723/wd/hub", caps) # 启动app
time.sleep(15)
el1 = driver.find_element_by_id("com.tencent.qqmusic:id/clt") # 定位<分类歌单>元素
el1.click() # 点击
time.sleep(5)
driver.swipe(500, 1550, 500, 800) # 从(500, 1500)滑动到(500, 800)
driver.quit() # 退出
3. 总结
Appium是目前比较成熟的自动化测试工具,使用了系统自带的自动化框架,不需要把Appium特定的或者第三方的代码编译进你的应用,这样就可以使用正式发布的包进行测试,不用担心测试包与正式包存在区别。同时可以结合python已有的测试框架,例如:pytest、unittest,编写测试用例,执行自动化测试。Appium还有很多很有趣的功能没有介绍到,欢迎有疑问或者建议的朋友与我们一起探讨。