一、启动Appium服务器
1、Appium Desktop启动
Appium Desktop的作用
简单来说,Appium Desktop其实是Appium服务器的图形界面,使用后就不需要使用Node / NPM来安装Appium。可以用来启动/停止服务器,使用检查器查看应用程序的元素,查看日志。-
根据系统下载release版本https://github.com/appium/appium-desktop/releases
-
安装使用
默认启动的server端口号为4723,可手动修改;使用Advanced也可配置更多服务器标志
iOS 和 Android 的运行配置详情可查:
iOS 和 Android 的运行
2、终端启动
安装
Appium 是一个用 Node.js 写的服务器,首先需要安装
npm install -g appium
启动服务器
终端直接输入:appium
$ appium
[Appium] Welcome to Appium v1.18.1
[Appium] Appium REST http interface listener started on 0.0.0.0:4723
- 环境要求
- node v10.11.0
- java version "1.8.0_171"
- Python 3.7.2
- Appium 1.18.0
二、Appium客户端程序库
1、Appium 客户端 / 服务器架构
由于Appium自身的架构特性,有服务端,自然就有客户端;
主要是指实现了Appium功能的WebDriver协议的客户端程序库,它负责与Appium服务器建立连接,并将测试脚本的指令发送到Appium服务器。客户端程序库
语言 / 框架 | Github 仓库和安装指南 |
---|---|
Ruby | https://github.com/appium/ruby_lib, https://github.com/appium/ruby_lib_core |
Python | https://github.com/appium/python-client |
Java | https://github.com/appium/java-client |
JavaScript (Node.js) | https://github.com/admc/wd |
JavaScript (Node.js) | https://github.com/webdriverio/webdriverio |
JavaScript (Browser) | https://github.com/projectxyzio/web2driver |
Objective C | https://github.com/appium/selenium-objective-c |
PHP | https://github.com/appium/php-client |
C# (.NET) | https://github.com/appium/appium-dotnet-driver |
RobotFramework | https://github.com/jollychang/robotframework-appiumlibrary |
若以使用python为脚本语言为例
- 安装Appium-Python-Client
-
pip install Appium-Python-Client
- 测试脚本引用webdriver
-
from appium import webdriver
会话(Session)
客户端程序库以各自的方式发起与服务器的会话,但最终都会发给服务器一个 POST /session 请求,请求中包含一个被称作「预期能力(Desired Capabilities)」的 JSON 对象。这时服务器就会开启这个自动化会话,并返回一个用于发送后续命令的会话 ID。-
预期能力(Desired Capabilities)
简单来说,就是我们需要测试的手机设备及应用程序配置
Appium Desktop为例:
三、启动测试脚本(以Android为例)
1、启动步骤
- adb连接到手机设备
- 启动Appium服务器
- 配置desired capabilities
- 创建会话session
2、测试脚本配置
subprocess.Popen(
'appium -a 127.0.0.1 -p 4723 --pre-launch --session-override --log appiumlog.txt &' , shell=True)
desired_caps = {}
desired_caps['platformName'] = 'Android' # 设置平台
desired_caps['platformVersion'] = '6.0.1' # 系统版本
desired_caps['deviceName'] = 'emulator-5554' # 设备id
desired_caps['autoLaunch'] = 'true'
desired_caps["noReset"] = 'True'
desired_caps['androidDeviceReadyTimeout'] = '100'
desired_caps['unicodeKeyboard'] = 'True'
desired_caps['resetKeyboard'] = 'True'
desired_caps['appPackage'] = 'com..xzdz' # 包名
desired_caps['appActivity'] = 'main.ui.SplashPageActivity' # 启动的activity
driver = webdriver.Remote('http://localhost:4723/wd/hub', desired_caps)
3、执行用例
成功创建webdriver对象后,就可以开始执行对手机APP的操作了
def first_test(driver):
driver.find_element_by_id('com.xiaozhu.xzdz:id/luDetail_news_total').click()
四、可能遇到的问题(for Mac)
1、JDK版本
Exception in thread "main" java.lang.UnsupportedClassVersionError: com/android/archquery/Main : Unsupported major.minor version 52.0
(1)更新jdk版本至1.8
java -version
java version "1.8.0_171"
Java(TM) SE Runtime Environment (build 1.8.0_171-b11)
Java HotSpot(TM) 64-Bit Server VM (build 25.171-b11, mixed mode)
(2)多个jdk版本时,设置默认的jdk(.bash_profile)
# 设置 jdk1.7
export JAVA_7_HOME=`/usr/libexec/java_home -v 1.7`
# 设置 jdk1.8
export JAVA_8_HOME=`/usr/libexec/java_home -v 1.8`
# 默认 jdk 使用1.8版本
export JAVA_HOME=$JAVA_8_HOME
2、“URLError:10061-由于目标计算机积极拒绝,无法连接”解决方案
(1)检查Appium软件是否已经打开
$ ps -ef | grep 'appium'
501 38556 1 0 11:40上午 ?? 0:03.79 node /usr/local/bin/appium -a 127.0.0.1 -p 4754 --pre-launch --session-override --log appiumlog_54.txt
(2)网络设置中取消勾选已经设置的代理