首页
技术小册
AIGC
面试刷题
技术文章
MAGENTO
云计算
视频课程
源码下载
PDF书籍
「涨薪秘籍」
登录
注册
聊聊Web自动化测试:黑盒、白盒、α测试、β测试、冒烟测试、回归测试
Selenium三剑客:WebDriver、IDE、Grid一网打尽
Selenium开发环境搭建
下载安装浏览器驱动:教你解决最麻烦的版本匹配问题
第一个Selenium测试:Selenium测试流程、源码分析
实现元素定位:掌握Selenium八大定位方法
通过打车生活案例,深入剖析WebDriver运行原理
掌握WebDriver核心方法和属性的使用
掌握WebElement核心方法和属性的使用
form表单:熟练掌握form表单操作步骤
掌握checkbox和radiobutton的定位技巧
下拉列表:熟练使用Select类,来实现下拉列表定位
弹框处理:掌握alert、confirm、prompt三种弹出的用法
Selenium三种等待方式:剖析原理、用法和应用场景
Selenium等待条件:掌握17种元素等待条件
掌握鼠标单击、双击、右击,键盘输入、键盘组合键的应用
熟练执行JavaScript的方法和技巧,掌握JavaScript操作滚动条
Selenium屏幕截图:实现屏幕截屏、按照日期时间格式保存图片
掌握frame、iframe定位,熟练frame的切入和切出
下载安装Selenium IDE:下载安装Chrome、Firefox插件IDE
熟练Selenium IDE菜单栏、工具类、命令窗口的使用
Selenium IDE实现录制和回放及脚本导出
项目环境搭建:安装JDK、MySQL、Tomcat和测试系统
需求分析和用例设计:深度挖掘需求,掌握测试用例设计范式
项目架构设计:掌握分层设计思想,合理设计目录和包结构
解决验证码问题-方案一:使用pytesseract和Pillow实现验证码识别
解决验证码问题-方案二:通过第三方AI库识别验证码
实现工具类:设计获得验证码、随机字符串生成、cookie操作工具类
完成用户注册测试用例:解决验证码、等待弹框等复杂内容
完成用户登录测试用例:实现登录成功和失败测试
完成管理员登录测试用例:完成验证码正确和错误测试用例
完成文章分类测试用例:解决测试用例依赖问题
完成添加、删除文章测试用例
unittest简介:测试用例、测试套件、测试运行器、测试加载器
unittest中的方法:掌握各种setup、teardown和断言方法
测试用例、测试套件和测试加载器:掌握加载测试用例的四种方法
使用unittest重构测试用例:掌握使用unittest模块的方法和技巧
为项目添加测试报告:使用第三方模块实现测试报告
pytest框架简介:pytest安装、用例编写规则、执行用例
pytest标记:查找测试策略、标记测试函数
pytest参数化处理:使用参数化装饰器、解析列表、元组、字典等数据
pytest Fixture:使用fixture实现用例之间的调用
pytest setup 和 teardown
pytest allure生成测试报告
使用pytest重构项目:实现用例依赖、测试报告、数据参数化
logging模块简介:日志的作用、等级和常用函数
logging日志格式输出:日志发生的时间、文件、模块、行号等信息格式输出
logging模块四大组件:Logger、Handler、Formatter、Filter的用法
为项目添加日志:将日志应用到项目
使用csv模块读取CSV文件,使用pytest参数化实现DDT
使用json模块读取json文件,使用pytest参数化实现DDT
使用xlrd模块读取excel文件,使用pytest参数化实现DDT
Selenium读取数据库数据:将数据保存到数据库,实现数据驱动的测试
Selenium DDT:使用DDT模块实现数据驱动的测试
使用DDT思想重构项目:使用数据库保存数据,将数据驱动思想应用到项目
POM设计模式简介:理解页面-对象-模型设计模式,实现代码的松耦合
设计BasePage类:设计基类,提高项目的代码重用性
设计项目页面对应的PO类:使用POM设计模式设计PO类
设计项目测试用例:将POM设计模式应用到项目
Selenium Grid下载安装:配置Java运行环境,下载安装Selenium Grid
Selenium注册node节点
使用Selenium执行远程测试
Jenkins环境搭建:下载安装Jenkins
在Jenkins中运行项目
邮件通知:实现邮件通知功能
定时运行项目,实现真正的自动化测试
当前位置:
首页>>
技术小册>>
Selenium自动化测试实战
小册名称:Selenium自动化测试实战
### 设计BasePage类:设计基类,提高项目的代码重用性 在自动化测试领域,特别是在使用Selenium进行Web自动化测试时,设计高效的测试框架是确保测试代码可维护性、可扩展性和可重用性的关键。其中,设计一个强大的`BasePage`类作为所有页面对象的基类,是提升测试项目结构清晰度与代码复用率的重要手段。本章将深入探讨如何设计并实现这样一个`BasePage`类,以及它如何助力自动化测试项目的优化。 #### 一、引言 自动化测试框架中,页面对象模型(Page Object Model, POM)是一种被广泛采用的设计模式。它通过将网页的每一个页面抽象成一个对象,将页面上的元素和针对这些元素的操作封装起来,从而实现了测试脚本与页面结构的解耦。`BasePage`类作为这一模式中的核心基类,定义了所有页面对象共通的属性和方法,如元素定位、等待机制、页面跳转等,极大地提高了代码的重用性和可维护性。 #### 二、BasePage类的设计原则 在设计`BasePage`类时,应遵循以下几个基本原则: 1. **抽象性**:确保`BasePage`类能够提炼出所有页面对象的共同特征,如初始化浏览器驱动、设置等待时间、元素定位策略等。 2. **灵活性**:设计时应考虑未来可能的需求变更,提供足够的接口或钩子,以便在不修改基类代码的情况下扩展功能。 3. **易用性**:基类提供的方法应简洁明了,易于理解和使用,降低学习成本。 4. **可测试性**:确保`BasePage`类本身及其提供的方法可以被独立测试,以验证其正确性。 #### 三、BasePage类的实现 ##### 3.1 引入必要的库 首先,需要引入Selenium WebDriver库及其他可能用到的库,如`time`用于实现简单的等待机制,`unittest`用于编写测试用例(虽然这不是`BasePage`类直接需要的,但通常在测试项目中会用到)。 ```python from selenium import webdriver from selenium.webdriver.common.by import By from selenium.webdriver.support.ui import WebDriverWait from selenium.webdriver.support import expected_conditions as EC import time ``` ##### 3.2 定义BasePage类 接下来,定义`BasePage`类,并初始化一些基本的属性,如WebDriver实例、页面加载等待时间等。 ```python class BasePage: def __init__(self, driver, wait_time=10): self.driver = driver self.wait = WebDriverWait(driver, wait_time) def find_element(self, locator): """根据给定的定位器查找元素""" try: element = self.wait.until(EC.element_to_be_clickable(locator)) return element except Exception as e: print(f"Failed to find element: {e}") return None def find_elements(self, locator): """根据给定的定位器查找多个元素""" return self.driver.find_elements(*locator) def navigate_to(self, url): """导航到指定URL""" self.driver.get(url) def is_element_present(self, locator): """检查元素是否存在""" try: self.wait.until(EC.presence_of_element_located(locator)) return True except Exception: return False # 可以添加更多通用方法,如点击、输入文本等 ``` ##### 3.3 元素定位策略 在`BasePage`类中,我们使用Selenium的`WebDriverWait`和`expected_conditions`来实现元素的智能等待,确保在元素可操作之前不执行后续操作。同时,`find_element`和`find_elements`方法通过接受一个定位器(如`(By.ID, 'elementId')`)作为参数,提高了代码的灵活性和复用性。 ##### 3.4 导航与等待 `navigate_to`方法用于导航到指定的URL,而`is_element_present`方法则用于检查页面上的某个元素是否存在,这两个方法都是自动化测试过程中常见的需求。 #### 四、BasePage类的扩展与应用 ##### 4.1 继承BasePage类 在实际项目中,每个具体的页面都可以继承`BasePage`类,并根据该页面的特定元素和操作来扩展方法。 ```python class HomePage(BasePage): def __init__(self, driver): super().__init__(driver) self.search_box = (By.ID, 'searchBox') def search_for(self, query): search_input = self.find_element(self.search_box) search_input.send_keys(query) search_input.submit() ``` ##### 4.2 使用示例 在测试用例中,可以直接实例化`HomePage`类(或其他继承自`BasePage`的页面类),并调用其方法来执行测试步骤。 ```python def test_search_functionality(self): driver = webdriver.Chrome() home_page = HomePage(driver) home_page.navigate_to('http://example.com') home_page.search_for('Selenium') # 后续断言等测试逻辑... driver.quit() ``` #### 五、总结 通过设计并实现一个强大的`BasePage`类,我们可以为自动化测试项目奠定一个坚实的基础。该类不仅封装了与页面交互的通用方法,还通过继承机制促进了代码的重用和扩展。在实际应用中,我们可以根据具体页面的需求,灵活地扩展`BasePage`类,从而构建出结构清晰、易于维护的自动化测试框架。此外,随着项目的发展,我们也可以不断地优化和重构`BasePage`类,以更好地适应新的测试需求和挑战。
上一篇:
POM设计模式简介:理解页面-对象-模型设计模式,实现代码的松耦合
下一篇:
设计项目页面对应的PO类:使用POM设计模式设计PO类
该分类下的相关小册推荐:
Python编程轻松进阶(四)
Python数据分析与挖掘实战(下)
Python与办公-玩转PDF
Python合辑9-判断和循环
Python合辑2-字符串常用方法
Python爬虫入门与实战开发(下)
Python机器学习基础教程(上)
Python合辑8-变量和运算符
Python合辑13-面向对象编程案例(上)
Python与办公-玩转Word
Python合辑7-集合、列表与元组
Python编程轻松进阶(一)