1.等待

1.1精确等待

sleep 不推荐

    @Test
public void testWait1() throws InterruptedException{
day_time();
Thread.sleep(10000);
day_time();
WebElement e1 = driver.findElementById("com.xueqiu.android:id/user_profile_icon");
System.out.println(e1.getTagName()+"\t"+e1.getLocation());
e1.click();
}


## 1.2全局隐式等待
一段时间内,会不断的查看当前页面是否有某个控件。存在就返回;否则就一直寻找,直到超时。默认值是0,即不等待
```#java
driver.manager().timeouts().implicitlyWait(10,TimeUnit.SECONDS);
```
```#java
@Test
public void testWait2(){
driver.manage().timeouts().implicitlyWait(20,TimeUnit.SECONDS);
day_time();
driver.findElementById("com.xueqiu.android:id/user_profile_icon").click();
day_time();
}
```

问题:隐式等待设置无效,没有继续寻找

1.3显式等待,针对单个元素

    WebDriverWait wait = new WebDriverWait(driver,10);
WebElement element = wait.until(ExpectedConditions.elementToBe(By.id("someid"));</font>
    @Test
public void testWait3(){
WebDriverWait wait = new WebDriverWait(driver,10);
day_time();
WebElement e3 = wait.until(ExpectedConditions.presenceOfElementLocated( By.id("com.xueqiu.android:id/user_profile_icon")));
day_time();
System.out.println(e3.getTagName()+"\t"+e3.getLocation());
e3.click();
}


# 2.log
```#java
driver.manage().logs().getAvailableLogTypes();
driver.manage().logs().get("logcat").getAll().toString()
```
```#java
public void testLog()throws InterruptedException {
Thread.sleep(8000);
driver.rotate(ScreenOrientation.LANDSCAPE);
System.out.println(driver.manage().logs().getAvailableLogTypes());
}
```

    public void testLog()throws InterruptedException {
Thread.sleep(8000);
driver.rotate(ScreenOrientation.LANDSCAPE);
System.out.println(driver.manage().logs().get("logcat").getAll().toString());
}


```#java
public void testLog()throws InterruptedException {
Thread.sleep(8000);
driver.rotate(ScreenOrientation.LANDSCAPE);
for(Object l:driver.manage().logs().get("logcat").getAll().toArray()){
System.out.println(l);
}
}
```

# 3.手机性能数据
python目前不支持
```#java
public void testPerformace() throws Exception{
System.out.println(driver.getPerformanceData("com.xueqiu.android", "cpuinfo", 10));
WebDriverWait wait = new WebDriverWait(driver,10);
WebElement e3 = wait.until(ExpectedConditions.presenceOfElementLocated(By.id("com.xueqiu.android:id/user_profile_icon")));
System.out.println(driver.getSupportedPerformanceDataTypes());

    System.out.println(driver.getPerformanceData("com.xueqiu.android", "memoryinfo", 10));
System.out.println(driver.getPerformanceData("com.xueqiu.android", "batteryinfo", 10));
System.out.println(driver.getPerformanceData("com.xueqiu.android", "networkinfo", 10));
Thread.sleep(3000);
}
<img src="https://img2018.cnblogs.com/blog/1418970/201810/1418970-20181010101234618-100093198.png" width="600" />

#    4.xpath
appium定位只支持3种,id,accessibility id,xpath。其中uiautomator2 accessibility id只针对content description。如果开发对与id的赋值不固定或简陋,每个包的id不一样,accessibility id也不一定存在。此时xpath就相当重要。
## 4.1.绝对定位不推荐
<font color=458B00>/xxx/ddd/dddd</font>
## 4.2.相对定位
* //* 获取所有控件
* //*[contains(@resource-id,'login')]
* //*[@text='登陆']
* //*[contains(@text,'登陆') and contains(@resource-id), 'login']
* //*[contains(@text, '登陆') or contains(@label,'登陆')] 获取text为登陆的控件
* //*[contains(@text, '看点')]/ancestor::*//*[contains(name(),'EditText')] 从看点的父类下面去寻找classname为EditText的控件
* //*[clickable="true"]//android.widget.TextView[string-length(@text)>0 and string-length(@text)<20] 所有元素下类名为android.widget.TextView且text长度在0-20之间的控件 ## 4.3Android和iOS的属性对应,待补充 |android|ios|
----------|----------
tag class|tag
resourceId|null
content-desc|null
text|label ## 4.4.xpath定位验证
* 使用appium的inspector进行查找
* 将pagesource复制到https://www.freeformatter.com/xpath-tester.html/#ad-output网址去查找 # 5.webdriver 协议与手工模拟
## 5.1 .webdriver协议基础知识
## 5.2.session_id获取
* session_id=`curl http://127.0.0.1:4723/wd/hub/sessions|awk -F \" '{print $8}'` ## 5.3.element id获取
curl -X POST http://127.0.0.1:4723/wd/hub/session/$session_id/elements --data-binary '{"using":"xpath","value":"//*[@class=\"android.widget.Toast\"]"}' -H "Content-Type:application/json;charset=UTF-8"
* 元素属性获取
curl http://127.0.0.1:4723/wd/hub/session/${session_id}/element/${element-id}/attribute/text
* 元素动作
curl -X POST http://127.0.0.1:4723/wd/hub/session/${session_id}/element/${$element_id}/click # FAQ
## 1.如1.2全局隐式等待中代码,运行无效果,没有持续查找元素
## 2.执行System.out.println(driver.getPerformanceData("com.xueqiu.android", "cpuinfo", 10))时,appium报错如下
<img src="https://img2018.cnblogs.com/blog/1418970/201810/1418970-20181010095358396-1532949485.png" width="600" />
原因:1.应用信息更新不及 2.执行命令时该应用已停止
<img src="https://img2018.cnblogs.com/blog/1418970/201810/1418970-20181010095953538-270790384.png" width="600" />
解决:将cpuinfo方法提前或增加等待时间防止应用被杀死 ## 3.全局隐私等待无效果

appium 3-4-1034等待、日志、性能数据、xpath定位、web driver协议的更多相关文章

  1. 通过ngx-lua来统计Nginx上的虚拟主机性能数据

    Web server调研分析 Filed under: Web Server — cmpan @ 2012-10-29 20:38:34 摘要 简单可依赖的架构首先需要有一个简单可依赖的前端WebSe ...

  2. 手把手教你用Python抓取AWS的日志(CloudTrail)数据

    数据时代,利用数据做决策是大数据的核心价值. 本文手把手,教你使用python进行AWS的CloudTrail配置,进行日志抓取.进行数据分析,发现数据价值! 如今是云的时代,许多公司都把自己的IT架 ...

  3. 解说mysql之binlog日志以及利用binlog日志恢复数据

    众所周知,binlog日志对于mysql数据库来说是十分重要的.在数据丢失的紧急情况下,我们往往会想到用binlog日志功能进行数据恢复(定时全备份+binlog日志恢复增量数据部分),化险为夷! 废 ...

  4. Java日志性能

    在任何系统中,日志都是非常重要的组成部分,它是反映系统运行情况的重要依据,也是排查问题时的必要线索.绝大多数人都认可日志的重要性,但是又有多少人仔细想过该怎么打日志,日志对性能的影响究竟有多大呢?今天 ...

  5. Performance Monitor采集性能数据

    Performance Monitor采集性能数据 Windows本身为我们提供了很多好用的性能分析工具,大家日常都使用过资源管理器,在里面能即时直观的看到CPU占用率.物理内存使用量等信息.此外新系 ...

  6. Java日志性能那些事(转)

    在任何系统中,日志都是非常重要的组成部分,它是反映系统运行情况的重要依据,也是排查问题时的必要线索.绝大多数人都认可日志的重要性,但是又有多少人仔细想过该怎么打日志,日志对性能的影响究竟有多大呢?今天 ...

  7. Mysql之binlog日志说明及利用binlog日志恢复数据操作记录

    众所周知,binlog日志对于mysql数据库来说是十分重要的.在数据丢失的紧急情况下,我们往往会想到用binlog日志功能进行数据恢复(定时全备份+binlog日志恢复增量数据部分),化险为夷! 一 ...

  8. 使用Jyhon脚本和PMI模块监控WAS性能数据

    使用Jyhon脚本和PMI模块监控WAS性能数据的优点有: 1.可以使用非交互的方式远程获取数据 2.不需要图形化模块支持 3.对各种was版本的兼容性较高 4.使用方便,官方自带 缺点也有很多: 1 ...

  9. mod_php和mod_fastcgi和php-fpm的介绍,对比和性能数据

    1.php中fastcgi和php-fpm是什么东西 最近在研究和学习php的性能方面的知识,看到了factcgi以及php-fpm,发现我对他们是少之又少的理解,可以说几乎是一无所知,想想还是蛮可怕 ...

随机推荐

  1. L1-037 A除以B

    真的是简单题哈 —— 给定两个绝对值不超过100的整数A和B,要求你按照“A/B=商”的格式输出结果. 输入格式: 输入在第一行给出两个整数A和B(−100≤A,B≤100),数字间以空格分隔. 输出 ...

  2. MyEclipse WebSphere开发教程:安装和更新WebSphere 6.1, JAX-WS, EJB 3.0(七)

    [周年庆]MyEclipse个人授权 折扣低至冰点!立即开抢>> [MyEclipse最新版下载] MyEclipse支持Java EE技术(如JAX-WS和EJB 3.0),它们以功能包 ...

  3. SaltStack自动化运维工具

    一.SaltStack的了解 SaltStack管理工具允许管理员对多个操作系统创建一个一致的管理系统,包括VMware vSphere环境. SaltStack作用于仆从和主拓扑.SaltStack ...

  4. Java中的容器和注入分析

    为什么会出现容器的注入? 容器:顾名思义,装东西的器物. 至于spring中bean,aop,ioc等一些都只是实现的方式:具体容器哪些值得我们借鉴,我个人觉得是封装的思想.将你一个独立的系统功能放到 ...

  5. Xcode清理垃圾

    摘抄自https://blog.csdn.net/hu434587115/article/details/54602449 ~/Library/Developer/Xcode/DerivedData/ ...

  6. Flume-NG源码阅读之SpoolDirectorySource(原创)

    org.apache.flume.source.SpoolDirectorySource是flume的一个常用的source,这个源支持从磁盘中某文件夹获取文件数据.不同于其他异步源,这个源能够避免重 ...

  7. linux-performance

    1. top 2. cat /proc/meminfo nvidia@tegra-ubuntu:~/zrj/laneseg_TRT$ cat /proc/meminfo MemTotal: kB Me ...

  8. 文件的存储GridFS

    1.存储路径--->可以理解就是存储路径,然后在通过路径来获取文件 将文件放在本地路径(网络路径)下,然后数据库中存储该文件的查找路径 db.log.insert({filename:" ...

  9. jboss 5.1 启动问题解决

    在安装好后启动时可能遇到这样的情况: ERROR [AbstractKernelController] Error installing to Instantiated: name=Attachmen ...

  10. ArrayList和LinkedList插入删除效率的测试(完全不在一个数量级8/20)

    通过index获取元素的值 java里面的链表可以添加索引,而C中的链表,是没有索引的 package ArrayListVSLinkedList; import java.util.ArrayLis ...