本文章转载于搜狗测试
不知道上次看完文章的小伙伴,有没有点感悟;
说完UITest,让我们再了解这个自动化框架;
Appium
Appium作为一个开源的、跨平台的自动化测试工具,适用于测试原生或混合型移动App。
Appium的核心是一个web服务器,他使用WebDriver json wire协议,来驱动系统的UIAutomation(UIAutomation后续会详细介绍)库。
WebDriver Json wire协议的Server端采用node.js封装了iOS UI Automation的接口,提供提供出一套RESTFul web service的接口,这样Client端以HTTP请求获得操纵UI的能力。
说到底,真正执行测试的还是 UIAutomation,Appium只是封装或解释了UIAutomation的执行脚本,作为UIAutomation和被测试APP的中间层传递消息。
让我们分析一下appium的优缺点:
优点:
(1) 跨平台 - appium可以很好的融合在addroid和iOS系统之间
(2) 支持多种语言 - 支持各种语言对appium的脚本编写,但是好像oc的支持不太好
(3) 不依赖源代码 - 不用依赖于源码的支持,这是一个很突出的亮点
(4) 开源 - 这个说主要也不算主要,因为appium是给予UIAutomaiton之上的,而UIAutomation不是开源的
缺点:
(1) 环境配置较繁琐 - 配置及其繁琐,而且问题较多,需要你耐心的就一点点解决,iOS版本更为严重
(2) 不支持自定义控件
(3) UIWebView的状态不可访问
(4) 无法脱机跑,需要连着Mac机器 - 这是iOS自动化框架共有的硬伤
(5) 支持系统效率慢 - 这是我认为这个框架比较严重的伤,由于不是苹果公司自有的框架,在支持上总慢一两个月,所以很多人在适配新系统的时候比较头疼
适用场景:
多平台的应用测试或是web应用测试。
测试脚本:
原理
Appium是由client和server组成,client提供多种语言的API,这些API是对WebDriver的扩展和封装,利用这些API就可以快速编写测试用例;client和server间通过符合Mobile JSON Wire Protocol的http请求进行交互。下面是Appium在iOS上的一个架构图:
1.上图左边为Appium client端,除手机外的部分为server端,client和server的通信是通过http进行的,
所以不管用什么语言实现,只要client能发出符合协议的http请求就可以,这就是Appium支持多种语言的原因。
2.又由于WebDriver已经够好的了,为了避免重复造轮子,Appium对WebDriver的API进行了扩展,WebDriver
已经binding的语言都可以拿来用,省去了为每种语言开发一个client的工作量。
3.Appium的server部分主要功能是监听一个端口,接收由client发送来的http请求后进行翻译,调用苹果官方
提供的UIAutomation库来进行模拟点击等操作,操作后移动设备把执行结果返回给server,server再把结果
返回给client。
4.图中的Instruments command server维护了一个command队列,Instruments command
client从中取走命令并在iOS的instruments环境中的bootstrap.js中执行。
框架的原理相对简单,大家可以熟悉一下,在github上也有源码,大家可以去看一下。https://github.com/testerhome/appium-chinese-tutorial
安装及配置
我简单的介绍一下安装过程,可能在安装过程中,会遇到一下问题,这里就不一一举例了,我们后续讨论
brew安装。brew之于OS X如同apt之于Ubuntu。
Node安装
brew install node
安装Appium server
l install globally
npm install -g appium
npm install wd
安装Appium Client
安装 selenium python-client
下载 https://pypi.python.org/packages/source/s/selenium/selenium-2.42.1.tar.gz
python setup.py install
安装 appium python-client
下载 https://github.com/appium/python-client/archive/master.zip
python setup.py install
启动Appium server
~ appium
info: Welcome to Appium v1.1.0 (REV e433bbc31511f199287db7724e1ce692bcb32117)
info: Appium REST http interface listener started on 0.0.0.0:4723
info: LogLevel: debug
获取控件
根据”class”定位
el = self.driver.find_elements_by_class_name(‘UIAButton’)
根据”xpath”定位
el = self.driver.find_element_by_xpath(‘//UIAMapView[1]’)
iOS uiautomation
sum = self.driver.find_element_by_ios_uiautomation(‘elements()[3]’).text
一个递归地、使用本地Accessibility的Name进行元素搜索的字符串
element = self.driver.find_element_by_name(“Test Gesture”)
同时,Appuim还提供一个第三文的工具Appium Inspector,以方便定位控件:
执行操作
滑动屏幕
self.driver.execute_script(“mobile: swipe”, {“touchCount”: 1 , “startX”: x1, “startY”: y1, “endX”: x2, “endY”: y2, “duration”: 2})
点击
self.driver.execute_script(“mobile: tap”, {“tapCount”: 1, “touchCount”: 1, “duration”: during_time, “x”: x1, “y”: y1 }
获取元素内容
element = self.driver.find_element_by_xpath(r”%s” % elementinfo)
Element.txt
截图
screenshot = self.driver.get_screenshot_as_base64()
执行测试
在启动服务器后,执行测试脚本即可。但是测试脚本里要包含以下内容,作为Appium的初始化,告诉Appium要测试哪台机器上的哪个app,以及其他信息。
怎么样你的app是不是也跑起来了??