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 zookeeper 单机安装

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

  2. hive基础操作

    hive --version  查看hive的版本 hive -S -e "set" | grep auto  ##在shell下可以查找属性的状态.小技巧.

  3. VB-创建类模块DLL文件

    最近需要调用MSCOMM32.OCX控件,但是ABAP调用过程中发现无法同时发送多条记录,则需调整实现方式: a.创建DLL文件封装MSCOMM控件相关属性及方法 b.系统注册DLL文件 c.ABAP ...

  4. ReactiveX 学习笔记(17)使用 RxSwift + Alamofire 调用 REST API

    JSON : Placeholder JSON : Placeholder (https://jsonplaceholder.typicode.com/) 是一个用于测试的 REST API 网站. ...

  5. k8s的Deployment 滚动升级

    首先定义一个Deployment,并创建它 apiVersion: apps/v1beta1 kind: Deployment metadata: name: house-live spec: rep ...

  6. JQuery+Ajax实现唯一性验证、正则

    //唯一性验证 public function Only(){ //实例化模型层 $model = new User(); $res = $model->Only(); echo $res; } ...

  7. (转)JS之——解决IE6、7、8使用JSON.stringify报JSON未定义错误的问题

    https://blog.csdn.net/l1028386804/article/details/53439755 在通过JavaScript将对象类型的参数通过JSON.stringify转换成字 ...

  8. C# 如何获取屏幕的截图,以及如何在图像上添加文字

    关键代码为 Screen sc = Screen.PrimaryScreen; Rectangle rct = sc.Bounds; Image img = new Bitmap(rct.Width, ...

  9. python模拟线性回归的点

    构造符合线性回归的数据点 import numpy as np import tensorflow as tf import matplotlib.pyplot as plt # 随机生成1000个点 ...

  10. opencv对手写数字进行无黏连切割

    //src:待分割的二值图,最大值为255 //segMat:分割好的每个图片 //算法:判断连通域,有几个连通域就会分割成几个子图片 //用途:手写数字识别中进行无黏连数字的分割 void getC ...