使用Robot Framework+Appium进行移动端UI自动化
最近项目需要做移动端自动化,找到Appium,在网上搜了一大堆教程,很多都写的很乱,自己摸索了一阵给弄出来了,所以想写个教程记录一下。
本人是使用mac做的,使用win的朋友可以参考一下,大体差不多。
先说一下需要准备的东西,因为是基于Robot Framework框架的,所以robot需要的东西都要装上,robot第一个示例这里可以参考一下虫师的博客:
- JDK
- SDK
- Python(mac自带2.7)
- Robot framework
- wxPython
- Robot framework-ride
- Robot framework-selenium2library
- Appium-Python-Client
- robotframework-appiumlibrary
- Appium
- 模拟器
声明
这里只说到如何通过Appium实现UI自动化的一个demo,进阶内容下一期再说,需要安装的内容这里默认已经安装好,安装教程百度,这些比较容易查到
环境检查准备
找到adb路径打开命令行窗口,输入adb,如果提示'command not found',需要设置adb环境变量
cd到user文件夹下,运行
touch .bash_profile
open -e .bash_profile
在打开的窗口中加入
export PATH=$PATH:/xxx/sdk/platform-tools
关闭窗口,运行命令
source .bash_profile
这时候再运行adb -version就可以看到adb版本了
查看版本这时候运行adb devices查看链接的移动设备,如果是使用模拟器会发现列表中没有模拟器的设备信息,以本人使用的夜神模拟器为例,运行如下命令即可
1.先到模拟器中打开开发者模式( 夜神模拟器:设置->关于平板电脑->点击5次版本号 进入开发者模式 )
2.右键点击夜神模拟器的app,选择显示包内容,进入到MacOS文件夹中
命令行cd到MacOS文件夹下,运行命令
adb connect 127.0.0.1:62001
现在再运行adb devices命令就能看到设备信息了,显示如下:
查看设备信息接下来看看Appium
打开我们下载的Appium,点开设置按钮
设置AppiumServer Address设置为本地ip,端口号不变
Override Existing Sessions勾选上
点开安卓小人,App Path设置为你需要测试的app在本机的地址
安卓版本选择模拟器对应的安卓版本
点击Launch,出现下图我们就可以进行下一步了:
检查运行状态另外点击上面听诊器按钮可以进行自检,缺少组件会提示
Demo示例
新建一个测试项目在命令行运行ride.py打开RIDE,像创建web测试项目一样,我们创建一个android测试项目
注意在测试套件里面导入AppiumLibrary包
导入AppiumLibrary如果导入没有问题AppiumLibrary显示为黑色
接下来写第一条测试用例
第一条测试用例伪代码为:
Open Application http://127.0.0.1:4723/wd/hub platformName=Android platformVersion=4.4.2 deviceName=127.0.0.1:62001 app=/Users/moooke/Desktop/bosch-debug.apk
其中几个参数说明一下
Open Application : 关键字
http://127.0.0.1:4723/wd/hub :/wd/hub为固定格式,前面我是指向本机地址
platformName : 平台名称
platformVersion : 平台版本
deviceName : 设备名称
app : 指向待测试app的路径
之后还有两个参数:包名、Activity名字,可以省略
用例运行结果接下来我们先把apk安装到模拟器中,让Appium跑起来,然后跑我们刚才写的这个用例
可以看到模拟器已经把我安装的apk启动起来了。
这个时候可能会遇到问题,ride提示应用没有启动成功,Appium中报错:
注意报错信息这是因为环境变量没有设置完成,找到我们之前的 .bash_profile文件夹
open -e .bash_profile
在打开的文件中写入
export PATH=$PATH:/xxx/sdk/tools
export ANDROID_HOME=/xxx/sdk/
这时候再通过ride运行我们的测试用例就可以成功打开应用了。
两点补充
第一次运行robot framework进行web-ui自动化的时候可能会提示浏览器打开错误,如果大家用的是chrome,一般来说是因为对应的驱动有问题,大家可以先查看自己的chrome版本,然后去网上搜对应的chrome的驱动,下载好之后,同样在刚才的 .bash_profile 文件中添加上
export PATH=$PATH:/xxx/chromedriver #指向自己下载的chormedriver
就可以正常启动chrome了
在sdk-tools文件夹下可以找到uiautomatorviewer文件
双击打开,点击设备按钮
我们就可以看到如图所示的界面,通过右边的标签我们就可以很轻松定位到我们所需要的元素信息了
更多的API信息和操作会持续分享
网友评论