4.1 等待函数癈使用

4.1.1 为什么要使用等待函数

我们在做自动化的时候很多时候都不是很顺利,不是因为app的问题,我们的脚本也没问题,但是很多时候都会报错,比如一个页面本来就有id为1的这个元素,可是我无论怎么定位他都没办法操作,然后报错,这个是怎么个情况呢?因为当我们app打开一个页面的时候我们的appium的运行速度过快那么可能害没有将页面的资源解析完成然后你就去操作了,这样能行吗?肯定不行的,这样不报错谁错呢?所以在很多的时候我们都需要加载等待时间的。那什么时候为每个页面都加载等待时间呢?

4.1.2 什么时候用等待函数

自动化的目的是高效,如果你每个页面都去添加等待时间那么执行下来的效率是不是大大降低了?在加载等待时间时我们需要根据自己的判断去增加,比如一些页面资源较多加载慢了那你肯定需要加的。是不是都是这样呢?其实不是的,下面介绍几种不同类型的等待。

4.2 强制等待

4.2.1 什么是强制等待

故名思义就是你必须给我等,有点耍流氓的意思。比如:我进入到登陆页面,刚好有一个强制等待的函数,那么结果就是无论页面的资源加载完没有你都得给我等着。

4.2.2 强制等待使用

import time
time.sleep(10) #单位秒

备注:调试程序的时候这样写写就好,千万别在实际项目中多用。因为这个time的等待是线程的死等,就是无论如何都会执行这一条语句,如果你在实际项目中去运行那么你会发现效率会很慢。所以实际项目不推荐

4.2.3 强制等待封装

#!/usr/bin/env python
# -*- codinfg:utf-8 -*-
'''
@author: Jeff LEE
@file: 等待函数.py
@time: 2018-07-30 11:08
@desc:
'''
import time
from appium import webdriver
import os def Case(platformName, platformVersion, deviceName, app, appPackage, appActivity):
PATH = lambda p: os.path.abspath(os.path.join(os.path.dirname(__file__), p))
# print getConfig("baseconf", "platformName")
desired_caps = {}
desired_caps['platformName'] = platformName # 设置平台
desired_caps['platformVersion'] = platformVersion # 系统版本
desired_caps['deviceName'] = deviceName # 设备id
# desired_caps['autoLaunch'] = 'true' # 是否自动启动
# desired_caps['noReset'] = 'true'
# desired_caps['newCommandTimeout'] = 20
# desired_caps['app'] = PATH(app) # 安装包路径,放在该py文件的目录下)
desired_caps['appPackage'] = appPackage # 包名
desired_caps['appActivity'] = appActivity # 启动的activity
driver = webdriver.Remote('http://localhost:4723/wd/hub', desired_caps)
waitFor(5) # 等待函数
def waitFor(t):
time.sleep(t)

4.3 隐式等待

4.3.1 什么是隐式等待

driver.implicitly_wait(10) #单位秒

  隐式等待,顾名思义看不见,也可理解为智能等待,从上面函数可以看出,这个等待函数是webdriver提供的一个等待函数,它是针对我们整个driver的。也就是说你只要是用driver去操作一个对象,或者一个元素,当你找不到这个元素或者对象的时候他就会自动的去等待你设置的这个超时时间,如果在超时时间内还没有找到,程序才会报错。

4.3.2 隐式等待封装

#!/usr/bin/env python
# -*- codinfg:utf-8 -*-
'''
@author: Jeff LEE
@file: 等待函数.py
@time: 2018-07-30 11:08
@desc:
'''
import time
from appium import webdriver
import os def Case(platformName, platformVersion, deviceName, app, appPackage, appActivity):
PATH = lambda p: os.path.abspath(os.path.join(os.path.dirname(__file__), p))
# print getConfig("baseconf", "platformName")
desired_caps = {}
desired_caps['platformName'] = platformName # 设置平台
desired_caps['platformVersion'] = platformVersion # 系统版本
desired_caps['deviceName'] = deviceName # 设备id
# desired_caps['autoLaunch'] = 'true' # 是否自动启动
# desired_caps['noReset'] = 'true'
# desired_caps['newCommandTimeout'] = 20
# desired_caps['app'] = PATH(app) # 安装包路径,放在该py文件的目录下)
desired_caps['appPackage'] = appPackage # 包名
desired_caps['appActivity'] = appActivity # 启动的activity
driver = webdriver.Remote('http://localhost:4723/wd/hub', desired_caps)
waitFor(5) return driver # 等待函数
def waitFor(t):
time.sleep(t) # 隐式等待
def implicit_for_wait(t):
driver = Case(platformName, platformVersion, deviceName, app, appPackage, appActivity)
driver.implicitly_wait(t)

4.4 显示等待

4.4.1 什么是显示等待

WebDriverWait(driver, timeout, poll_frequency=0.5, ignored_exceptions=None)

  

首先我们来弄明白这个方法里面几个参数的含义:

1、driver:是我们操作的driver。

2、timeout:超时时间,也就是我们找这个元素要找多久

3、poll_frequency:间隔时间,怎么理解?就是说在超时时间内每多少秒去查询一次,默认情况是0.5秒一次

4、ignored_exceptions:异常,就是没有找到程序抛出什么异常。在默认情况是跑出:NoSuchElementException

4.4.2 显示等待封装

#!/usr/bin/env python
# -*- codinfg:utf-8 -*-
'''
@author: Jeff LEE
@file: 等待函数.py
@time: 2018-07-30 11:08
@desc:
'''
import time
import os from appium import webdriver
from selenium.webdriver.support.ui import WebDriverWait def Case(platformName, platformVersion, deviceName, app, appPackage, appActivity):
PATH = lambda p: os.path.abspath(os.path.join(os.path.dirname(__file__), p))
# print getConfig("baseconf", "platformName")
desired_caps = {}
desired_caps['platformName'] = platformName # 设置平台
desired_caps['platformVersion'] = platformVersion # 系统版本
desired_caps['deviceName'] = deviceName # 设备id
# desired_caps['autoLaunch'] = 'true' # 是否自动启动
# desired_caps['noReset'] = 'true'
# desired_caps['newCommandTimeout'] = 20
# desired_caps['app'] = PATH(app) # 安装包路径,放在该py文件的目录下)
desired_caps['appPackage'] = appPackage # 包名
desired_caps['appActivity'] = appActivity # 启动的activity
driver = webdriver.Remote('http://localhost:4723/wd/hub', desired_caps)
waitFor(5) return driver # 等待函数
def waitFor(t):
time.sleep(t) # 隐式等待
def implicit_for_wait(t):
driver = Case(platformName, platformVersion, deviceName, app, appPackage, appActivity)
driver.implicitly_wait(t) #显示等待
def wait(t):
driver = Case(platformName,platformVersion,deviceName,app,appPackage,appActivity)
WebDriverWait(driver, 10,5).until(lambda driver:driver.find_element_by_id("XXXX"))

  

Appium+python自动化4-等待函数的更多相关文章

  1. Appium+python自动化8-Appium Python API

    Appium+python自动化8-AppiumPython API   前言: Appium Python API全集,不知道哪个大神整理的,这里贴出来分享给大家. 1.contexts conte ...

  2. appium+python自动化61-中文输入乱码问题解决

    前言 在夜神模拟器上输入中文,发现是乱码,将unicodeKeyboard和resetKeyboard参数设置为True了,发现还是没法解决. 打开手机设置语言和输入法,发现找不到Appium And ...

  3. appium+python自动化52-多点触控MultiAction

    前言 MultiAction是针对多点触控操作的,是TouchAction的一个补充模块 TouchAction用法参考前面的一篇:appium+python自动化33-TouchAction 多点触 ...

  4. Appium+python自动化20-查看iOS上app元素属性

    前言 学UI自动化首先就是定位页面元素,玩过android版的appium小伙伴应该都知道,appium的windows版自带的Inspector可以定位app上的元素 Mac版的appium1.6的 ...

  5. Appium+python自动化19-iOS模拟器(iOS Simulator)安装自家APP

    前言 做过iOS上app测试的小伙伴应该都知道,普通用户安装app都是从appstore下载安装,安装测试版本的app,一般就是开发给的二维码扫码安装, 或者开发给个.ipa的安装包文件,通过itoo ...

  6. appium+python自动化50-生成定位对象模板templet(jinja2)

    前言 每次自己写pageobject定位元素对象太繁琐,格式都差不多,只是换个定位方法,这种就可以才有模板的方式,批量生成pageobject定位元素对象的模板 python里面生成模板有两个模块可以 ...

  7. Appium+python自动化20-查看iOS上app元素属性【转载】

    前言 学UI自动化首先就是定位页面元素,玩过android版的appium小伙伴应该都知道,appium的windows版自带的Inspector可以定位app上的元素Mac版的appium1.6的版 ...

  8. Appium+python自动化19-iOS模拟器(iOS Simulator)安装自家APP【转载】

    前言 做过iOS上app测试的小伙伴应该都知道,普通用户安装app都是从appstore下载安装,安装测试版本的app,一般就是开发给的二维码扫码安装, 或者开发给个.ipa的安装包文件,通过itoo ...

  9. Appium+python自动化

    名称 链接地址 Appium+python自动化8-Appium Python API(上) http://mp.weixin.qq.com/s/WvpT5oRrYY22avI95FuypQ Appi ...

随机推荐

  1. 让linux每天定时备份MySQL数据库并删除五天前的备份文件

    MYSQL定期备份是一项重要的工作,但人工操作太繁琐,也难避免有所疏漏,使用下面的方法即可让系统定期备份数据.利用系统crontab来定时执行备份文件,按日期对备份结果进行保存,达到备份的目的. 1. ...

  2. 深度学习原理与框架-Tensorflow基本操作-变量常用操作 1.tf.random_normal(生成正态分布随机数) 2.tf.random_shuffle(进行洗牌操作) 3. tf.assign(赋值操作) 4.tf.convert_to_tensor(转换为tensor类型) 5.tf.add(相加操作) tf.divide(相乘操作) 6.tf.placeholder(输入数据占位

    1. 使用tf.random_normal([2, 3], mean=-1, stddev=4) 创建一个正态分布的随机数 参数说明:[2, 3]表示随机数的维度,mean表示平均值,stddev表示 ...

  3. 【JEECG技术文档】Online唯一校验使用说明

    1.功能介绍 配置了唯一校验的字段,在录入和编辑页面中,动态查询用户输入值是否存在校验. 要使用online唯一校验功能必须先在online表单开发中配置唯一字段的校验方式为唯一校验. 2.配置唯一校 ...

  4. Linux zookeeper 单机安装

    Zookeeper(端口2181) 下载地址 http://mirror.bit.edu.cn/apache/zookeeper/ 解压到/usr/local目录 >tar -zxvf zook ...

  5. 2018.3,GC可控了

    如题,不再像以前那样由系统决定什么时候进行GC,现在可以通过设置,决定自己手动回收还是使用传统的系统决定方式. 传统方式不可控,就算是手动调用了GC.COLLECT,系统也不一定会立即执行.

  6. 一个seq_file的小问题

    在修改一个内核模块的时候,我们使用seq_file来打印我们的数据,结果非常出人意料. static void flowinfo_seq_printf_stats(struct seq_file *s ...

  7. LeetCode OJ 15. 3Sum

    题目 Given an array S of n integers, are there elements a, b, c in S such that a + b + c = 0? Find all ...

  8. Android DevArt6:Android中IPC的六种方式

    Android中IPC的六种方式 1.使用Bundle 最简单的进程间通信方式:Intent + Bundle: 支持三大组件:Activity.Service.BroadcastReceiver : ...

  9. week05 06绑定滚动条 去抖动

    像这种小代码 为了满足某种需求 可以直接上网搜 这些都是JS代码和react无关 我们下拉 就会触发事件从而调用loading more news 那个函数 react要求我们加个key key就是唯 ...

  10. Hibernate 再接触 ID生成策略

    Xml 方法 在student.hbm.xml中 <generator class="uuid"></generator> 取值如下 1.identity: ...