百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

AirTest-selenium基于Web实现UI自动化测试

ccwgpt 2024-10-14 08:44 23 浏览 0 评论

一、简介:

1、AirtestIDE:跨平台的UI自动化测试编辑器,适用于游戏和App;

2、对于自动化测试新手而言,AirTest是一款可快速上手的UI自动化测试框架;

3、在阅读本文章之前,希望大家可以先去看下官方文档,对于airTest是什么,能做什么,以及怎么使用都有非常清晰的介绍;

4、官方文档链接地址为:http://airtest.netease.com/docs/cn/index.html;



二、要求:

Airtest Project上手很容易,但并非没有门槛,我希望大家能够:

(1)、对自动化测试有一些初步了解,有一些代码基础;

(2)、了解Python基本语法,我的脚本基于Python,如果完全对它不了解的话可能需要预先学习一些Python的语法知识;

(3)、准备一个集成开发环境,可以使用AirtestIDE,这个下载成功后直接运行AirtestIDE.exe即可打开测试脚本编辑页面;

(4)、在详细阅读官方文档前,可提前先阅读官网的5分钟快速上手教程,可对AirTestIDE有大致的了解;

(5)、5分钟教程链接:http://airtest.netease.com/tutorial/Tutorial.html;



三、airTest-selenium对于实现web的UI自动化测试步骤如下:

(1)、启动AirtestIDE编译器:将下载的安装包解压后进入目录,找到如下图所示的AirtestIDE.exe的执行文件,双击即可,以下截图为我本地的安装目录结构图:

(2)、进入的编译器界面如下截图所示:

(3)、在选项->设置中设定chrome path的值,如下截图所示:

(4)、在窗口中选中:Selenium Window,选中后左下栏会展示辅助栏,如下截图所示:

(5)、初次使用airTest-selenium,可先使用录制功能:

开启浏览器并生成初始化代码:点击

start_web 开启浏览器-点击编辑框中弹出的提示,生成初始化代码如下:

from selenium import webdriver

from selenium.webdriver.common.keys import Keys

from airtest_selenium.proxy import WebChrome

driver = WebChrome()

driver.implicitly_wait(20)

(6)、生成访问待测试网址的代码:浏览器中进入待测试的网页-点击辅助窗的start_web

driver.get("http://news.baidu.com")

(7)、开始Airtest-Selenium脚本录制:点击

录制record - 在浏览器进行操作


(8)、结束录制,运行脚本:点击

运行脚本按钮run_button


(9)、运行结束后,点击报告按钮,查看报告

report


(10)、新建文件方法:点击“文件”->新建脚本,可创建一个以.air结尾的文件,可在该文件内编写测试脚本

完成上面这些步骤,相信大家应该对airTest-selenium有了初步的了解,接下来将会详细介绍如何使用AirtestIDE来编写测试脚本。


四、airTest-selenium实现web自动化测试脚本详解:

1、代码内容如下:

2、重点解释说明:

(1)、标记:1中的代码如果使用录制功能,则会自动生成,无需自己编写;

(2)、浏览器窗口的最大化依然可使用python+selenium框架中用到的:

driver.maximize_window()方法来实现;

(3)、标记:2中的代码,对于直接从浏览器中复制而来的xpath路径,粘贴至AirtestIDE编译器中时,会报错,需要使用转义符“\”进行转义;

(4)、标记:3中的代码,测试过程中需要在当前页面重新打开新标签页时,将目标定位到新打开的标签页的实现方法为:driver.switch_to_new_tab();

(5)、标记:4中的代码,测试过程中需要定位的目标元素不在当前所视的页面,需要下拉滚动条才能获取到目标元素信息,该场景的实现方法为:

driver.execute_script("arguments[0].scrollIntoView();", driver.find_element_by_id("buyCy"));其中:

driver.find_element_by_id("buyCy")为目标元素;

(6)、特别介绍:

该方法使用了airtest框架独有的图像识别功能,可根据页面展示的元素按钮,使用该方法对元素进行点击操作;

(7)、其他未重点讲解的代码同python+selenium框架的实现方法,可参考代码片段截图,脚本运行方法和查看测试报告方法同上;

相关推荐

Spring WebFlux vs. Spring MVC(springboot是什么)

背景随着异步I/O和Netty等框架的流行,响应式编程逐渐走入大众的视野。但是,响应式编程本身并不是太新的概念,这个术语最早出现在1985年DavidHarel和AmirPnue...

深度解析微服务高并发:适配SpringMVC框架适配模块及实现原理

适配主流框架如果不借助Sentinel提供的适配主流框架的模块,则在使用Sentinel时需要借助try-catchfinally将要保护的资源(方法或代码块)包起来,在目标方法或代码块执行之前,调...

Spring MVC 底层原理深度解析:从请求到响应的全链路拆解

一、Servlet容器与DispatcherServlet的启动博弈1.Tomcat初始化阶段java//Tomcat初始化流程StandardContext#startInterna...

改造总结之传统SpringMVC架构转换为SpringBoot再到集群

改造出发点,是基于现在服务都在向上云的目标前进,传统SpringMVC难以满足项目持续构建、服务节点任意扩展的需求,所以开始了历史项目的改造。项目改造考虑的主要是兼容以前的业务代码,以及session...

SpringBoot3 整合 Spring MVC 全解析:开启高效 Web 开发之旅

在当今的JavaWeb开发领域,Spring框架家族无疑占据着重要的地位。其中,SpringBoot3和SpringMVC更是开发者们构建强大、高效Web应用的得力工具。今天,...

一文读懂SpringMVC(一文读懂!残疾人低保边缘家庭能领的超实用福利政策)

1.SpringMVC定义1.1.MVC定义Model(模型):是应用程序中用于处理应用程序数据逻辑的部分。通常模型对象负责在数据库中存取数据View(视图):是应用程序中处理数据显示的部分。通常...

69 个Spring mvc 全部注解:真实业务使用案例说明(必须收藏)

SpringMVC框架的注解为Web开发提供了一种简洁而强大的声明式方法。从控制器的定义、请求映射、参数绑定到异常处理和响应构建,这些注解涵盖了Web应用程序开发的各个方面。它们不仅简化了编码工作,...

Spring MVC工作原理:像拼积木一样构建Web应用

SpringMVC工作原理:像拼积木一样构建Web应用在Java的Web开发领域,SpringMVC无疑是一个让人又爱又恨的存在。它像一位神通广大的积木搭建大师,将一个个分散的功能模块巧妙地拼接在...

5千字的SpringMVC总结,我觉得你会需要

思维导图文章已收录到我的Github精选,欢迎Star:https://github.com/yehongzhi/learningSummary概述SpringMVC再熟悉不过的框架了,因为现在最火的...

SpringMVC工作原理与优化指南(springmvc工作原理和工作流程)

SpringMVC工作原理与优化指南在现代Java开发中,SpringMVC无疑是构建Web应用程序的首选框架之一。它以其优雅的设计和强大的功能吸引了无数开发者。那么,SpringMVC究竟是如何工作...

Spring MVC框架源码深度剖析:从入门到精通

SpringMVC框架源码深度剖析:从入门到精通SpringMVC框架简介SpringMVC作为Spring框架的一部分,为构建Web应用程序提供了强大且灵活的支持。它遵循MVC(Model-V...

3000字搞明白SpringMVC工作流程、DispatcherServlet类、拦截器!

SpringMVC基础虽然SpringBoot近几年发展迅猛,但是SpringMVC在Web开发领域仍然占有重要的地位。本章主要讲解SpringMVC的核心:DispatcherServlet类...

多年经验大佬用2000字透彻解析SpringMVC的常用注解及相关示例

SpringMVC注解SpringMVC框架提供了大量的注解,如请求注解、参数注解、响应注解及跨域注解等。这些注解提供了解决HTTP请求的方案。本节主要讲解SpringMVC的常用注解及相关示例...

知乎热议:如何成为前端架构师,赚百万年薪?

作者|慕课网精英讲师双越最近有一条知乎热议:从一个前端工程师,如何根据目标,制定计划,才能快速进阶成为前端架构师?不久之前我参与了一次直播,讲到了自己对于Web前端架构师的理解。架构师这个角色...

学习笔记-前端开发架构设计(前端架构设计方案)

前端开发的技术选项主要包含以下几点,下面对一些名词概念的解释做了笔记:1、分层架构:把功能相似,抽象级别相近的实现进行分层隔离优势:松散耦合(易维护,易复用,易扩展)常见分层方式:MVC,MVVM2、...

取消回复欢迎 发表评论: