Airtest1.2.7新增断言API介绍

1. 前言

1.2.7版本的Airtest中,一个很重要的功能是 新增了非常丰富的断言API ,今天我们就来详细看一下Airtest都给我们提供了哪些断言语句。

2. 旧版Airtest提供的断言语句

先回顾下,旧版Airtest一直以来,都只给我们提供了2种断言语句,一种是断言目标存在/不存在当前页面:

assert_exists
assert_not_exists
另一种是断言2个值相等/不相等:

assert_equal
assert_not_equal
1)断言目标存在/不存在当前画面

assert_exists(Template(r"tpl1665570124249.png", record_pos=(0.118, -0.026), resolution=(720, 1440)), "请填写测试点")assert_not_exists(Template(r"tpl1665570165989.png", record_pos=(0.118, -0.032), resolution=(720, 1440)), "请填写测试点")

图片

2)断言2个值相等/不相等

assert_equal(poco("score").get_text(), "100", "分数为100分")assert_not_equal(poco("score").get_text(), "0", "分数不为0")

图片

3. 新版Airtest新增的断言语句

而Airtest1.2.7版本,又给我们新增了14个断言的API,包含断言表达式为True或者False(bool)、断言表达式为空/不为空、断言2个值的大小情况等:

1)断言表达式为True/False(bool)

from airtest.core.assertions import *# 断言表达式为True
assert_true(1==1, msg="assert 1==1")# 断言表达式为False
assert_false(1==2, msg="assert 1!=2")

2)断言2个对象相同/不相同

from airtest.core.assertions import *# 断言2个对象相同
assert_is(1, 1, msg="assert 1 is 1")# 断言2个对象不相同
assert_is_not(1, 2, msg="assert 1 is not 2")

3)断言表达式为None/不为None

from airtest.core.assertions import *# 断言表达式为None
assert_is_none(None, msg="assert None is None")# 断言表达式不为None
assert_is_not_none(1, msg="assert 1 is not None")

4)断言第一个参数是否在第二个参数中(包含关系)

from airtest.core.assertions import *# 断言第一个参数在第二个参数中
assert_in(1, [1, 2], msg="assert 1 in [1, 2]")# 断言第一个参数不在第二个参数中
assert_not_in(3, [1, 2], msg="assert 3 not in [1, 2]")

5)断言对象是不是某种类型的实例

from airtest.core.assertions import *# 断言对象是某种类型的实例
assert_is_instance(1, int, msg="assert 1 is int")# 断言对象不是某种类型的实例
assert_not_is_instance(1, str, msg="assert 1 is not str")

这个断言语句中,第一个参数为obj,是一个具体的对象实例,第二个参数为cls,是一种类型,我们可以用这个断言来判断某个实例是不是属于某种类型的。

不过这个断言,在AirtestIDE中执行会报一个错误,我们会在下个版本修复这个问题:

TypeError: can't pickle mappingproxy objects

6)断言第一个值大于/大于等于第二个值

from airtest.core.assertions import *# 断言第一个值大于第二个值
assert_greater(2, 1, msg="assert 2 > 1")# 断言第一个值大于等于第二个值
assert_greater_equal(1, 1, msg="assert 1 >= 1")
7)断言第一个值小于/小于等于第二个值
from airtest.core.assertions import *# 断言第一个值小于第二个值
assert_less(1, 2, msg="assert 1 < 2")# 断言第一个值小于等于第二个值
assert_less_equal(1, 1, msg="assert 1 <= 1")

4. 拓展:Airtest断言的msg参数说明

可以看到,所有Airtest的断言语句中,都包含msg参数,这个参数是为了方便我们给当前的断言语句增加一个说明,并且该说明会显示在Airtest报告,断言步骤的描述上:

图片

5. 拓展:Airtest断言的snapshot参数说明

从Airtest1.2.7版本起,断言还新增了一个snapshot的参数,为了支持同学们在设置断言时,还能附带截取当前画面的图片,然后显示在Airtest报告中。

当然如果我们不需要断言截图的话,也可以设置关闭断言的截图:

# 默认情况下,断言截图会开启
assert_is_not_none("1", msg="assert '1' is not None")# 如不需要断言时截取当前画面,则可以设置关闭断言的截图
assert_is_not_none("1", msg="assert '1' is not None",snapshot=False)

图片

图片

1)assert_exists关闭截图的特殊说明

比较特别的是,assert_exists 默认也是带截图的,但是要设置这个步骤不截图,不能使用 snapshot=False 来设置,而是要通过Airtest的全局设置来控制:

ST.SAVE_IMAGE = Falseassert_exists(Template(r"tpl1665719197992.png", "请填写测试点"))

assert_not_exists 也是同理。如果给assert_exists强行传入snapshot=False,则会报错:

TypeError: assert_exists() got an unexpected keyword argument 'snapshot'

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

在这里插入图片描述

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你! 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/110462.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【论文笔记】Perception, Planning, Control, and Coordination for Autonomous Vehicles

单纯作为阅读笔记&#xff0c;文章内容可能有些混乱。 文章目录 1. Introduction2. Perception3. Planning3.1. Autonomous Vehicle Planning Systems3.2. Mission Planning3.3. Behavioral Planning3.4. Motion Planning3.4.1. Combinatorial Planning3.4.2. Sampling-Based P…

C++的异常类型与多级catch匹配

try-catch 的用法: try{// 可能抛出异常的语句 }catch(exceptionType variable){// 处理异常的语句 } 我们还遗留下一个问题,就是 catch 关键字后边的exceptionType variable,这节就来详细分析一下。exceptionType是异常类型,它指明了当前的 catch 可以处理什么类型的异常…

进程,线程,并发相关入门

进程与线程的简单理解 进程是一个独立的执行单元&#xff0c;它拥有自己的内存空间、文件句柄和系统资源.进程是操作系统层面的,每个应用运行就是一个进程.进程之间通常是隔离的&#xff0c;它们不能直接访问对方的内存空间&#xff0c;必须通过进程间通信&#xff08;IPC&…

Docker实战技巧(一):Kubernetes基础操作实战

Kubernetes定位在Saas层,重点解决了微服务大规模部署时的服务编排问题 1、关闭防火墙并设置开机禁用   systemctl stop firewalld   systemctl disable firewalld 2、配置repo   cd /etc/yum.repos.d/   下载Docker repo   wget https://mirrors.aliyun.com/docker-…

【CMU15-445 Part-10】Sorting and Aggregations

Part10-Sorting and Aggregations Part10-Sorting & Aggregations Query Plan 查询计划指的是指令或者是数据库系统如何执行一个给定查询的方式。整个查询计划是树形结构或者有向无环图。 Logical Plan&#xff1a;先SCAN A&#xff0c;交给join operator&#xff0c;SC…

教育领域数据可视化:点亮知识之路

教育领域一直以来都在不断进步和演变&#xff0c;而数据可视化技术正在为这一领域带来一场革命。在过去的几年里&#xff0c;教育者们越来越意识到&#xff0c;通过将教育数据转化为可视化图表和图形&#xff0c;可以更好地理解学生的表现、需求和趋势&#xff0c;从而提供更好…

开源项目-SeaTunnel-UI数据集成系统

哈喽,大家好,今天给大家带来一个开源项目-SeaTunnel-UI数据集成系统 系统主要有任务配置,任务实例,数据源,虚拟表,用户管理等功能 登录 数据源 mysql数据源配置参数说明 kafka参数配置 mysqlcdc配置参数说明 虚拟表

无涯教程-JavaScript - IFS函数

描述 IFS函数检查是否满足一个或多个条件,并返回与第一个TRUE条件相对应的值。此功能已在Excel 2016中添加。 语法 IFS (logical_test1, value_if_true1, [logical_test2, value_if_true2], [logical_test3, value_if_true3]…) 争论 Argument描述Required/Optionallogical…

【C++】深拷贝和浅拷贝 ② ( 默认拷贝构造函数是浅拷贝 | 代码示例 - 浅拷贝造成的问题 )

文章目录 一、默认拷贝构造函数是浅拷贝1、默认拷贝构造函数2、默认拷贝构造函数是浅拷贝机制 二、代码示例 - 浅拷贝造成的问题 一、默认拷贝构造函数是浅拷贝 1、默认拷贝构造函数 如果 C 类中 没有定义拷贝构造函数 , C 编译器会自动为该类提供一个 " 默认的拷贝构造函…

前端-layui动态渲染表格行列与复杂表头合并

说在前面&#xff1a; 最近一直在用layui处理表格 写的有些代码感觉还挺有用的&#xff0c;顺便记录下来方便以后查看使用&#xff1b; HTML处代码 拿到id 渲染位置表格 <div class"layui-table-body salaryTable"><table class"layui-table" i…

Java大文件分片上传(minio版),超详细

本文使用spring boot 结合minio文件服务做的大文件分片上传&#xff0c;思路&#xff1a;①&#xff1a;初始化文件调用后端接口&#xff0c;后端再调用minio把文件分片成几份&#xff0c;生成每个分片的minio上传url②&#xff1a;把提起分片好的文件依次调用上一把返回的url …

C语言是否快被时代所淘汰?

今日话题&#xff0c;C语言是否快被时代所淘汰&#xff1f;在移动互联网的冲击下&#xff0c;windows做的人越来越少&#xff0c;WP阵营没人做&#xff0c;后台简单的php&#xff0c;复杂的大数据处理的java&#xff0c;要求性能的c。主流一二线公司基本上没多少用C#的了。其实…