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. MonGoDB 在linux 上的安装和配置

    01: 下载 linux 版本的二进制包 => https://www.mongodb.com/ 02: 解压  => tar -zxf mongodb-linux-x86_64-3.4. ...

  2. sonar自定义规则

    Sonar并不是简单地把不同的代码检查工具结果(例如 FindBugs,PMD 等)直接显示在 Web 页面上,而是通过不同的插件对这些结果进行再加工处理,通过量化的方式度量代码质量的变化,从而可以方 ...

  3. Ajax技术剖析

    Ajax的全称是Asynchronous JavaScript and XML,是JS的特有功能,它作用是异步JS数据交互,即在不进行页面刷新的情况下进行部分数据的获取,性能较高.值得注意的是,仅有A ...

  4. Emac

    https://emacs-china.org/ 启动 console模式的emacs,$emacs -nw 学习参考: 1)<21天精通emacs> 2)Emacs常用命令简集. 3)& ...

  5. ETC2 区别于ETC的重要点

    ETC2 主要是对于NPOT却是4的倍数的贴图有较大压缩,比如一个1920X1080RGB的Loading图,ETC4压缩下不管用,大小5.9M,ETC2下压缩为1M

  6. HTML实现页面自动跳转的五种方法

    下面列了五个例子来详细说明,这几个例子的主要功能是:在5秒后,自动跳转到同目录下的hello.html(根据自己需要自行修改)文件. 1)html的实现 复制代码 代码如下: <head> ...

  7. delphi 原创应用工具箱

    用到的主要知识点: (1) listview背景透明 (2) 读取应用图标 (3)图标透明 (4)实时显示微软必应首页图,裁剪图片等

  8. 关于在VS2008和VS2010中禁用及卸载Visual Assist X的方法研究——转载

    禁用和启用   此方法对于VS2008和VS2010 都适用. 在VS2008或VS2010菜单栏中选择“VassistX”选项卡,找到“Enable/Disable Visual Assist X” ...

  9. Kubernetes 本地仓库

    1.Kubernetes本地私有仓库 Docker仓库主要用于存放Docker镜像,Docker仓库分为公共仓库和私有仓库,基于registry可以搭建本地私有仓库.使用私有仓库有如下优点: 1)节省 ...

  10. 局部变量and全局变量

    局部变量 <1>什么是局部变量 如下图所示: <2>小总结 局部变量,就是在函数内部定义的变量 不同的函数,可以定义相同的名字的局部变量,但是各用个的不会产生影响 局部变量的作 ...