Appium使用

作者: 沈宥 | 来源:发表于2020-09-03 11:51 被阅读0次

一、启动Appium服务器

1、Appium Desktop启动
  • Appium Desktop的作用
    简单来说,Appium Desktop其实是Appium服务器的图形界面,使用后就不需要使用Node / NPM来安装Appium。可以用来启动/停止服务器,使用检查器查看应用程序的元素,查看日志。

  • 根据系统下载release版本https://github.com/appium/appium-desktop/releases

    Screen Shot 2020-09-03 at 10.19.26 AM.png
  • 安装使用
    默认启动的server端口号为4723,可手动修改;使用Advanced也可配置更多服务器标志

    1.png
  • 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为例:

    1.png

三、启动测试脚本(以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)网络设置中取消勾选已经设置的代理

相关文章

网友评论

    本文标题:Appium使用

    本文链接:https://www.haomeiwen.com/subject/bglnsktx.html