airtest web 录制滑块_Airtest之web自动化(一)

Airtest之web自动化(一)

[此文档有许多涉及到gif动图的地方,请全屏观看]

了解Airtest:

简介:

Airtest是由网易团队开发的一款自动化框架,前期运用与游戏测试(通过截图识别),后来又被运用到安卓测试以及web测试。这款自动化框架如此强大的原因来自其团队自己开发的一个图像识别框架,这个框架的祖宗就是一种新颖的图形脚本语言Sikuli。Sikuli这个框架的原理是这样的,计算机用户不需要一行行的去写代码,而是用屏幕截屏的方式,用截出来的图形摆列组合成神器的程序,这是Airtest的一部分。另外,Airtest也基于poco这个UI控件搜索框架,这个框架也是网易自家的跨平台UI测试框架,原理类似于appium,通过控件的名称,id之类的来定位目标控件,然后调用函数方法,例如click(),send_keys()之类的方法来对目标控件进行点击或者是操作。

Airtest展示:

这个动图是Airtest官方文档中截取的,细心的同学可能已经发现:Airtest实现的脚本是python+selenium,刚刚接触到这款框架的时候,我在想这不就是python+selenium的再封装吗,也没有什么新颖的地方。但是细心认真的看,才会发现Airtest强大的之处...

一:Airtest打开浏览器,导入必须的类

在配置好chrome浏览器,以及webdriver之后(此操作很简单),点击AirtestIDE中selenium窗左上方的像地球一样的图标,打开浏览器,然后脚本编辑窗会提示你是否导入必要的模块,点击yes(已经导入了的就点击No)

点击yes后结果:可以看到此处除了导入必要的类以外,还实例化了driver:(driver = WebChrome()),并设置了隐性等待时间:(driver.implicitly_wait(20)),这些都是可以编辑的

start_web按钮:实现driver.get()操作

start_web按钮点击就会生成代码,这样类型的按钮还有许多,他们被称为直接生成代码按钮:(这一类按钮,点击后直接生成代码。不需多余操作,不过部分按钮会根据当前浏览器实际情况生成不同的参数。 对于Firefox,不会在页面上显示检视器,而是直接生成代码)

start_web: 点击该按钮后生成当前浏览器所访问的页面地址的语句。例: driver.get("https://github.com/AirtestProject")

snapshot: 点击该按钮后生成对当前页面进行截图的语句。例: driver.snapshot()

new_tab: 点击该按钮生成一条跳转在最新出现的标签页的语句,一般用在一个生成新的标签页的语句后面。例:driver.switch_to_latest_window()

previous_tab: 点击该按钮生成一条跳转到当前标签页之前的标签页(父标签)的语句。例:driver.switch_to_last_window()

back: 点击该按钮,生成后退到上一个页面的语句。例:driver.back()

forward: 点击该按钮,生成前进到下一个页面的语句。例:driver.forward()

airtest—录制:

如动图所示:点击AirtestIDE中selenium窗中右上角摄像头的图标之后便可以开始录制,在浏览器中的每一步操作都会变为python代码保存在脚本编辑窗中。当然录制也会有些弊端,所以需要酌情使用。弊端:元素定位时不能通过id,name这种简单方式定位,且xpath过长时可能会出现bug(此处可以自己尝试一下),解决方案,所有的元素定位都可以自己写,也可以通过airtest_touch(图像识别点击)跳过元素定位——后面细讲

类似于录制的按钮也还存在许多,这类按钮被称作: Inspect类按钮(这一类按钮点击后,不会直接生成代码;浏览器会进入inspect模式,用户可以在浏览器中选择自己想要操作的元素进行点击,然后编辑框内会生成代码定位到对应元素,并生成对应操作的代码)

Inspect按钮: 点击这个按钮后,选取页面元素,会生成一个定位到该元素的语句。但不会在后面生成对应的操作代码,用户可以自行补充想要执行的selenium语句。例: driver.find_element_by_xpath("//*[@id=\"navbarContent\"]/ul/li[2]/a")还支持其他查找元素的方法*

touch按钮:这个按钮,点击后会生成点击对应元素的代码。例: driver.find_element_by_xpath("//*[@id=\"navbarContent\"]/ul/li[2]/a").click()

text按钮:点击这个按钮,会生成一条在指定元素内输入文本的语句,生成代码后,用户需自行在内部填入需要输入的文本。同时,用户可以定义在输入后执行某个键盘事件,如回车。例: driver.find_element_by_xpath("//input[@placeholder='Search']").send_keys("Airtest Project", Keys.ENTER)

assert按钮:assert按钮在点击后,生成一条assert页面元素是否存在的语句。这是一条Airtest-Selenium封装的语句,在运行时会尝试用参数代表的方法去寻找元素,如果找到会返回True,如果没找到会返回False。可用于测试脚本是否成功的判读。例: driver.assert_exist("//*[@id=\"js-pjax-container\"]/div/header/div/nav/a[2]", "xpath")

Airtest——Airtest_touch

可以避免复杂的元素定位,以及框架的频繁切换的情况

airtest—assert_template(基于图片识别的断言)

上面的两个按钮是Airtest自带的图像识别按钮(这一类按钮,点击后进入截取图像模式,对当前屏幕进行框选区域并截图。)

airtest_touch: 点击该按钮开启截屏模式,对当前屏幕进行截屏,可从浏览器中截取区域图片。表示对截取图片进行点击。例:

1_airtest_touch

assert_template: 点击该按钮后,对当前屏幕截图。表示断言当前浏览器存在该图片。例

1_assert_template

airtest——测试报告:

Airtest脚本运行完成之后会自动生成测试报告,点击IDE上方的LOG页签按钮及可查看,测试报告会将整个脚本的每一个步骤记录下来,最新版本的测试报告与动图展示的样式还有些不一样,但是内容是差不多的:

Airtest其他操作:

Airtest生成的代码是纯python代码,所以还有很多其他操作可以直接用python+selenium实现

上传文件:

1、定位页面上用于上传文件的input元素,其属性应该是type为file(通常为上传文件的那个框或按钮)

2、用driver.find_element_by...定位该元素

3、对该元素进行send_Keys()操作,内容为你要上传的文件

加载用户配置文件:有时候需要绕过验证码,或者用到浏览器中其他配置时使用

1、在浏览器启动代码之前创建ChromeOptions()属性option

2、在option中通过add_argument()方法添加属性‘--user--data--dir’

3、在调用webChrome方法启动浏览器之前,加上chrome_options = option参数加载用户配置文件

4、访问网站,就可以加载本地浏览器已经记录的cookie

代码如下:

option = ChromeOptions()

option.add_argument(‘--user--data--dir = "你的浏览器存储配置文件的路径"’)

driver = WebChrome(chrome_options = option)

附:

附一个之前为了这片介绍而写的一个小脚本:

本来想用这个脚本的实现过程来自己来录制gif讲解的,但是太录制出来的效果不怎么好,也太耗时了,于是就放弃了。

总结一波Airtest的亮点:

1、能够快速定位元素,一键实现许多我们常用的动作(点击,输入,前进,后退,截图...)

2、将selenium关于元素的断言实现了封装

3、可以录制脚本,降低了自动化的难度

4、一键切换窗口,少去了通过句柄切换窗口的烦恼

5、基于图片识别的点击和断言,避免了元素难定位,iframe切换频繁的问题

整个脚本实现过程就在2分钟左右,用Airtest来辅助写自动化脚本的效率真的很高,但是现在的唯一的问题是找不到整套可以预期配合的自动化框架,也难以实现PO设计理念,测试报告对于整个项目来说也是相当冗余的。

但是Airtest录制的脚本是可以在其他python环境中运行,需要我们安装其依赖的两个库:’atrtest‘以及’poco‘,这样的话,上面所讲的缺点还是有办法解决的(下一贴再讲)。

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

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

相关文章

error C2065: 'ULONG_PTR' : undeclared identifier

处理方法: 把#define ULONG_PTR ULONG 加到 stdafx文件 靠前面的位置 原因: Visual C 6.0 开发环境, gdi 的头文件和库文件并没有被包含在环境中, 需要您手工安装 VC6 中没有 ULONG_PTR 类型

重构价格日历

重构价格日历转载于:https://www.cnblogs.com/usual2013blog/p/3728655.html

aliyun centos6 安装mysql_阿里云CentOS6.8安装MySQL5.6

1、使用SSH Secure Shell工具连接阿里云服务器2、使用SSH Secure File Transfer工具上传MySQL压缩包3、解压MySQL压缩包到指定目录(需要在先/usr/local下创建mysql目录)进入压缩文件存放位置,进行解打包:tar -xvf MySQL-5.6.22-1.el6.i686.rpm-bundle.ta…

RegOpenKeyEx 返回值 2

RegOpenKeyEx 返回值 2 x64 系统: 32bit 应用程序调用RegOpenKeyEx (HKEY_LOCAL_MACHINE, "SOFTWARE\\Microsoft", 0, KEY_WOW64_64KEY | KEY_READ, &hKey ); 注意 KEY_WOW64_64KEY 权限值必须使用否则将查找不到指定的路径。

mysql client 未开启_Django+mysqlclient未关闭数据库连接

我使用2个mysql数据库连接。在django中的每个页面请求之后,连接计数(如SHOW STATUS LIKE Conn%所示)每次增加2。在Python 3.4.0django 1.8.2mysqlclient 1.3.6版(Windows和Linux似乎都有这个问题)最初我直接通过MySQLdb访问第二个数据库,但现在我改为使用…

OpenGL中各种坐标系的理解

OPENGL坐标系可分为:世界坐标系和当前绘图坐标系。 世界坐标系:在OpenGL中,世界坐标系是以屏幕中心为原点(0, 0, 0),且是始终不变的。你面对 屏幕,你的右边是x正轴,上面是y正轴,屏幕指向你的为z…

默认手机照相功能

下面是主要代码: - (void) addPicEvent { //先设定sourceType为相机,然后判断相机是否可用(ipod)没相机,不可用将sourceType设定为相片库 UIImagePickerControllerSourceType sourceType UIImagePickerControllerSourceT…

qmake生成vs2013工程文件

qmake -spec win32-msvc2013 -r -tp vc xxx.pro

iOS面试题

今天上午,下午分别面试了两家公司。上午是一家互联网公司,气氛还比较好,是我比较喜欢的。技术这块是直接机试,主要是给了些BUG让我修复,整个过程还算顺利。下午去了一家大型的证券公司。整理技术问题如下: …

Prepar3d.cfg

如果设置为0,打开p3d直接进入默认场景 [USERINTERFACE] SHOW_SCENARIO_WINDOW1

mysql严格模式 报错_mysql严格模式

mysql严格模式严格模式例子1234567DB::table(table_name)->where(status, 1)->select(DB::raw(sum(score) as num,user_id,channel))->groupBy(user_id)->orderBy(num, desc)->limit(10)->get();会报错:Syntax error or access violation: 1055 E…

Android Service 的一些笔记

绑定服务: 用于间接调用服务里面的方法。如果调用者Activity被销毁了,服务也跟着销毁了,服务也会跟着销毁。 开启服务: 不可以调用服务里面的方法。如果调用者的Activity退出了,服务还会长期在后台运行 生命周期 ①单独…

python traceback 丢失_基于python traceback实现异常的获取与处理

这篇文章主要介绍了基于python traceback实现异常的获取与处理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下1、traceback.print_exc()2、traceback.format_exc()3、traceback.print_exception()简单说下这三个…

用Javascript获取页面元素的位置

制作网页的过程中,你有时候需要知道某个元素在网页上的确切位置。 下面的教程总结了Javascript在网页定位方面的相关知识。 一、网页的大小和浏览器窗口的大小 首先,要明确两个基本概念。 一张网页的全部面积,就是它的大小。通常情况下&#…

[Qt] 利用QtWebKit完成JavaScript访问C++对象

http://blog.csdn.net/longsir_area/article/details/42965565 一. 介绍 在浏览器扩展或者WebApp的项目经常用的脚本语言JavaScript有很多局限性,比如,javascript语言不能够夸窗口访问js对象,不能直接读写磁盘文件(这个…

lua cURL使用笔记

cURL cURL是 URL命令行工具, 即 command URL, 可以通过命令行模拟各种应用协议的发包, 包括FTP HTTP HTTPS, 官方网站 http://curl.haxx.se/ luacurl lua curl是基于curl的库libcurl(http://curl.haxx.se/libcurl/&…

mysql三大范式_MySQL学习笔记

1、数据库结构设计1、总-总体流程图2、分-【提取属性】业务分析评价的属性:{用户,课程主标题,内容,综合评分,内容实用,简洁易懂,逻辑分析,发布时间} 问答评论属性:{类型,…

QT webkit 各个类之间关系--QWebView-QWebPag

一、QT webkit简介 1.Qt Qt(发音同 cute)是一个跨平台的C应用程式开发框架,有时又被称为C部件工具箱。Qt被用在KDE桌面环境、Opera、Google Earth、Skype、Adobe Photoshop Album和VirtualBox的开发中。它是挪威Qt Software 的产品&#xff0…

baidu patchrom项目开发详细教程(Being updated)

linux64位android开发环境 baidu patchrom项目开发 by: doswhy [百度云ROM官方项目组修订] by: colinchen 学习修改 ****************************************************************************************************************************************************…

vue 文件转换二进制_在vue中使用axios实现post方式获取二进制流下载文件(实例代码)...

需求点击导出下载表格对应的excel文件在 vue 项目中,使用的 axios ,后台 java 提供的 post 接口 api实现第一步,在 axios 请求中加入参数,表示接收的数据为二进制文件流responseType: "blob"第二步,在拿到数据流之后,把流转为指定文件格式并创建a标签,模拟点击下载,实…