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

Selenium 之浏览器封装

wptr33 2025-03-12 21:10 20 浏览

介绍

基于 Selenium 的自动化测试提供一个便捷的浏览器驱动初始化和操作封装,使得测试人员能够方便地使用不同浏览器进行网页自动化操作。

// 声明当前类所属的包为 utils,用于组织相关的工具类
package utils;

// 导入 Selenium 框架中的 WebDriver 接口,它是操作浏览器的核心接口
import org.openqa.selenium.WebDriver;
// 导入 Chrome 浏览器对应的驱动类,用于创建 Chrome 浏览器的驱动实例
import org.openqa.selenium.chrome.ChromeDriver;
// 导入 Edge 浏览器对应的驱动类,用于创建 Edge 浏览器的驱动实例
import org.openqa.selenium.edge.EdgeDriver;
// 导入 Firefox 浏览器对应的驱动类,用于创建 Firefox 浏览器的驱动实例
import org.openqa.selenium.firefox.FirefoxDriver;
// 导入 Java 8 引入的 Duration 类,用于设置时间间隔,如页面加载超时时间
import java.time.Duration;

/**
 * Browser 类用于封装浏览器驱动的初始化、导航到指定 URL、获取 WebDriver 实例以及关闭浏览器等操作。
 * 通过该类可以方便地根据不同的浏览器类型创建对应的 WebDriver 实例,并进行相关操作。
 */
public class Browser {

    // 声明一个私有的 WebDriver 类型的成员变量,用于存储具体的浏览器驱动实例
    private WebDriver driver;
    // 声明一个私有的常量,用于存储浏览器驱动程序所在的路径,默认值为 "driver"
    private final String driverPath = "driver";

    /**
     * 构造函数,用于初始化 Browser 类的实例。
     * 根据传入的浏览器类型初始化 WebDriver 实例,并将浏览器导航到指定的 URL。
     * 
     * @param browserType 浏览器类型,支持的值为 "chrome", "firefox", "edge"
     * @param url         要访问的 URL 地址
     */
    public Browser(String browserType, String url) {
        // 调用 initializeDriver 方法,根据传入的浏览器类型初始化 WebDriver 实例
        initializeDriver(browserType);
        // 调用 navigateToUrl 方法,将浏览器导航到指定的 URL
        navigateToUrl(url);
    }

    /**
     * 初始化 WebDriver 实例。
     * 根据传入的浏览器类型,设置相应的系统属性并创建对应的浏览器驱动实例。
     * 同时设置浏览器窗口最大化和页面加载超时时间。
     * 
     * @param browserType 浏览器类型,该方法会将其转换为小写进行匹配
     */
    private void initializeDriver(String browserType) {
        // 使用 switch 语句根据浏览器类型进行不同的处理,将传入的 browserType 转换为小写以忽略大小写
        switch (browserType.toLowerCase()) {
            case "chrome":
                // 设置 Chrome 浏览器驱动的系统属性,指定驱动程序的路径
                System.setProperty("webdriver.chrome.driver", driverPath + "/chromedriver.exe");
                // 创建 Chrome 浏览器的驱动实例
                driver = new ChromeDriver();
                break;
            case "firefox":
                // 设置 Firefox 浏览器驱动的系统属性,指定驱动程序的路径
                System.setProperty("webdriver.gecko.driver", driverPath + "/geckodriver.exe");
                // 创建 Firefox 浏览器的驱动实例
                driver = new FirefoxDriver();
                break;
            case "edge":
                // 设置 Edge 浏览器驱动的系统属性,指定驱动程序的路径
                System.setProperty("webdriver.edge.driver", driverPath + "/msedgedriver.exe");
                // 创建 Edge 浏览器的驱动实例
                driver = new EdgeDriver();
                break;
            default:
                // 如果传入的浏览器类型不支持,抛出 IllegalArgumentException 异常
                throw new IllegalArgumentException("Unsupported browser type: " + browserType);
        }

        // 将浏览器窗口最大化
        driver.manage().window().maximize();
        // 设置页面加载超时时间为 30 秒
        driver.manage().timeouts().pageLoadTimeout(Duration.ofSeconds(30));
    }

    /**
     * 导航到指定 URL。
     * 使用 WebDriver 的 navigate().to() 方法将浏览器导航到指定的 URL 地址。
     * 
     * @param url 要访问的 URL 地址
     */
    private void navigateToUrl(String url) {
        // 调用 WebDriver 的 navigate().to() 方法,将浏览器导航到指定的 URL
        driver.navigate().to(url);
    }

    /**
     * 获取 WebDriver 实例。
     * 该方法用于返回当前 Browser 类实例中存储的 WebDriver 实例。
     * 
     * @return WebDriver 实例
     */
    public WebDriver getDriver() {
        return driver;
    }

    /**
     * 关闭浏览器。
     * 该方法用于关闭当前浏览器窗口,并释放 WebDriver 占用的系统资源。
     * 在关闭浏览器后,将 driver 成员变量置为 null。
     */
    public void close() {
        // 检查 driver 成员变量是否不为 null
        if (driver != null) {
            // 调用 WebDriver 的 quit() 方法关闭浏览器并释放资源
            driver.quit();
            // 将 driver 成员变量置为 null,避免后续误操作
            driver = null;
        }
    }
}

 

对Browser类进行测试

package verifyAndTest;

import org.openqa.selenium.WebDriver;
import org.testng.Assert;
import org.testng.annotations.AfterMethod;
import org.testng.annotations.Test;
import utils.Browser;

public class BrowserTest {

    private Browser browser;

    @Test
    public void testBrowser() {
        // 创建 Browser 对象并进行初始化和导航
        // 浏览器类型,支持的值为 "chrome", "firefox", "edge"
        // url – 要访问的 URL 地址
        browser = new Browser("chrome", "https://www.baidu.com/");

        // 获取 WebDriver 实例
        WebDriver driver = browser.getDriver();

        // 断言浏览器标题是否正确
        Assert.assertEquals(driver.getTitle(), "百度一下,你就知道");
    }

    @AfterMethod
    public void tearDown() {
        if (browser != null) {
            browser.close();
        }
    }
}


总结

Browser 类通过封装浏览器驱动的初始化、页面导航、获取驱动实例和关闭浏览器等操作,为基于 Selenium 的自动化测试提供了一个简洁、易用的工具类,减少了测试代码中重复的浏览器初始化和操作代码,提高了测试代码的可维护性和可扩展性。

【完】

分享,让更多的人少走弯路!

#selenium##自动化测试##软件测试#

相关推荐

什么是Java中的继承?如何实现继承?

什么是继承?...

Java 继承与多态:从基础到实战的深度解析

在面向对象编程(OOP)的三大支柱中,继承与多态是构建灵活、可复用代码的核心。无论是日常开发还是框架设计,这两个概念都扮演着至关重要的角色。本文将从基础概念出发,结合实例与图解,带你彻底搞懂Java...

Java基础教程:Java继承概述_java的继承

继承概述假如我们要定义如下类:学生类,老师类和工人类,分析如下。学生类属性:姓名,年龄行为:吃饭,睡觉老师类属性:姓名,年龄,薪水行为:吃饭,睡觉,教书班主任属性:姓名,年龄,薪水行为:吃饭,睡觉,管...

java4个技巧:从继承和覆盖,到最终的类和方法

日复一日,我们编写的大多数Java只使用了该语言全套功能的一小部分。我们实例化的每个流以及我们在实例变量前面加上的每个@Autowired注解都足以完成我们的大部分目标。然而,有些时候,我们必须求助于...

java:举例说明继承的概念_java继承的理解

在现实生活中,继承一般指的是子女继承父辈的财产。在程序中,继承描述的是事物之间的所属关系,通过继承可以使多种事物之间形成一种关系体系。例如猫和狗都属于动物,程序中便可以描述为猫和狗继承自动物,同理,...

从零开始构建一款开源的 Vibe Coding 产品 Week1Day4:业界调研之 Agent 横向对比

前情回顾前面两天我们重点调研了了一下Cursor的原理和Cursor中一个关键的工具edit_file的实现,但是其他CodingAgent也需要稍微摸一下底,看看有没有优秀之处,下...

学会这几个插件,让你的Notepad++使用起来更丝滑

搞程序开发的小伙伴相信对Notepad++都不会陌生,是一个占用空间少、打开启动快的文件编辑器,很多程序员喜欢使用Notepad++进行纯文本编辑或者脚本开发,但是Notepad++的功能绝不止于此,...

将 node_modules 目录放入 Git 仓库的优点

推荐一篇文章Whyyoushouldcheck-inyournodedependencies[1]...

再度加码AI编程,腾讯发布AI CLI并宣布CodeBuddy IDE开启公测

“再熬一年,90%的程序员可能再也用不着写for循环。”凌晨两点半,王工还在公司敲键盘。他手里那份需求文档写了足足六页,产品经理反复改了三次。放在过去,光数据库建表、接口对接、单元测试就得写两三天。现...

git 如何查看stash的内容_git查看ssh key

1.查看Stash列表首先,使用gitstashlist查看所有已保存的stash:...

6万星+ Git命令懒人必备!lazygit 终端UI神器,效率翻倍超顺手!

项目概览lazygit是一个基于终端的Git命令可视化工具,通过简易的TUI(文本用户界面)提升Git操作效率。开发者无需记忆复杂命令,即可完成分支管理、提交、合并等操作。...

《Gemini CLI 实战系列》(一)Gemini CLI 入门:AI 上命令行的第一步

谷歌的Gemini模型最近热度很高,而它的...

deepin IDE新版发布:支持玲珑构建、增强AI智能化

IT之家8月7日消息,深度操作系统官方公众号昨日(8月6日)发布博文,更新推出新版deepin集成开发环境(IDE),重点支持玲珑构建。支持玲珑构建deepinIDE在本次重磅更...

狂揽82.7k的star,这款开源可视化神器,轻松创建流程图和图表

再不用Mermaid,你的技术文档可能已经在悄悄“腐烂”——图表版本对不上、同事改完没同步、评审会上被一句“这图哪来的”问得哑口无言。这不是危言耸听。GitHub2025年开发者报告显示,63%的新仓...

《Gemini CLI 实战系列》(五)打造专属命令行工具箱

在前几篇文章中,我们介绍了GeminiCLI的基础用法、效率提升、文件处理和与外部工具结合。今天我们进入第五篇...