Appium

Appium是一个开源、跨平台的测试框架,可以用来测试原生及混合的移动端应用。Appium支持IOS、Android及FirefoxOS平台。Appium使用WebDriver的json wire协议,来驱动Apple系统的UIAutomation库、Android系统的UIAutomator框架。Appium对IOS系统的支持得益于Dan Cuellar’s对于IOS自动化的研究。Appium也集成了Selendroid,来支持老android版本。

使用Appium进行自动化测试有两个好处:
1. Appium在不同平台中使用了标准的自动化APIs,所以在跨平台时,不需要重新编译或者修改自己的应用。
2. Appium支持Selenium WebDriver支持的所有语言,如java、Object-C、JavaScript、Php、Python、Ruby、C#、Clojure,或者Perl语言,更可以使用Selenium WebDriver的Api。Appium支持任何一种测试框架。如果只使用Apple的UIAutomation,我们只能用javascript来编写测试用例,而且只能用Instruction来运行测试用例。同样,如果只使用Google的UIAutomation,我们就只能用java来编写测试用例。Appium实现了真正的跨平台自动化测试。

Requirements

总体:

  • IOS自动化测试需要Mac os操作系统
  • Mac OS X 10.7或者更高版本,推荐10.8.4版本
  • Android自动化测试可以在Mac、Linux上进行。对于Windows平台的支持还在beta阶段
  • 需要安装node和npm(node版本高于0.8)

IOS自动化:

  • Mac Xcode
  • Apple开发者工具(iphone模拟器sdk,及命令行工具)
    Android自动化:
  • Android SDK API版本 >= 17,即android版本高于4.2

快速入门

方案1: 使用Appium.app

  • 下载appium.app dmg
  • 在Apple系统上安装appium.app,就可以直接运行自己的case

方案2: 使用node从命令行运行appium

  • 安装node及npm
  • 下面命令是在linux系统中安装appium
mkdir appium-test && cd appium-test
npm install -g appium  # might have to do this with sudo
sudo authorize_ios # enable developer use of iOS sim
npm install wd
curl -O https://raw.github.com/appium/appium/master/sample-code/examples/node/simplest.js
appium &
node simplest.js

下面是一些不同语言编写的appium的测试用例
Example Tests: 

Node.js

 | Python | PHP | Ruby | Java

问题解决

如果使用过程遇到问题,可以参考这里,这里包含了一些常见错误的解决方法,也包含appium组织的联系方法。

使用appium编写测试用例

Appium支持Selenium WebDriver json wire 协议(部分支持,非全部)

appium定位元素的方法也和webdriver类似,但是也仅支持webdriver中的部分方法,详细信息见这里.

Appium也为json wire协议提供了一些拓展,来支持智能手机的手势动作,如tap(轻击)、flick,swipe,更多信息点击这里

Appium也支持在混合的app中,自动化测试web views,参见这里

Appium 同时支持Android和IOS平台:

  • Appium自动化测试Android、IOS,环境搭建
  • Appium自动化测试Android,环境搭建
  • Appium自动化测试Android,linux环境搭建
  • Appium自动化测试IOS,目标app准备
  • Appium自动化测试Android,目标app准备
  • IOS自动化用例执行
  • Android自动化用例执行
  • 在Mac系统中,Ruby使用appium进行自动化测试

Appium全部文档,点击https://github.com/appium/appium/tree/master/docs。