目录
1.Appium设计
2.Appium环境安装
1.JDK安装配置
2.SDK安装
3.Appium desktop安装(appium server+appium inspector工具)
3.DesiredCapability(启动参数)设置
4.Appium定位方法(appium中无css selector定位)
1.id定位
2.accessibility_id定位
3.class定位
4.xpath定位
5.AndroidUIAutomator定位
5.元素的常用操作
6.TouchAction类
7.显式等待与隐式等待
1.WebDriverWait显示等待
2.implicitlyWait隐式等待
8.toast定位
Client/Server模式,客户端通过WebDriver json wire协议与服务通信,server端是由nodejs开发的http服务,可安装在任何地方,包括远程服务器;appium通过appium-xcuitest-driver来测试iOS设备(需要安装facebook的WDA(webdriver agent)来驱动测试).
WebDriver json wire协议:
webdriver是基于http协议的,第一次连接appium服务的时候会建立一个session会话,并通过post请求发送一个json告知服务端相关的测试信息.
客户端会传递 Desired Capabilities 给 Appium Server 创建一个会话,Appium Server 会调用 appium-uiautomator2-driver 同时将 UiAutomator2 Server 的两个 apk 安装到测试设备上.
1).安装JDK(1.8版本)
2).配置环境变量
a).JAVA_HOME jdk的安装路径;
b).classpath .;%JAVA_HOME%\lib\dt.jar;%JAVA_HOME%\lib\tools.jar;
c).path %JAVA_HOME%\bin;%JAVA_HOME%\jre\bin;
3).javac -version检查是否安装成功.
1).下载SDK后解压
2).配置Android SDK环境变量
a).ANDROID_HOME SDK的安装路径
b).path %ANDROID_HOME%\tools;%ANDROID_HOME%\platform-tools
3).adb回车检查是否安装成功.
1).下载对应系统的安装包 https://github.com/appium/appium-desktop/releases
2).如果不需要appium inspector,可直接通过npm安装appium
npm install -g cnpm --registry=https://registry.npm.taobao.org
cnpm install -g appium
3).运行appium appium
adb shell getprop ro.build.version.release 获取终端安卓系统版本
adb shell pm list packages 获取包名
appPackage app包名
appActivity activity名
查看appPackage和appActivity名:
adb logcat | grep ActivityManager
adb logcat | grep -i displayed
adb shell dumpsys activity activities | grep mFocusedActivity
automationName android默认使用uiautomator2,iOS默认使用XCUITest
noRest/fullReset 是否重置环境
unicodeKeyBoard/resetKeyBoard 输入中文/测试完成后重置输入法
dontStopAppOnReset 首次启动后不停止app(调试脚本时使用)
skipDeviceInitialization 跳过安装及权限设置等操作
By.id("resoure-id属性值")
By.AccessibilityId("content-desc属性值")
By.className("class属性值")
相对路径定位: "//*[@属性名='属性值']"----->"//*[@text='text的属性值']"
多属性精准定位: "//*[@text='text的属性值' and @resource-id='id属性值']"
androidDriver.findElementsByAndroidUIAutomator("new UiSelector().text("河南")");
实现滚动查找元素:"new UiScrollable(
new UiSelector().scrollable(true).instance(0)
).scrollIntoView(
new UiSelector().text('待查找的文本').instance(0)
)"
点击方法 element.click()
清除方法 element.clear()
输入方法 element.senKeys("text")
设置元素的值 element.setValue("text")
获取属性值 element.getAttribute("属性名")
是否可见 element.displayed() 返回true/false
是否可用 element.enabled() 返回true/false
是否被选中 element.isS elected() 返回true/false
获取元素文本 element.text
获取元素坐标 element.location
获取元素尺寸 element.size
TouchAction可用事件
press 手势按下
release 手势抬起,释放
moveTo 移动
tap 点击,轻敲
wait 等待
longPress 长按
cancel 取消
perform 执行
页面加载流程:
title出现-->
dom树出现(presence还不完整)-->
css出现(可见visibility)-->
js出现,js特效执行(可点击clickable)
html是自上而下加载,js文件加载会阻塞html内容的加载,有些使用js异步加载的方式来完成js加载 ;css样式表下载完成后会跟之前的样式表一起进行解析,会对之前的元素重新渲染.
显示等待针对当个元素控件,有些等待较长时间的元素用显示等待,如果用隐式等待,
比如等待20s,则全局的元素在定位报错时都要等待20s才会抛出异常,所以用显示等待.
显示等待需要与ExpectedConditions条件连用
wait=new WebDriverWait(driver,10,500)
wait.until(ExpectedConditions.visibilityOfElementLocated(by)).click();
尽量脚本中都加上,时间设置3~6s,为所有查找元素操作设置缓冲.
driver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
appium使用uiautomator底层机制来分析抓取toast,并把toast放到控件树中,但toast本身并不属于控件.
toast必须使用xpath定位
//*[@class='android.widget.Toast']