测试——Selenium

news2025/1/16 19:12:48

内容大纲:

什么是自动化测试

什么是Selenium

Selenium工作原理

Selenium环境搭建

Selenium API

目录

1. 什么是自动化测试

2. 什么是Selenium

3. Selenium工作原理

4. Selenium环境搭建(java)

5. Selenium API

5.1 定位元素 

5.1.1 CSS选择器定位元素

5.1.2 XPath定位元素

5.1.3 标签定位元素

5.2 操作测试对象 

5.3 添加等待

5.3.1 强制等待sleep

5.3.2 隐式等待(更推荐)

5.3.3 显示等待

5.4 打印信息

5.4.1 打印title

5.4.2 打印url

5.5 浏览器的操作

5.5.1  浏览器最大化

5.5.2 设置浏览器的宽高

5.5.3 操作浏览器的前进、后退

5.5.4 控制浏览器滚动条

5.6 键盘事件

5.6.1 回车

5.6.2 组合 (A+C+V)

5.7 鼠标事件(右击)

5.8 窗口

5.9 截图

6. 几个小案例

6.1 定位一组元素

6.2 窗口定位

6.3 下拉框处理

6.4 定位弹窗

6.5 上传文件


1. 什么是自动化测试

将人工要做的测试工作进行转换,让代码去执行测试工作,这样是为了提高测试效率,提高测试产品的质量

2. 什么是Selenium

做UI自动化测试的一个工具

3. Selenium工作原理

 

三个角色:

  • 自动化脚本代码(在idea里面写的代码)
  • 驱动:有个这个驱动就可以对页面进行操作
  • 浏览器

4. Selenium环境搭建(java)

在此不详细说明......

引入的依赖:

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

 

 

 

5. Selenium API

5.1 定位元素 

5.1.1 CSS选择器定位元素

  • 类选择器: .class值(.s_ipt)
  • id选择器: #id值(#kw)
  • 父类选择器 子类选择器: 父类选择器表达式 子类选择器表达式(#s_kw_wrap #kw)
  • 标签选择器:标签名(form)

举例说明:

 

 ③


 

5.1.2 XPath定位元素

  • 相对路径+索引://form/span[1]/input
  • 相对路径+属性值://input[@class="s_ipt"]
  • 相对路径+通配符://*[@*="s_ipt"]
  • 相对路径+文本匹配://span[text()=""]

举例说明:

 

 


5.1.3 标签定位元素

 

问:CSS选择器和XPath选择器,,哪个效率更高?

CSS 


5.2 操作测试对象 

  • click点击对象

  • send_keys 在对象上模拟按键输入
  • clear 清楚对象输入的文本内容
  • submit 提交
  • text用于获取元素的文本信息 

getText和getAttribute: 

getText'获取的元素在:

getAttribute获取的元素是一个属性值:

问:submit和click之间的区别:

submit操作的元素需要放在form标签中,否则会报错

click没有这个限制(更推荐)

此时submit报错


5.3 添加等待

5.3.1 强制等待sleep

 

5.3.2 隐式等待(更推荐)

 

5.3.3 显示等待

 


5.4 打印信息

5.4.1 打印title

 

5.4.2 打印url

 

 


5.5 浏览器的操作

5.5.1  浏览器最大化

 

5.5.2 设置浏览器的宽高

 

5.5.3 操作浏览器的前进、后退

 

5.5.4 控制浏览器滚动条

 


5.6 键盘事件

5.6.1 回车

5.6.2 组合 (A+C+V)


5.7 鼠标事件(右击)


5.8 窗口

当前的窗口:

获取所有窗口:

切换窗口:

 


5.9 截图

引入依赖:

        <!-- https://mvnrepository.com/artifact/commons-io/commons-io -->
         <dependency>
            <groupId>commons-io</groupId>
            <artifactId>commons-io</artifactId>
            <version>2.15.1</version>
        </dependency>

 

6. 几个小案例

6.1 定位一组元素

描述:

 让矩形框的都勾上

private static void Page01(){
        WebDriver webDriver = new ChromeDriver();
        webDriver.get("http://localhost:63342/0720-test/Page/test01.html?_ijt=g2mlnu74s9004ua0282u8h05lg&_ij_reload=RELOAD_ON_SAVE");
        List<WebElement> webElements = webDriver.findElements(By.cssSelector("input"));
        for (int i = 0; i < webElements.size(); i++){
            if (webElements.get(i).getAttribute("type").equals("checkbox")){
                webElements.get(i).click();
            }
        }
}

6.2 窗口定位

描述:

点击click

private static void Page02() throws InterruptedException {
        WebDriver webDriver = new ChromeDriver();
        webDriver.get("http://localhost:63342/0720-test/Page/test02.html?_ijt=csarghoqcdtbu2pd8sdrhhka8v&_ij_reload=RELOAD_ON_SAVE");

        webDriver.switchTo().frame("f1");
        sleep(3000);
        webDriver.findElement(By.cssSelector("body > div > div > a")).click();
}

6.3 下拉框处理

描述:

选择其它

private static void Page03() throws InterruptedException {
        WebDriver webDriver = new ChromeDriver();
        //打开目标网页
        webDriver.get("http://localhost:63342/0720-test/Page/test03.html?_ijt=j61coa63ol45u8trp3tr5rjirr&_ij_reload=RELOAD_ON_SAVE");
        /**
         * 方法一:借助Select对象
         */
        WebElement webElement = webDriver.findElement(By.cssSelector("#ShippingMethod"));
        sleep(3000);
        Select select = new Select(webElement);
        //通过序号选中选项,下标从0开始
        //select.selectByIndex(3);
        //sleep(3000);

        /**
         * 方法二:通过值
         */
        select.selectByValue("8.34");

}

6.4 定位弹窗

描述:

输入:某某.点击确认

 

private static void Page04() throws InterruptedException {
        WebDriver webDriver = new ChromeDriver();
        webDriver.get("http://localhost:63342/0720-test/Page/test04.html?_ijt=hfa18g211latukccpp96p1gl28&_ij_reload=RELOAD_ON_SAVE");
        sleep(3000);
        webDriver.findElement(By.cssSelector("body > button")).click();
        sleep(3000);
        //点击了弹窗里面的取消
        webDriver.switchTo().alert().dismiss();
        //点中弹窗
        webDriver.findElement(By.cssSelector("body > button")).click();
        String name = "momo";
        //输入某某
        webDriver.switchTo().alert().sendKeys("momo");
        sleep(3000);
        //弹窗确认
        webDriver.switchTo().alert().accept();
        //校验
        String text = webDriver.findElement(By.cssSelector("body > div:nth-child(5)")).getText();
        if (text.equals(name)){
            System.out.println("测试通过");
        }else {
            System.out.println("测试不通过");
        }
}

6.5 上传文件

描述:

选择文件之后:

private static void Page05() throws InterruptedException {
        WebDriver webDriver = new ChromeDriver();
        webDriver.get("http://localhost:63342/0720-test/Page/test05.html?_ijt=c69p92i1r4598lea74dko8r147&_ij_reload=RELOAD_ON_SAVE");
        sleep(3000);
        //上传文件
        webDriver.findElement(By.cssSelector("body > input[type=file]")).sendKeys("C:\\Users\\27695\\Desktop\\bit\\3.MySQL\\01 MySQL安装与配置.pdf");

}

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

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

相关文章

arr的谜思

arr到底是个啥&#xff1f; 在C语言中&#xff0c;arr 本身不是一个指针&#xff0c;而是一个数组名。然而&#xff0c;在大多数表达式中&#xff0c;数组名会被转换为指向数组首元素的指针。这种转换是自动的&#xff0c;并且是C语言的一个基本特性。 具体来说&#xff0c;当…

LDR6020快充线,科技与便捷的新宠

在快节奏的现代生活中&#xff0c;充电效率成为了我们不可忽视的一个重要因素。随着智能手机、平板电脑等电子设备的普及&#xff0c;快充线以其独特的优势逐渐成为充电设备市场的新宠。 快充线&#xff0c;相比于传统的普通充电线&#xff0c;快充线在充电速度上有着显著的提升…

Linux用户-sudo命令

作者介绍&#xff1a;简历上没有一个精通的运维工程师。希望大家多多关注我&#xff0c;我尽量把自己会的都分享给大家&#xff0c;下面的思维导图也是预计更新的内容和当前进度(不定时更新)。 Linux是一个多用户多任务操作系统,这意味着它可以同时支持多个用户登录并使用系统。…

明日周刊-第19期

演唱会现场的感受确实跟耳机里的感觉非常不一样&#xff0c;听见音响和人声真真切切出现在你身边&#xff0c;那种震撼可以让你暂时忘却生活的烦恼。感谢8月3日的蔡健雅演唱会&#xff0c;凑巧的是这一场是今年巡演的最后一场。 文章目录 资源分享言论歌曲推荐 资源分享 nginx…

DC-8靶机通关

今天我们来学习DC-8这个靶机&#xff01;&#xff01;&#xff01; 1.实验环境 攻击机&#xff1a;kali2023.2 靶机&#xff1a;DC-8 2.1主机扫描 2.2端口扫描 还是熟悉的配方&#xff01;&#xff01;&#xff01; 3.1查看网页 其实可以先尝试一下爆破&#xff0c;但是爆…

在VScode中导入conda环境的记录【原创】

今天在vscode编辑器中运行一个python代码&#xff0c;发现终端可以运行&#xff0c;但是编辑器中点击Run会显示缺包&#xff0c;但是python包明明是有的&#xff0c;在自己的conda环境中。后来发现&#xff0c;是vscode没有发现我自己创建的conda环境&#xff0c;在vscode中导入…

暑假第三周——学生管理系统仿写

iOS学习 前言账号界面主页添加学生信息&#xff1a;修改学生信息&#xff1a;删除学生信息&#xff1a;学生信息排序&#xff1a;查找学生信息 总结 前言 学生管理系统的仿写较为简单&#xff0c;与c语言的学生管理系统逻辑上相差不大。 账号界面 账号界面与3G share的相同&am…

推荐几款卓越的 .NET 开源搜索组件

目录 前言 一、Lucene.NET 1、介绍 2、地址 二、Elasticsearch.NET 和 NEST 1、介绍 2、文档地址 3、开源地址 三、Algolia.Search 1、介绍 2、文档地址 3、开源地址 四、SolrNet 1、介绍 2、文档开源地址 3、Solr社区 五、Masuit.LuceneEFCore.SearchEngine …

网页设计师必备!10个免费的设计素材网站推荐

当网页设计师使用网页设计材料时&#xff0c;他们会优先考虑那些免费和高质量的网页设计材料网站。找到一个免费和高质量的网页设计材料网站并不容易&#xff0c;有些网站要么需要打开材料网站成员&#xff0c;要么设计材料质量很差。即时设计总结了10个免费的网页设计材料网站…

iAppv3无白银会员使用SDK

前言 一个实用小技巧分享给大家。 工具 iapp&#xff1a;百度或点我获取 Mt管理器&#xff1a;百度或点我获取 教程 1.移出“项目路径/apk/lib/”内的全部文件 2.在iapp内测试打包&#xff0c;打包完成后直接返回&#xff0c;不要安装 3.在mt管理器里面点击“项目路径/b…

常见CMS漏洞(WordPress、DeDeCMS、ASPCMS、PHPMyadmin、Pageadmin)

目录 一&#xff1a;WordPress 步骤一:进入Vulhub靶场并执行以下命令开启靶场;在浏览器中访问并安装好子... 步骤二:思路是修改其WP的模板写入一句话木马后门并访问其文件即可GetShel;登陆WP后点击【外观】--》【编辑】 --》 404.php 步骤三:访问以下连接即可获取WebShel...…

【Linux】wsl win安装Linux环境

文章目录 wsl是什么配置wsl启用适用于 Linux 的 Windows 子系统安装 Linux 分发版 文件互操作参考文章 win 下安装linux其实很简单&#xff0c;百度一下wsl就明白了 wsl是什么 WSL&#xff08;Windows Subsystem for Linux&#xff09;是微软开发的一项技术&#xff0c;允许用…

七、分散加载说明

分散加载说明以GD32F103ZE为例&#xff0c;分别用Keil、IAR和Embedded Builder工具实现&#xff1a;将函数放置某个地址、将常量放置某个地址、将函数放在RAM中运行的三种效果。 1、将led_toggle()函数放在0x08040000地址后。 2、将tempbuf[1024]常量放在0x08020000地址后。 …

React管理系统整合Cesium避坑指南

花费了一周时间将React 升级到了最新版本18&#xff0c;同时整合Cesium三维模块到系统中&#xff0c;其中遇到了react 版本升级后模块删改&#xff0c;按照原来的引入方式无法使用的问题&#xff0c;以及Cesium 放入子路由一直404等问题 文章目录 一、系统版本依赖二、系统预览…

3.10.全卷积网络FCN

全连接卷积神经网络&#xff08;FCN&#xff09; ​ FCN是用来深度网络来做语义分割的奠基性工作&#xff0c;用转置卷积层来替换CNN最后的全连接层&#xff0c;从而可以实现对每个像素的预测 ​ CNN(卷积神经网络)可以认为是一个预训练好的模型。CNN的最后一层是全局平均池化…

【C++学习第19天】最小生成树(对应无向图)

一、最小生成树 二、代码 1、Prim算法 #include <cstring> #include <iostream> #include <algorithm>using namespace std;const int N 510, INF 0x3f3f3f3f;int n, m; int g[N][N]; int dist[N]; bool st[N];int prim() {memset(dist, 0x3f, sizeof di…

十大机器学习算法-学习笔记-章节1-线性回归—

一、前言 学习视频&#xff1a;第一章&#xff1a;线性回归原理推导 1-回归问题概述_哔哩哔哩_bilibili 相关资料 该内容仅作为个人笔记使用&#xff0c;希望看到的各位能有所获&#xff0c;博主有误的地方&#xff0c;各位可以在评论区有所指正 二、正文 1、线性回归 什…

CTF-web基础 web服务器

web服务器作用 web服务器是一个服务器软件&#xff0c;我们可以把静态网页部署到web服务器上&#xff0c;web‘服务器通常只能运行静态网页。 应用服务器可以运行动态网页&#xff0c;web服务器通常和应用服务器一起使用。 原理 当我们输入网页时&#xff0c;他会发送请求到…

2024小学生古诗文大会暑期备考:吃透历年真题和知识点(持续)

最近有一些家长朋友问好真题网&#xff0c;上海三年级以上的小学生有什么比较有价值的比赛可以参加&#xff1f;结合众多孩子的反馈和参与情况&#xff0c;好真题网体检参加上海市汉字小达人比赛活动、上海市小学生古诗文大会、AMC8美国数学竞赛等&#xff0c;主要针对的是语文…

使用Python创建多功能文件管理器

简介 在本文中&#xff0c;我们将探索一个使用Python的wxPython库开发的文件管理器应用程序。这个应用程序不仅能够浏览和选择文件&#xff0c;还支持文件预览、压缩、图片转换以及生成PPT演示文稿的功能。 C:\pythoncode\new\filemanager.py 完整代码 import wx import os …