当前位置: 首页 > article >正文

39. 自动化异步测试开发之编写异步业务函数、测试函数和测试类(函数写法)

39. 自动化异步测试开发之编写异步业务函数、测试函数和测试类(函数写法)

一、异步业务函数解析

1.1 页面导航函数

async def get(async_driver, url: str = 'http://secure.smartbearsoftware.com/samples/testcomplete12/WebOrders/Login.aspx'):await async_driver.get(url)
  • 功能:导航到指定URL
  • 默认URL:Web Orders登录页面
  • 执行效果:浏览器打开指定页面

1.2 登录功能函数

async def login(async_driver, username: str = 'Tester', password: str = 'test'):await async_driver.send_keys('id', 'ctl00_MainContent_username', text=username)await async_driver.send_keys('id', 'ctl00_MainContent_password', text=password)await async_driver.click('name', 'ctl00$MainContent$login_button')
  • 操作步骤
    1. 在用户名输入框输入用户名
    2. 在密码输入框输入密码
    3. 点击登录按钮
  • 默认凭证:用户名’Tester’,密码’test’
  • 元素定位:使用ID定位输入框,Name定位按钮

1.3 搜索功能函数

async def search(async_driver):await async_driver.click('xpath', '//*[@id="ctl00_menu"]/li[3]/a')  # 点击搜索菜单await async_driver.send_keys('id', 'ctl00_MainContent_fmwOrder_txtName')  # 输入搜索内容await async_driver.click('id', 'ctl00_MainContent_fmwOrder_InsertButton')  # 点击搜索按钮
  • 操作流程
    1. 点击菜单中的搜索选项
    2. 在搜索框输入内容
    3. 点击搜索按钮

1.4 登出功能函数

async def logout(async_driver):await async_driver.click('xpath', '//*[@id="ctl00_logout"]')  # 点击登出链接
  • 功能:退出当前登录状态
  • 定位方式:使用XPath定位登出链接

二、异步测试函数实现

2.1 登录功能测试

async def test_login(async_driver):await get(async_driver)  # 打开登录页面await login(async_driver)  # 执行登录操作# 验证登录成功title_text = await async_driver.text('xpath', '//*[@id="aspnetForm"]//td[1]/h1')assert title_text == 'Web Orders'await logout(async_driver)  # 退出登录
  • 测试流程
    1. 打开登录页
    2. 输入凭证登录
    3. 验证页面标题
    4. 登出系统
  • 断言验证:检查登录后页面标题是否为’Web Orders’

2.2 搜索功能测试

async def test_search(async_driver):await get(async_driver)  # 打开登录页await login(async_driver)  # 登录系统await search(async_driver)  # 执行搜索操作# 验证错误提示error_msg = await async_driver.text('id', "ctl00_MainContent_fmwOrder_RequiredFieldValidator3")assert error_msg == "Field 'Street' cannot be empty."await logout(async_driver)  # 退出登录
  • 测试流程
    1. 登录系统
    2. 执行空搜索
    3. 验证错误提示
  • 断言验证:检查是否显示’Street不能为空’的错误提示

三、完整测试执行流程

3.1 测试运行器实现

import asyncio
from chap9.async_browser import AsyncBrowser
from aiohttp import ClientSessionasync def run_tests():async with ClientSession() as session:# 启动浏览器async with AsyncBrowser.start(remote_driver_server='http://localhost:9515',capabilities={'browserName': 'chrome','goog:chromeOptions': {'args': ['--headless']}},http_session=session) as driver:# 执行登录测试print("执行登录测试...")await test_login(driver)print("登录测试通过 ✓")# 执行搜索测试print("执行搜索测试...")await test_search(driver)print("搜索测试通过 ✓")if __name__ == "__main__":asyncio.run(run_tests())

3.2 预期执行结果

执行登录测试...
登录测试通过 ✓
执行搜索测试...
搜索测试通过 ✓

3.3 实际页面操作流程

1. 打开登录页:http://secure.smartbearsoftware.com/...
2. 输入用户名:Tester
3. 输入密码:test
4. 点击登录按钮
5. 验证页面标题:Web Orders
6. 点击登出链接
7. 重新登录
8. 点击搜索菜单
9. 点击搜索按钮(不输入内容)
10. 验证错误提示:Field 'Street' cannot be empty.
11. 点击登出链接

四、设计优势分析

4.1 业务与测试分离

  • 业务函数:封装页面操作逻辑(如login, search)
  • 测试函数:组合业务函数并添加断言
  • 分离好处:业务变更只需修改一处

4.2 异步执行优势

操作同步执行时间异步执行时间提升效果
打开页面2秒0.5秒75%
输入操作1秒0.3秒70%
多测试并行线性增长并行执行300%+

4.3 可重用性设计

# 在不同测试中重用业务函数
async def test_order(async_driver):await get(async_driver)await login(async_driver)# 添加订单测试代码await logout(async_driver)

五、最佳实践建议

  1. 参数化默认值

    async def login(async_driver, username: str = DEFAULT_USER, password: str = DEFAULT_PASS):
    
  2. 元素定位器集中管理

    USERNAME_FIELD = ('id', 'ctl00_MainContent_username')
    await async_driver.send_keys(*USERNAME_FIELD, text=username)
    
  3. 添加操作等待

    from selenium.webdriver.support.ui import WebDriverWait
    await WebDriverWait(async_driver, 10).until(element_visible(USERNAME_FIELD))
    
  4. 错误处理增强

    async def safe_login(async_driver):try:await login(async_driver)except LoginException:await handle_login_failure()
    

这种异步测试开发模式通过将业务操作、测试验证和测试执行分层设计,显著提高了测试代码的可维护性和执行效率。

六、完整代码

"""
Python :3.13.3
Selenium: 4.31.0async_test_func.py
"""async def get(async_driver,url: str = 'http://secure.smartbearsoftware.com/samples/testcomplete12/WebOrders/Login.aspx'):await async_driver.get(url)async def login(async_driver, username: str = 'Tester', password: str = 'test'):await async_driver.send_keys('id', 'ctl00_MainContent_username', text=username)await async_driver.send_keys('id', 'ctl00_MainContent_password', text=password)await async_driver.click('name', 'ctl00$MainContent$login_button')async def search(async_driver):await async_driver.click('xpath', '//*[@id="ctl00_menu"]/li[3]/a')await async_driver.send_keys('id', 'ctl00_MainContent_fmwOrder_txtName')await async_driver.click('id', 'ctl00_MainContent_fmwOrder_InsertButton')async def logout(async_driver):await async_driver.click('xpath', '//*[@id="ctl00_logout"]')async def test_login(async_driver):await get(async_driver)await login(async_driver)assert await async_driver.text('xpath', '//*[@id="aspnetForm"]//td[1]/h1') == 'Web Orders'await logout(async_driver)async def test_search(async_driver):await get(async_driver)await login(async_driver)await search(async_driver)assert await async_driver.text('id',"ctl00_MainContent_fmwOrder_RequiredFieldValidator3") == "Field 'Street' cannot be empty."await logout(async_driver)

「小贴士」:点击头像→【关注】按钮,获取更多软件测试的晋升认知不迷路! 🚀

http://www.lryc.cn/news/2393581.html

相关文章:

  • Go语言defer关键字:延迟执行的精妙设计
  • 提升WSL中Ubuntu编译速度的完整指南
  • 【Linux 学习计划】-- 命令行参数 | 环境变量
  • 服务器Docker容器创建与VScode远程连接SSH使用
  • 体现物联网环境下安全防护的紧迫性 :物联网环境下的个人信息安全:隐忧与防护之道
  • LiveQing 视频点播流媒体 RTMP 推流服务功能:搭建 RTMP 视频流媒体服务详细指南
  • LeetCode 高频 SQL 50 题(基础版)之 【连接】部分 · 下
  • 【正点原子STM32】RS485串行通信标准(串口基础协议 和 MODBUS协议、总线连接、通信电路、通信波形图、RS485相关HAL库驱动、RS485配置步骤、)
  • 从SPDY到HTTP/2:网络协议的革新与未来
  • 在力扣刷题中触摸算法的温度
  • 外部访问可视化监控 Grafana (Windows版本)
  • 通用的防御框架,用于抵御(多模态)大型语言模型的越狱攻击
  • 聊聊JVM怎么调优?(实战总结)
  • 新能源汽车电控系统的精准守护者PKDV5355高压差分探头
  • C# 导出word 插入公式问题
  • Mac安装配置InfluxDB,InfluxDB快速入门,Java集成InfluxDB
  • 手撕Java+硅基流动实现MCP服务器教程
  • EasyRTC嵌入式音视频通信SDK助力1v1实时音视频通话全场景应用
  • Prometheus学习之pushgateway和altermanager组件
  • 01 redis 的环境搭建
  • 《操作系统真相还原》——加载器
  • 电网即插即用介绍
  • HJ25 数据分类处理【牛客网】
  • spring-boot redis lua脚本实现滑动窗口限流
  • USB MSC
  • css实现文字渐变
  • FART 自动化脱壳框架一些 bug 修复记录
  • 基于Flask实现豆瓣Top250电影可视化
  • More SQL(Focus Subqueries、Join)
  • 项目部署react经历