Selenium 自动化测试工具(1) (Selenium 工作原理,常用API的使用)

news2024/11/19 9:27:45

文章目录

  • 什么是自动化测试
  • 什么是测试工具:
  • Selenium 工作原理(重要)
  • Selenium API
    • 定位元素
      • CSS 选择器
      • xpath 定位元素
    • 通过Java代码实现自动化
      • 1. 定位元素
      • 2. 关闭浏览器
      • 3. 获取元素文本
      • 4. 鼠标点击与键盘输入
      • 5. 清空内容
      • 6.打印信息

什么是自动化测试

关于自动化,很好理解,比如,像菜鸟,京东,顺丰等这样的快的公司,在早期时,进行快递的筛选,快递的配送,都是人工进行,而现在随着科技的进步,这些工作就可以使用机器进行代替,效率也能得到了大大的提高,所以自动化测试就是:

将人工要做的测试工作转换成让代码去执行测试,以提高测试效率和测试的质量。

什么是测试工具:

测试工具可以是一个jar包,用的时候,导入这个包,调用方法使用,或者是一个web网站,输入测试数据进行测试,或者是一个exe程序,就例如fiddler工具这样,测试工具是各种各样的,

Selenium 工作原理(重要)

Selenium 是一个主要用于对 Web 程序进行自动化测试的工具, 主要应用于页面当中,模拟用户操作浏览器,实现 UI 自动化测试。它有三大组件,分别是:

在这里插入图片描述

Selenium WebDrive:Selenium WebDrive 提供了很多的API,测试人员通过调用这些接口,来访问浏览器驱动,浏览器驱动再操作浏览器。

Selenium 工作原理:

通过以下例子讲解 Selenium 的工作原理:

比如,我们坐出租车到指定的地方这样的一个例子,这里面就涉及到三个角色:我自己,司机,出租车,如下图:

在这里插入图片描述

Selenium 的工作原理也就是这样的,Selenium 里面也有三个角色:

自动化代码:自动化测试代码发送请求给浏览器驱动(比如Chrome驱动,火狐驱动)

浏览器驱动:它来解析解析自动化测试代码,然后发送给浏览器。

浏览器:执行浏览器驱动发来的指令,最终完成工程师想要的操作。

下面通画图讲解一下 Selenium WebDriver 和 浏览器之间如何通信:

  • 自动化脚本 和 浏览器驱动之间是 C/S 架构(客户端-服务器),两者之间使用的是 HTTP 协议,对于每一条 Selenium 脚本,都会创建一个HTTP请求发送给浏览器驱动。
  • 在浏览器驱动中,包含了一个服务器,用来接收这些http请求
  • 服务器收到请求后,进行解析,发送给浏览器
  • 浏览器执行具体的测试步骤
  • 浏览器执行完之后,将执行结果返回给服务器
  • 服务器又将结果返回给自动化测试代码,如果是错误的http代码,我们就会在控制台看到对应的报错信息

在这里插入图片描述

问题:驱动是同一个,假如是 Chrome 驱动,在客户端使用 Java 或 python 代码,但是为什么可以同时接收 Java 请求和 python请求呢?

这个驱动里面并不是说可以同时接收两种代码,而是支持一种通用的协议,WebDriver 里遵循的一个协议叫作 Json Wire protocol,它们传输的数据格式是 Json 的,可以理解成在HTTP协议之上,再封装了一层这样的公共协议,通过这层协议,就可以解决多种语言。

Selenium API

使用 Selenium API 需要引入依赖:

    <dependencies>
        <!-- https://mvnrepository.com/artifact/org.seleniumhq.selenium/selenium-java -->
        <dependency>
            <groupId>org.seleniumhq.selenium</groupId>
            <artifactId>selenium-java</artifactId>
            <version>3.4.0</version>
        </dependency>
    </dependencies>

定位元素

定位元素常用的主要有以下两种:

CSS 选择器

下面介绍几种常见的选择器

  1. 类选择器:. class值(例如:. s_ipt)

  2. id选择器:# id值 (例如:#s_ipt)

  3. 标签选择器:标签名

  4. 父类选择器 子类选择器:父类选择器表达式 子类选择器表达式(例如:#s_ipt #kw)

xpath 定位元素

xpath 是根据指定路径选择一组元素,指定路径时可以通过 “绝对路径”和“相对路径”两种方式。

绝对路径:以 ‘/’ 开头为绝对路径

通过绝对路径查找比较麻烦,如下图:

场景:寻找 html 标签下的 head 标签下的 meta 标签。

在这里插入图片描述

通过绝对路径的方式就是:html/head/meta,就会比较麻烦,如下图:

在这里插入图片描述

相对路径:以 ’//‘ 开头为相对路路径 (推荐)

场景:通过相对路径查寻找 html 标签下的 head 标签下的 meta 标签。

相对路径://meta,这种方式就比较简单,如下图:

在这里插入图片描述

通过相对路径查找时,又可以分为以下几种方式:

场景:通过相对路径查找 form 标签下面的 input 标签,发现 input 标签有多个,所以,可以通过以下几种方式定位。(注意:这里的索引是以1开始的)

  • 相对路径+索引

    路径://form/input[1]

    在这里插入图片描述

  • 相对路径 + 属性的值

    场景:找到 form 标签下 name 属性等于 ”ie“的 input 标签

    路径://form /input[@name=“ie”]

在这里插入图片描述

  • 相对路径 + 通配符

    找到当前路径下面所有等于 hidden 的标签

    路径:// [@*=“hidden”]*

在这里插入图片描述

  • 相对路径 + 文本匹配

    场景:寻找加载某个标签中的文本,例如下图的 a 标签。

    路径://a[text()=“新闻”]

    在这里插入图片描述

在这里插入图片描述

CSS 选择器和 xpath的区别

CSS 选择器的效率比xpath高,因为,xpath 是通过路径来确定某个元素的,所以有一个路径扫描的开销。

通过Java代码实现自动化

1. 定位元素

场景:通过 Java 代码打开浏览器,定位“百度一下”按钮,如下图:

在这里插入图片描述

代码实现:

 public static void main(String[] args) {
        // 创建浏览器驱动
        WebDriver webDriver = new ChromeDriver();
        // 指定页面
        webDriver.get("https://www.baidu.com");
        //通过 CSS 选择器定位元素
//        WebElement element = webDriver.findElement(By.cssSelector("#su"));
        //通过xpath方式定位元素
        WebElement element = webDriver.findElement(By.xpath("//*[@id=\"su\"]"));
        if(element == null) {
            // 表示当前页面中没有指定的元素
            System.out.println("当前页面没有指定的元素");
        }else {
            System.out.println("测试成功");
        }
    }

在这里插入图片描述

小技巧:

在这里插入图片描述

在这里指定定位元素时,需要按照前端的语法进行写代码,所以,有的同学可能会觉得麻烦,下面交给同学们一个小技巧:

在这里插入图片描述

2. 关闭浏览器

关闭浏览器有两种方式:

  • close()
  • quit()

在这里插入图片描述

在打开浏览器时,也会保存一些 Cookie,使用 quit() 关闭浏览器时,会将浏览器中的 Cooike 也清除掉,而 close() 不会。

3. 获取元素文本

第一种情况:

场景:获取下图中地图按钮上的文本,也就是“地图”文本

在这里插入图片描述

   private static void test6() {
        // 创建浏览器驱动
        WebDriver webDriver = new ChromeDriver();
        // 指定浏览器页面
        webDriver.get("https://www.baidu.com");
        // 定位按钮
        WebElement element = webDriver.findElement(By.cssSelector("#s-top-left > a:nth-child(3)"));
        // 获取文本
        System.out.println(element.getText());
    }

执行结果:

在这里插入图片描述

第二种情况:

场景:获取”百度一下“按钮中的文本

在这里插入图片描述

如果再使用 getText() 方法就不会获取到,如下图:

在这里插入图片描述

原因:

”地图“ 文本是在两个 a 标签中间夹着,所以通过 getText() 可以获取到,这也就说明了 getText() 用于获取到标签中的文本,但是,”百度一下“ 文本是一个属性的值,所以会报错。

在这里插入图片描述

在这里插入图片描述

解决方法:获取属性的值使用 getAttribute()

  private static void test6() {
        // 创建浏览器驱动
        WebDriver webDriver = new ChromeDriver();
        // 指定浏览器页面
        webDriver.get("https://www.baidu.com");
        // 定位按钮
        WebElement element = webDriver.findElement(By.cssSelector("#su"));
        // 获取文本
        System.out.println(element.getAttribute("value"));
    }

在这里插入图片描述

4. 鼠标点击与键盘输入

场景:通过代码在百度的输入框中输入“软件测试”,然后点击百度一下按钮进入新的页面,在新的页面中查找文本为”软件测试“的元素。

在这里插入图片描述

需要使用到的API:

sendkeys(要输入的文本):自动输入文本

click():自动点击选择的按钮

代码实现:

private static void test2() throws InterruptedException {
        // 创建浏览器驱动
        WebDriver webDriver = new ChromeDriver();
        // 指定浏览器页面
        webDriver.get("https://www.baidu.com");
        // 定位输入框
        WebElement importInput = webDriver.findElement(By.cssSelector("#kw"));
        // 输入文本
        importInput.sendKeys("软件测试");
        // 定位按钮
        WebElement clickButton = webDriver.findElement(By.cssSelector("#su"));
        // 进行点击
        clickButton.click();
        // 获取搜索到的页面中指定的所有元素
        // 因为元素不止一个,所以使用findElements
        // 进行一个睡眠,等待页面加载出来在寻找元素
        sleep(3000);
        List<WebElement> elements = webDriver.findElements(By.cssSelector("a em"));
        sleep(3000);
        //遍历list
        for(int i = 0; i < elements.size(); i++) {
            if(elements.get(i).getText().equals("软件测试")) {
                //如果元素是“软件测试”则表示测试成功,否则测试失败
                System.out.println("测试成功");
            }else{
                System.out.println("测试失败");
            }
        }
    }

submit() 与 click() 的区别

click() 是点击,submit() 都是提交,而submit() 是提交form标签,submit 操作的元素需要放在 form 标签中,如果不是 form 标签,使用 submit() 进行提交后,在返回时就会报错。而 click() 就没有任何限制。

5. 清空内容

场景:清空输入框中的元素

    private static void test3() {
        // 创建浏览器驱动
        WebDriver webDriver = new ChromeDriver();
        // 指定浏览器页面
        webDriver.get("https://www.baidu.com");
        // 定位输入框
        WebElement importInput = webDriver.findElement(By.cssSelector("#kw"));
        // 输入文本
        importInput.sendKeys("软件测试");
        //清空输入框中内容
        importInput.clear();
    }

6.打印信息

  1. 打印 title

    在这里插入图片描述

    代码实现:

    private static void test7() {
            // 创建浏览器驱动
            WebDriver webDriver = new ChromeDriver();
            // 指定浏览器页面
            webDriver.get("https://www.baidu.com/");
            // 获取页面的title
            String title = webDriver.getTitle();
            System.out.println("当前页面的title:" + title);
            // 关闭浏览器
            webDriver.quit();
        }
    

    执行结果:

    在这里插入图片描述

  2. 获取当前页面的 URL

    getCurrentUrl()

在这里插入图片描述

代码实现:

private static void test8() {
        // 创建浏览器驱动
        WebDriver webDriver = new ChromeDriver();
        // 指定浏览器页面
        webDriver.get("https://www.baidu.com/");
        //获取当前页面的url
        String currentUrl = webDriver.getCurrentUrl();
        //判断当前页面的url与指定跳转的页面的url是否相同
        if(currentUrl.equals("https://www.baidu.com/")) {
            System.out.println("测试通过,当前页面url:" + currentUrl);
        }else {
            System.out.println("测试不通过");
        }
        webDriver.quit();
    }

在这里插入图片描述

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

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

相关文章

11.3G全国矢量地名路网SHP地图

我们在《2015年中国电子地图数据》一文中&#xff0c;分享了一份26.8G的全矢量地名路网地图。 这里再分享一份11.3G的全国矢量地名路网地图&#xff0c;这份数据虽然比2015版更小&#xff0c;但它比那一版更新。 值得一提的是这份数据的图层更丰富&#xff0c;比2015版多32个…

于ThinkPHP开发的赛事报名小程序

基于ThinkPHP开发的赛事报名微信小程序 功能包括 1、参赛公告 2、会员中心&#xff08;会员注册、登录、成绩查询、资料管理、参赛记录管理&#xff09; 3、个人报名和企业报名 &#xff08;身份证验证防止重复报名&#xff09; 4、培训报名 5、查询是否在库人员&#xff0c;根…

收藏:六款好用的企业防泄密软件推荐

企业数据如同企业的生命线&#xff0c;保护数据安全免遭泄露变得至关重要。 面对日益复杂的网络安全威胁&#xff0c;一套高效的企业防泄密软件成为企业安全架构的基石。 以下是精心挑选的六款企业防泄密软件&#xff0c;它们在数据加密、访问控制、行为监控等方面表现出色&am…

Java开发-特殊文本文件,日志技术

目录 01.特殊文件,日志技术概述 02.特殊文件:Properties属性文件 ​编辑Properties案例 特殊文件:XML文件 XML的作用和应用场景 读取XML文件中的数据 XML的生成 约束XML文件的编写[了解] 日志技术 日志技术的体系 ​编辑 ​编辑 Logback日志框架的概述 Logback快…

JS 中怎么删除数组元素?有哪几种方法?

正文开始之前推荐一位宝藏博主免费分享的学习教程,学起来! 编号学习链接1Cesium: 保姆级教程+源码示例2openlayers: 保姆级教程+源码示例3Leaflet: 保姆级教程+源码示例4MapboxGL: 保姆级教程+源码示例splice() JavaScript中的splice()方法是一个内置的数组对象函数, 用于…

VM虚拟机共享文件夹fuse: bad mount point `/mnt/hgfs‘: No such file or directory

报错显示挂载点 /mnt/hgfs 不存在&#xff0c;你需要先创建这个目录。可以按照以下步骤进行操作&#xff1a; 创建挂载点目录&#xff1a; sudo mkdir -p /mnt/hgfs 手动挂载共享文件夹&#xff1a; sudo vmhgfs-fuse .host:/ /mnt/hgfs -o allow_other 确保每次启动时自动…

FFMPEG+ANativeWinodow渲染播放视频

前言 学习音视频开发&#xff0c;入门基本都得学FFMPEG&#xff0c;按照目前互联网上流传的学习路线&#xff0c;FFMPEGANativeWinodow渲染播放视频属于是第一关卡的Boss&#xff0c;简单但是关键。这几天写了个简单的demo&#xff0c;可以比较稳定进行渲染播放&#xff0c;便…

重庆耶非凡科技选品师项目大揭秘:成功背后的故事与经验

在电商行业迅猛发展的今天&#xff0c;选品师这一职业愈发受到市场的关注。重庆耶非凡科技有限公司凭借其专业的选品团队和科学的选品方法&#xff0c;成为众多商家关注的焦点。那么&#xff0c;该公司的选品师项目是否真的有成功的案例呢?接下来&#xff0c;我们将从多个角度…

备受推崇的公司文件加密文件推荐榜单

迄今为止&#xff0c;加密依然是最有效的用于保护数据、通讯安全的手段之一 在数字化时代&#xff0c;文件加密软件成为了保护个人和企业数据安全的重要工具。随着技术的不断进步&#xff0c;市场上涌现出了众多优秀的文件加密软件。 以下十款文件加密软件因其出色的性能、易…

STM32-12-OLED模块

STM32-01-认识单片机 STM32-02-基础知识 STM32-03-HAL库 STM32-04-时钟树 STM32-05-SYSTEM文件夹 STM32-06-GPIO STM32-07-外部中断 STM32-08-串口 STM32-09-IWDG和WWDG STM32-10-定时器 STM32-11-电容触摸按键 文章目录 1. OLED显示屏介绍2. OLED驱动原理3. OLED驱动芯片简介4…

企业电脑加密系统是如何发展的,今天最可靠的电脑加密系统是什么

企业电脑加密系统历经了几十年的发展&#xff0c;如今技术已经逐渐成熟&#xff0c;加密强度和防泄密效果越来越显著&#xff0c;那么它是怎么发展的&#xff0c;以及当今使用的加密技术是什么呢&#xff1f; 一、发展历程 1.早期探索阶段&#xff1a; 时间&#xff1a;上世纪…

python基础-数据结构-leetcode刷题必看-queue---队列-python的底层构建

文章目录 队列双端队列 deque底层存储deque接口1. __init__(self, iterable: Iterable[_T], maxlen: int | None None) -> None2. append(self, __x: _T) -> None3. appendleft(self, __x: _T) -> None4. copy(self) -> Self5. count(self, __x: _T) -> int6. …

增强团队建设和创造力的 6 个敏捷游戏

加入敏捷框架提供了对资源的访问和支持&#xff0c;可以帮助你的组织最大限度地发挥敏捷的优势。它还提供了一个与其他敏捷从业者联系的平台&#xff0c;以共享最佳实践并相互学习。 实践敏捷工作方法可以让团队按照自己的节奏&#xff0c;尽可能多地发挥创造力来追求目标&…

【408精华知识】关于存储系统,看这一篇就够了!

关于存储系统&#xff0c;其实是一个很完整的逻辑&#xff0c;在学完基础知识后&#xff0c;我们可以试着将整个存储系统的转化逻辑画下来&#xff0c;更形象化地去理解整个存储系统&#xff0c;如下图&#xff1a; 文章目录 &#xff08;一&#xff09;虚-->实&#xff08;…

Python面向对象学习笔记

Python面向对象编程 记录人&#xff1a; 李思成 时间&#xff1a; 2024/05/01至2024/05/23 课程来源&#xff1a; B站Python面向对象 1.面向对象编程概述 官方概述 程序是指令的集合&#xff0c;运行程序时&#xff0c;程序中的语句会变成一条或多条指令&#xff0c;然后…

算法练习——字符串

一确定字符串是否包含唯一字符 1.1涉及知识点 c的输入输出语法 cin>>s; cout<<"NO"; 如何定义字符串 切记&#xff1a;在[]中必须加数字——字符串最大长度&#xff0c;不然编译不通过 char s[101]; 如何获取字符串长度 char s[101];cin>>s;i…

Lua的几个特殊用法

&#xff1a;/.的区别 详细可以参考https://zhuanlan.zhihu.com/p/651619116。最重要的不同就是传递默认参数self。 通过.调用函数&#xff0c;传递self实例 通过 &#xff1a; 调用函数&#xff0c;传递self (不需要显示的传递self参数&#xff0c;默认就会传递&#xff0c;但…

STM32FLASH闪存

文章目录 前言首先来回顾一下存储器映像FLASH简介闪存模块组织Flash基本结构&#xff08;关系&#xff09;图Flash解锁使用指针访问存储器FLASH操作Flash全擦除Flash页擦除Flash写入 选项字节选项字节操作选项字节擦除选项字节写入 器件电子签名注意闪存控制寄存器一览 前言 本…

Bentham Science药学全文期刊库文献在家轻松下载

今天讲一个药学期刊库——Bentham Science药学全文期刊数据库 Bentham Science出版公司&#xff0c;作为全球范围内主要的制药、医疗、生物医学及化学出版商之一&#xff0c;出版期刊质量在全球享有广泛赞誉&#xff0c;其中有54种期刊被ISI收录&#xff0c;43%被PubMed收录&a…

Vue3 图片或视频下载跨域或文件损坏的解决方法

Vue3 图片或视频下载跨域或文件损坏的解决方法 修改跨域配置文件下载方法 修改跨域配置文件 修改vite.config.ts文件proxy里面写跨域地址&#xff0c;如下图&#xff0c;图片地址就是我们要跨域的目标地址&#xff1a; 下载方法 如下就是我取消上面那句后的报错 然后调用两…