快速入门Selenium自动化测试

一、背景与意义

Selenium是常用的Web自动化测试工具,前端开发工程师可以在完成每项开发任务之后,使用Selenuim做一下回归测试,以避免被提BUG太多导致后面做项目总结时太难看。测试工程师学习Selenium时需要掌握很多API接口,例如页面元素如何定位、如何触发各种鼠标操作事件等。而前端工程师则可以充分利用自己所掌握的JavaScript相关API,来替换Selenium中的一些API,从而更快地入门。

文本接下来将给出一个适合前端开发工程师(而不是测试工程师)的Selenium入门示例。

二、代码示例
2.1 编程语言选择

Selenium支持的编程语言有Java、Python、C#、Ruby、JavaScript、Kotlin,Python可能是最常用的语言,很多Selenium教材都是以Python作为编程语言。但对大多数前端开发工程师而言,写JavaScript当然比写Python更顺手。故这里以JavaScript作为编程语言。

2.2 安装Selenium依赖

运行如下命令即可安装JavaScript版本的Selenium依赖:

npm install selenium-webdriver
2.3 启动Selenium

接下来创建自动化测试的主文件test.js:

  1. const { Builder } = require("selenium-webdriver");

  2. // 由于要用到await关键字,故这里需要使用async function包装一下。

  3. (async function() {

  4. /*

  5. * 这里使用firefox而不是更常用的浏览器chrome,是因为selenium和chrome搭配使用时,

  6. * 会出现一些兼容性问题导致的错误,对新手不那么友好。用firefox省事一些

  7. */

  8. driver = await new Builder().forBrowser('firefox').build();

  9. await driver.get('https://www.sogou.com');

  10. })();

然后运行node test.js命令,可以看到firefox打开了https://www.sogou.com,并且导航栏是红色的,表示firefox受到其他程序的控制:

image.png

2.4 自动执行文本输入与按钮点击操作

接下来,我们要在搜索框中输入HelloWorld并执行搜索。查看页面元素的代码可知,搜索框的id为query,根据基础的JavaScript知识,如果在firefox的开发者控制台中执行以下JavaScript代码,可以在搜索框中输入HelloWorld

document.getElementById("query").value = "HelloWorld"

类似地,搜索按钮的id为stb,根据基础的JavaScript知识可知,以下JavaScript可以触发搜索:

document.getElementById("stb").click()

Selenium正好也提供了执行JavaScript的API,即driver.executeScript函数,test.js中可使用driver.executeScript函数执行输入HelloWorld并触发搜索的操作:

  1. const { Builder } = require("selenium-webdriver");

  2. // 由于要用到await关键字,故这里需要使用async function包装一下。

  3. (async function() {

  4. /*

  5. * 这里使用firefox而不是更常用的浏览器chrome,是因为selenium和chrome搭配使用时,

  6. * 会出现一些兼容性问题导致的错误,对新手不那么友好。用firefox省事一些

  7. */

  8. driver = await new Builder().forBrowser('firefox').build();

  9. await driver.get('https://www.sogou.com');

  10. // 输入HelloWorld,并触发搜索

  11. await driver.executeScript(`document.getElementById("query").value = "HelloWorld"`);

  12. await driver.executeScript(`document.getElementById("stb").click()`);

  13. })();

再次运行node test.js命令,可以看到浏览自动打开网站并执行了搜索操作。绝大多数网页上的操作都可以通过JavaScript来模拟实现,故只用driver.executeScript就可以完成很多操作了。

2.5 等待结果和补充断言

执行搜索之后,可能需要等待几百毫秒才能返回搜索结果,这里就需要使用Selenium的等待函数driver.wait。另外执行搜索之后,页面应该会展示“已为您找到xxxx条相关结果”,故可以增加断言验证是否符合预期。另外整个测试流程执行完毕之后,应该调用driver.quit()退出。相关代码补充如下:

  1. const { Builder } = require("selenium-webdriver");

  2. const assert = require("assert");

  3. // 由于要用到await关键字,故这里需要使用async function包装一下。

  4. (async function() {

  5. /*

  6. * 这里使用firefox而不是更常用的浏览器chrome,是因为selenium和chrome搭配使用时,

  7. * 会出现一些兼容性问题导致的错误,对新手不那么友好。用firefox省事一些

  8. */

  9. driver = await new Builder().forBrowser('firefox').build();

  10. await driver.get('https://www.sogou.com');

  11. // 输入HelloWorld,并触发搜索

  12. await driver.executeScript(`document.getElementById("query").value = "HelloWorld"`);

  13. await driver.executeScript(`document.getElementById("stb").click()`);

  14. // wait方法第一个参数是函数,Selenium会反复调用该函数,直到该函数的返回结果为true再执行后面的代码。

  15. // wait方法第二个参数是设置超时时间(单位毫秒),超过该时间第一个参数还没返回true就报错。

  16. await driver.wait(async () => {

  17. // 注意,如果要获取executeScript的执行返回,JS命令中必须要有return语句

  18. return await driver.executeScript(`return !!document.querySelector(".num-tips")`);

  19. } , 60 * 1000); // 超时时间设置为60秒

  20. // 获取页面上的“已为您找到xxxx条相关结果”这一段文字

  21. const searchResultText = await driver.executeScript(`return document.querySelector(".num-tips").innerText`);

  22. // 打个日志以方便调试

  23. console.log("searchResultText", searchResultText);

  24. // 通过断言确认是否符合预期

  25. assert(searchResultText.match(/^搜狗已为您找到约[0-9,]+条相关结果$/, ''), "没有获取到搜索结果");

  26. driver.quit();

  27. })();

三、代码结构优化

从代码结构的角度看,连续两段driver.executeScript命令可以合并在一起,且driver.executeScript命令经常用但有些长,可以用一个名字短一点的函数替代。代码优化为:

  1. const { Builder } = require("selenium-webdriver");

  2. const assert = require("assert");

  3. // 由于要用到await关键字,故这里需要使用async function包装一下。

  4. (async function() {

  5. /*

  6. * 这里使用firefox而不是更常用的浏览器chrome,是因为selenium和chrome搭配使用时,

  7. * 会出现一些兼容性问题导致的错误,对新手不那么友好。用firefox省事一些

  8. */

  9. driver = await new Builder().forBrowser('firefox').build();

  10. await driver.get('https://www.sogou.com');

  11. const exec = command => driver.executeScript(command);

  12. // 输入HelloWorld,并触发搜索

  13. await exec(`

  14. document.getElementById("query").value = "HelloWorld";

  15. document.getElementById("stb").click();

  16. `);

  17. let searchResultText = null;

  18. // wait方法第一个参数是函数,Selenium会反复调用该函数,直到该函数的返回结果为true再执行后面的代码。

  19. // wait方法第二个参数是设置超时时间(单位毫秒),超过该时间第一个参数还没返回true就报错。

  20. await driver.wait(async () => {

  21. // 获取页面上的“已为您找到xxxx条相关结果”这一段文字

  22. // 注意,如果要获取executeScript的执行返回,JS命令中必须要有return语句

  23. searchResultText = await exec(`return document.querySelector(".num-tips")?.innerText`);

  24. return !!searchResultText;

  25. } , 60 * 1000); // 超时时间设置为60秒

  26. // 打个日志以方便调试

  27. console.log("searchResultText", searchResultText);

  28. // 通过断言确认是否符合预期

  29. assert(searchResultText.match(/^搜狗已为您找到约[0-9,]+条相关结果$/, ''), "没有获取到搜索结果");

  30. driver.quit();

  31. })();

 感谢每一个认真阅读我文章的人!!!

作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

 

          视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方蓝色字体或小卡片即可自行领取。软件测试全套资料分享: 耗时2个月整理的软件测试最全资料包

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

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

相关文章

Java基础-内部类与异常处理

(创作不易,感谢有你,你的支持,就是我前行的最大动力,如果看完对你有帮助,请留下您的足迹) 目录 一、Java 内部类 什么是内部类? 使用内部类的优点 访问局部变量的限制 内部类和继承 内部…

HCIP—MSTP(多生成树协议)

目录 一、MSTP技术的背景 二 、MSTP(多生成树协议)的概述 三、MSTP的基本概念 四、MSTP的实验配置 MSTP的引入:单点故障——冗余——二层环路——STP——RSTP——MSTP 一、MSTP技术的背景 单生成树的弊端—部分VLAN路径不同 单生成树的弊…

光控资本:中字头,多股涨停!融资客大举加仓

11月13日,受昨夜外盘心境影响,A股三大指数集体低开,沪指盘中翻红,A50期货指数快速拉升。 当时A股心境并未降温,代表商场急进心境的融资余额数据继续攀升,现在仅次于2015年牛市高点。‍‍‍ 从近期的盘面来…

项目功能--项目介绍(健康管理系统)

一、项目介绍 健康管理系统是一款应用于健康管理机构的业务系统,实现健康管理机构工作内容可视化、会员管理专业化、健康评估数字化、健康干预流程化、知识库集成化,从而提高健康管理师的工作效率,加强与会员间的互动,增强管理者对…

【深度学习目标检测|YOLO算法4-4】YOLO家族进化史:从YOLOv1到YOLOv11的架构创新、性能优化与行业应用全解析——工业领域

【深度学习目标检测|YOLO算法4-4】YOLO家族进化史:从YOLOv1到YOLOv11的架构创新、性能优化与行业应用全解析——工业领域 【深度学习目标检测|YOLO算法4-4】YOLO家族进化史:从YOLOv1到YOLOv11的架构创新、性能优化与行业应用全解析——工业领域 文章目录…

Warped Universe游戏即将在Sui上推出,为玩家提供多样化的游戏体验

Warped Games选择Sui作为其即将推出的创新多类型游戏Warped Universe的首选Web3技术。Warped Universe让玩家可以体验第三视角实时动作、回合制策略和基地建设等玩法。该游戏使用Unreal Engine 5开发,将借助Sui的技术使玩家能够拥有、交易和变现其游戏内资产。 War…

【数据运营】数据治理与运营新纪元:全面解析数据治理平台与运营体系建设方案

踏入数据治理与运营的新纪元,我们迎来了一场深刻变革。本篇文章将带您全面解析数据治理平台与数据运营体系的建设方案,为您揭示数据治理的总体解决策略,探索数据治理平台构建的奥秘,以及数据治理运营实施的具体路径。 数据治理总体解决方案是数据治理与运营体系建设…

PyCharm2024.2.4安装

一、官网下载 1.从下面的链接点进去 PyCharm: The Python IDE for data science and web development by JetBrains 2.进入官网后,下载pycharm安装包 3.点击下载能适配你系统的安装包 4.安装包下载完成 二、安装 1.下载完成后,打开点击右键,打开 2.下一步

【无人机设计与控制】线性和非线性模型预测MPC、NMPC四旋翼无人机轨迹跟踪

摘要 本文研究了四旋翼无人机的线性和非线性模型预测控制(MPC与NMPC)算法在轨迹跟踪中的应用。通过Matlab/Simulink仿真实现了四旋翼无人机在复杂环境中的高效轨迹跟踪。研究结果表明,NMPC比传统MPC在处理非线性动态和外部扰动时具有更好的鲁…

如何用Java爬虫“偷窥”淘宝商品类目API的返回值

在这个数据为王的时代,获取信息就像是在玩一场大型的寻宝游戏。而淘宝,作为电商界的巨人,其商品类目API就像是藏宝图上的秘密标记。今天,我们就来聊聊如何用Java爬虫技术,悄悄地“偷窥”这些宝藏。 准备工作&#xff1…

2024最新网络安全自学路线,内容涵盖3-5年技能提升

01 什么是网络安全 网络安全可以基于攻击和防御视角来分类,我们经常听到的 “红队”、“渗透测试” 等就是研究攻击技术,而“蓝队”、“安全运营”、“安全运维”则研究防御技术。 无论网络、Web、移动、桌面、云等哪个领域,都有攻与防两面…

模拟实现优先级队列

目录 定义 特点 构造函数 常用方法 关于扩容的问题 关于建堆的问题 向上调整和向下调整的比较 (向上调整)代码 (向下调整)代码 关于入队列和出队列问题 模拟实现优先级队列代码 关于堆排序的问题 堆排序代码 关于对…

Django 搭建数据管理web——商品管理

教材: python web 企业级项目开发教程 黑马程序员 5.4 实例1:商品管理 实验步骤: 1.创建项目(任意名字)和应用(goods) 2.在项目文件夹(manage.py文件所在路径)新建te…

C语言中操作符详解(中)

C语言中操作符详解中 放在最前面的1、操作数(Operands)2、单目操作符2.1、分类2.2、举例分析(上代码) 3、关系操作符3.1、分类3.2、举例分析(上代码) 4、逻辑操作符4.1、分类4.2、举例分析(上代…

生成模型——扩散模型(Diffusion Model)

一、扩散模型简介 扩散模型(Diffusion Model)是一种生成模型,主要用于图像生成等任务。它的基本原理源于扩散过程的物理概念,通过最小化去噪过程中的重建损失(通常使用均方误差)来训练模型&#x…

ssm101珠宝首饰交易平台开发+jsp.zip(论文+源码)_kaic

毕业设计(论文) 珠宝首饰交易平台 学 院 专 业 班 级 学 号 用户姓名 指导教师 完成日期 …

关于我、重生到500年前凭借C语言改变世界科技vlog.18——内存函数

文章目录 1. memcpy函数2. memmove函数3. memset函数4. memcmp函数希望读者们多多三连支持小编会继续更新你们的鼓励就是我前进的动力&#xff01; 内存函数是用于 操作内存块的一组函数&#xff0c;它们可以对内存进行复制、移动、设置和比较等操作。这些函数主要在 <str…

Redis高可用-主从复制

这里写目录标题 Redis主从复制主从复制过程环境搭建从节点配置常见问题主从模式缺点 Redis主从复制 虽然 Redis 可以实现单机的数据持久化&#xff0c;但无论是 RDB 也好或者 AOF 也好&#xff0c;都解决不了单点宕机问题&#xff0c;即一旦 redis 服务器本身出现系统故障、硬…

NVR设备ONVIF接入平台EasyCVR视频融合平台社会面视频资源接入视频专网,应该如何处理?

在数字化时代&#xff0c;视频监控系统已成为社会安全管理的重要组成部分。随着城市化进程的加速和信息技术的发展&#xff0c;如何有效整合和管理跨区域、跨行业的视频监控资源&#xff0c;成为了提升社会治理能力的关键。 EasyCVR视频融合云平台&#xff0c;作为TSINGSEE青犀…

通过全球最前沿的技术解决视频拼接中时延带来的的应用缺陷,使得全景视频拼接能够真正得以大范围使用和推广的智慧地产开源了。

智慧地产视觉监控平台是一款功能强大且简单易用的实时算法视频监控系统。它的愿景是最底层打通各大芯片厂商相互间的壁垒&#xff0c;省去繁琐重复的适配流程&#xff0c;实现芯片、算法、应用的全流程组合&#xff0c;从而大大减少企业级应用约95%的开发成本。通过计算机视觉和…