Selenium实践总结

ops/2024/12/28 14:47:38/

1.使用显示等待而不是隐式等待

隐式等待可能会导致不可预测的测试行为,尤其是在动态 Web 应用程序中。显式等待,它允许您

等待特定条件发生后再继续测试,这种方法提供了更多的控制和可靠性。

WebDriverWait wait = new WebDriverWait(driver, TimeSpan.FromSeconds(10));
wait.Until(SeleniumExtras.WaitHelpers.ExpectedConditions.ElementIsVisible(By.Id("elementId")));

2.使用页面对象模型(POM)

页面对象模型是一种设计模式,可增强测试维护并减少代码重复。它涉及为每个网页或组件创建一

个类,封装页面的元素和行为。

public class LoginPage
{private IWebDriver driver;private By usernameField = By.Id("username");private By passwordField = By.Id("password");private By loginButton = By.Id("login");public LoginPage(IWebDriver driver){this.driver = driver;}public void EnterUsername(string username){driver.FindElement(usernameField).SendKeys(username);}public void EnterPassword(string password){driver.FindElement(passwordField).SendKeys(password);}public void ClickLogin(){driver.FindElement(loginButton).Click();}
}

3.优先使用CSS选择器而不是XPath

CSS 选择器通常比 XPath 更快、更易读。使用 CSS 选择器可获得更好的性能和更简洁的代码。

// CSS Selector
driver.FindElement(By.CssSelector(".class-name"));
// XPath
driver.FindElement(By.XPath("//div[@class='class-name']"));

4.避免硬编码测试数据

硬编码测试数据会让你的测试变得难以维护。使用数据驱动的测试技术将测试数据与

测试逻辑分开。

[TestCase("user1", "pass1")]
[TestCase("user2", "pass2")]
public void TestLogin(string username, string password)
{var loginPage = new LoginPage(driver);loginPage.EnterUsername(username);loginPage.EnterPassword(password);loginPage.ClickLogin();
}

5.实现强大的异常处理

try
{// Test logic here
}
catch (NoSuchElementException ex)
{Console.WriteLine("Element not found: " + ex.Message);
}
catch (Exception ex)
{Console.WriteLine("An error occurred: " + ex.Message);
}

自动化测试中不可避免地会出现异常。实施强大的异常处理,以确保测试正常失败并提供

有意义的错误消息。

6.利用浏览器特定选项

不同的浏览器可能有不同的行为。利用特定于浏览器的选项来自定义浏览器的行为并

提高测试稳定性。

var options = new ChromeOptions();
options.AddArgument("--headless");
options.AddArgument("--disable-gpu");
var driver = new ChromeDriver(options);

7.保持Selenium和驱动程序是最新版本

确保您使用的是最新版本的 Selenium WebDriver 和浏览器驱动程序。更新通常包括性能

改进和错误修复,以增强测试可靠性。

8.使用持续集成

将您的 Selenium 测试集成到 CI 管道中,以自动执行测试并立即获得有关代码更改的反馈。

Jenkins、Azure DevOps 和 GitHub Actions 等工具可以帮助您设置 CI 管道。

9.确保跨浏览器兼容性

跨不同浏览器测试您的应用程序,以确保跨浏览器兼容性。使用 Selenium Grid 或基于云的解决方

案(如 BrowserStack 和 Sauce Labs)在多个浏览器和平台上运行测试。

10.定期审查和重构你的测试

定期检查测试代码以确定需要改进的地方。重构测试以消除冗余、提高可读性并确保可维护性。


http://www.ppmy.cn/ops/145679.html

相关文章

Adversarial Machine Learning(对抗机器学习)

之前把机器学习(Machine Learning)的安全问题简单记录了一下,这里有深入研究了一些具体的概念,这里记录一下方便以后查阅。 Adversarial Machine Learning(对抗机器学习) Adversarial Examples 相关内容Eva…

全局webSocket 单个页面进行监听并移除单页面监听

之前全局封装的 webSocket 在某些特定的页面中使用会直接去调用 webSocket 的 onMessage 方法 已进入页面就会调,如果退出页面移除整个监听的话全局监听就会被移除 这是修改后的 全局封装 let token uni.getStorageSync(token) const HEARTBEAT_INTERVAL 1 *…

低代码配置式组态软件-BY组态

随着物联网、大数据等技术高速发展,我们逐步向数字化、可视化的人工智能(AI)时代的方向不断迈进。智能时代是工业 4.0 时代,我国工业领域正努力从“制造”迈向“智造”的新跨越。 什么是组态软件? 组态软件&#xff…

前端真实面试题自用

一、写在前面 笔者,经过计算机学硕考研的失败后,想谋求一份前端工作实在是太难了。一方面,确实曾经学习过的东西很久没有拾起,另一方面,对于前端面经还是记忆不深刻,特地写此贴记录笔者在真实前端面试中遇…

OpenHarmony开发板环境搭建

程序员Feri一名12年的程序员,做过开发带过团队创过业,擅长Java相关开发、鸿蒙开发、人工智能等,专注于程序员搞钱那点儿事,希望在搞钱的路上有你相伴!君志所向,一往无前! 0.OpenHarmony 0.1 OpenHarmony OpenHarmony是一款面向全场景、全连接、全智能的…

Xdebug

1、开启xdebug扩展 2、修改一下php.ini文件 xdebug.remote_enable 1 xdebug.remote_autostart 13、vscode安装插件php debug 4、生成launch.json文件,好像啥都不用改 5、vscode没有配置php路径的,需要去配置: 6、发起请求 8、代码断…

CSES-1687 Company Queries I(倍增法)

题目传送门https://vjudge.net/problem/CSES-1687#authorGPT_zh 解题思路 其实和倍增法求 LCA 是一样的…… 首先设 表示 号点的上面的第 个祖先是谁。 同倍增法: 然后,题目要求我们向上跳 个点。 枚举 (从大到小,想想为…

基于YOLOv5的智能水域监测系统:从目标检测到自动报告生成

随着人工智能技术的迅猛发展,机器视觉在各行各业中得到了广泛的应用,尤其是在安防、农业、环境监测等领域。今天,我们将探索一个结合了YOLOv5目标检测模型和PyQt5界面的智能水域监测系统,它不仅能精准地识别水域中的异常情况&…