全部产品

Appium简介

更新时间:2017-02-20 22:02:22   分享:   

Appium是一个开源的、跨平台的测试框架,可以用来测试Native App、混合应用、移动Web应用(H5应用)。

  • Appium坚持的测试理念:
  1. 无需用户对App进行任何修改或者重新编译,App 应该 Born to be automated
  2. 不应该限制用户只能使用特定的语言或者框架来编写和执行测试。
  3. 移动测试框架的API应该是稳定的,合理的。不应对自动化API 反复地造轮子。
  4. 移动测试框架应该是开源的,包括“精神和肉体”。

目前,Appium支持Python、JavaScript、Objective C、Java、Ruby、PHP、C#。MQC目前首先选择支持Python语言和Java语言。其他语言将会陆续在MQC上得到支持。您也可以告诉我们您希望下一个被支持的语言。

  • Appium的架构是如何设计的?

事实上,Appium 真正的工作引擎全部是第三方自动化框架。这样,就不需在你的应用里植入其他任何代码。也就是说你测试使用的应用和最终发布的应用完全一致。使用以下的第三方框架如下:

  1. iOS 9.3-: AppleUIAutomation
  2. iOS 10.0+: FacebookWebDriverAgent
  3. Android 4.2+: GoogleUiAutomator
  4. Android 2.3+: GoogleInstrumentation (由单独的项目Selendroid提供支持)

Appium把这些第三方框架封装成一套 WebDriver API。(协议格式参见 JSON Wire Protocol)。使用这种CS架构,Appium就可以通过任何语言来封装API调用,从而提供不同语言的客户端给不同的人员。

Appium 的核心是一个 web 服务器,它提供了一套 REST 的接口。它收到客户端的连接,监听到命令,接着在移动设备上执行这些命令,然后将执行结果放在 HTTP响应中返还给客户端。事实上,这种客户端/服务端的架构给予了许多的可能性:比如我们可以使用任何实现了该客户端的语言来写我们的测试代码。比如我们可以把服务端放在不同 的机器上。

  • WebDriver 的Session概念

自动化始终围绕一个session进行,客户端初始化一个seesion(会话)来与服务端交互,不同的语言有不同的实现方式,但是他们最终都是发送为一个POST请求给服务端,请求中包含一个JSON对象,被称作“desired capabilities”。此时,服务端就会开启一个自动化的 session,然后返回一个 session ID,session ID将会被用户发送后续的命令。

  • 什么是Desired Capabilities?

Desired capabilities 是一些键值对的集合 (比如,一个 map 或者 hash),客户端将这些键值对发给服务端,告诉服务端我们想要怎么测试。比如,我们可以把platformName capability 设置为 iOS,告诉 Appium 服务端,我们想要一个iOS 的 session,而不是一个 Android 的。完整列表参见 capabilities 文档

本文导读目录
本文导读目录
以上内容是否对您有帮助?