• Python Selenium搭建UI自动化测试框架


    自动化测试是软件测试中非常重要的一部分,可以提高测试效率和测试覆盖率。在UI自动化测试中,Selenium是非常流行的工具。本文将介绍如何使用Python和Selenium搭建UI自动化测试框架。

    一、环境准备
    在开始搭建UI自动化测试框架之前,需要先安装Python和Selenium。可以从Python官网下载Python安装包,并使用pip命令安装Selenium。

    二、框架目录结构
    在搭建UI自动化测试框架之前,需要先规划好框架的目录结构。以下是一个比较完整的目录结构:

    1. ├── config
    2. │ ├── __init__.py
    3. │ ├── config.ini
    4. │ └── logger.ini
    5. ├── data
    6. │ ├── __init__.py
    7. │ ├── test_data.xlsx
    8. │ └── test_data.json
    9. ├── logs
    10. │ ├── __init__.py
    11. │ └── test.log
    12. ├── page
    13. │ ├── __init__.py
    14. │ └── login_page.py
    15. ├── report
    16. │ ├── __init__.py
    17. │ └── test_report.html
    18. │ └── screenshots
    19. │ ├── test_login_failure_2022-05-01_08-30-00.png
    20. │ └── test_login_success_2022-05-01_08-30-00.png
    21. ├── testcase
    22. │ ├── __init__.py
    23. │ └── test_login.py
    24. ├── utils
    25. │ ├── __init__.py
    26. │ ├── driver.py
    27. │ ├── logger.py
    28. │ └── read_config.py
    29. │ └── take_screenshot.py
    30. ├── .gitignore
    31. ├── README.md
    32. ├── requirements.txt
    33. └── run.py

    config:存放配置文件,包括config.ini和logger.ini。

    data:存放测试数据,包括Excel和JSON格式的数据。

    logs:存放日志文件,包括test.log。

    page:存放页面对象,每个页面对应一个.py文件。

    report:存放测试报告,包括test_report.html。

    screenshots:用于存放测试过程中的截图。

    testcase:存放测试用例,每个用例对应一个.py文件。

    utils:存放工具类,包括driver.py、logger.py和read_config.py。

    .gitignore:Git忽略文件列表。

    README.md:项目说明文件。

    requirements.txt:Python依赖包列表。

    run.py:测试执行入口。

    三、框架搭建
    1.创建项目目录
    在本地创建一个项目目录,进入该目录,执行以下命令:

    1. mkdir config data logs page report report/screenshots testcase utils
    2. touch .gitignore README.md requirements.txt run.py
    3. cd config && touch __init__.py config.ini logger.ini && cd ..
    4. cd data && touch __init__.py test_data.xlsx test_data.json && cd ..
    5. cd logs && touch __init__.py test.log && cd ..
    6. cd page && touch __init__.py login_page.py && cd ..
    7. cd report && touch __init__.py test_report.html && cd ..
    8. cd testcase && touch __init__.py test_login.py && cd ..
    9. cd utils && touch __init__.py driver.py logger.py read_config.py && cd ..

    2.安装依赖包

    在项目目录下执行以下命令,安装依赖包:

    pip install selenium openpyxl configparser loguru

    3.编写配置文件

    在config目录下的config.ini文件中,配置浏览器类型和网站地址:

    1. [Browser]
    2. browser_name = chrome
    3. [URL]
    4. base_url = https://www.example.com

    在config目录下的logger.ini文件中,配置日志文件路径和日志级别:

    1. [loggers]
    2. keys=root
    3. [handlers]
    4. keys=consoleHandler,fileHandler
    5. [formatters]
    6. keys=formatter
    7. [logger_root]
    8. level=DEBUG
    9. handlers=consoleHandler,fileHandler
    10. [handler_consoleHandler]
    11. class=StreamHandler
    12. level=DEBUG
    13. formatter=formatter
    14. args=(sys.stdout,)
    15. [handler_fileHandler]
    16. class=handlers.TimedRotatingFileHandler
    17. level=DEBUG
    18. formatter=formatter
    19. args=('logs/test.log', 'D', 1, 30)
    20. [formatter_formatter]
    21. format=%(asctime)s - %(name)s - %(levelname)s - %(message)s
    22. datefmt=%Y-%m-%d %H:%M:%S

    4.编写工具类

    在utils目录下的driver.py文件中,封装获取浏览器驱动的方法:

    1. import os
    2. from selenium import webdriver
    3. from configparser import ConfigParser
    4. def get_driver():
    5. config = ConfigParser()
    6. config.read(os.path.join(os.path.dirname(__file__), '../config/config.ini'))
    7. browser_name = config.get('Browser', 'browser_name')
    8. if browser_name.lower() == 'chrome':
    9. return webdriver.Chrome()
    10. elif browser_name.lower() == 'firefox':
    11. return webdriver.Firefox()
    12. elif browser_name.lower() == 'edge':
    13. return webdriver.Edge()
    14. else:
    15. raise ValueError('Unsupported browser: {}'.format(browser_name))

    在utils目录下的logger.py文件中,封装日志记录的方法:

    1. import os
    2. from loguru import logger
    3. from configparser import ConfigParser
    4. config = ConfigParser()
    5. config.read(os.path.join(os.path.dirname(__file__), '../config/logger.ini'))
    6. logger.add(config.get('handler_fileHandler', 'class'), level=config.get('logger_root', 'level'), rotation=config.getint('handler_fileHandler', 'args')[2], retention=config.getint('handler_fileHandler', 'args')[3])
    7. def get_logger(name):
    8. return logger.bind(name=name)

    在utils目录下的read_config.py文件中,封装读取配置文件的方法:

    1. import os
    2. from configparser import ConfigParser
    3. config = ConfigParser()
    4. config.read(os.path.join(os.path.dirname(__file__), '../config/config.ini'))
    5. def get_base_url():
    6. return config.get('URL', 'base_url')

    在utils目录下新增了一个take_screenshot.py文件,用于封装截图的方法:

    1. import os
    2. from datetime import datetime
    3. from utils.driver import get_driver
    4. def take_screenshot(name):
    5. driver = get_driver()
    6. screenshot_dir = os.path.join(os.path.dirname(__file__), '../report/screenshots')
    7. os.makedirs(screenshot_dir, exist_ok=True)
    8. screenshot_file = os.path.join(screenshot_dir, '{}_{}.png'.format(name, datetime.now().strftime('%Y-%m-%d_%H-%M-%S')))
    9. driver.save_screenshot(screenshot_file)

    5.编写页面对象

    在page目录下的login_page.py文件中,封装登录页面的元素定位和操作方法:

    1. from selenium.webdriver.common.by import By
    2. from utils.driver import get_driver
    3. class LoginPage:
    4. url = '/login.html'
    5. username_input = (By.ID, 'username')
    6. password_input = (By.ID, 'password')
    7. login_button = (By.ID, 'login-button')
    8. def __init__(self):
    9. self.driver = get_driver()
    10. def open(self):
    11. self.driver.get(get_base_url() + self.url)
    12. def close(self):
    13. self.driver.quit()
    14. def login(self, username, password):
    15. self.driver.find_element(*self.username_input).send_keys(username)
    16. self.driver.find_element(*self.password_input).send_keys(password)
    17. self.driver.find_element(*self.login_button).click()

    6.编写测试用例

    在testcase目录下的test_login.py文件中,编写登录测试用例:

    1. import unittest
    2. from page.login_page import LoginPage
    3. from utils.take_screenshot import take_screenshot
    4. class TestLogin(unittest.TestCase):
    5. def setUp(self):
    6. self.page = LoginPage()
    7. def tearDown(self):
    8. self.page.close()
    9. def test_login_success(self):
    10. self.page.open()
    11. self.page.login('admin', 'admin123')
    12. self.assertIn('Welcome', self.page.driver.title)
    13. def test_login_failure(self):
    14. self.page.open()
    15. self.page.login('admin', 'wrong_password')
    16. self.assertIn('Login failed', self.page.driver.page_source)
    17. take_screenshot('test_login_failure')

    7.编写测试执行入口

    在run.py文件中,编写测试执行入口:

    1. import unittest
    2. from datetime import datetime
    3. from utils.logger import get_logger
    4. from report import HTMLTestRunner
    5. logger = get_logger(__name__)
    6. if __name__ == '__main__':
    7. logger.info('Start testing...')
    8. suite = unittest.defaultTestLoader.discover('testcase')
    9. report_file = 'report/test_report_{}.html'.format(datetime.now().strftime('%Y-%m-%d_%H-%M-%S'))
    10. with open(report_file, 'wb') as f:
    11. runner = HTMLTestRunner.HTMLTestRunner(stream=f, title='Test Report', description='Test Result')
    12. runner.run(suite)
    13. logger.info('Testing finished. Report file: {}'.format(report_file))
    14. # 将截图嵌入测试报告
    15. with open(report_file, 'r+', encoding='utf-8') as f:
    16. content = f.read()
    17. for root, dirs, files in os.walk('report/screenshots'):
    18. for file in files:
    19. screenshot_file = os.path.join(root, file)
    20. if 'test_report' not in screenshot_file:
    21. screenshot_name = os.path.splitext(os.path.basename(screenshot_file))[0]
    22. screenshot_time = datetime.strptime(screenshot_name.split('_')[-2], '%Y-%m-%d')
    23. screenshot_url = os.path.join(get_base_url(), screenshot_file)
    24. content = content.replace('{}"'.format(screenshot_name), '{}" width="50%"'.format(screenshot_url))
    25. f.seek(0)
    26. f.write(content)

    四、测试执行

    在项目目录下执行以下命令,执行测试:

    python run.py

    测试完成后,测试报告将保存在report目录下的test_report.html文件中。

    五、Jenkins持续集成
    持续集成是软件开发过程中非常重要的一环,可以帮助开发团队实现快速迭代和快速交付。Jenkins是一个开源的持续集成工具,可以帮助团队实现自动化构建、自动化测试和自动化部署。本文将介绍如何使用Jenkins进行UI自动化测试的持续集成。

    1.Jenkins安装和配置
    安装Jenkins
    Jenkins可以从官网下载安装包,根据操作系统选择相应的安装包进行安装。安装完成后,启动Jenkins服务。

    安装插件
    Jenkins需要安装一些插件来支持UI自动化测试,包括:

    Selenium Plugin:用于集成Selenium和Jenkins。

    HTML Publisher Plugin:用于生成测试报告。

    在Jenkins的插件管理页面中,搜索并安装这两个插件。

    配置Jenkins
    在Jenkins的系统管理页面中,配置全局环境变量和全局工具配置。

    配置全局环境变量:设置PYTHONPATH变量,指向Python的安装目录。

    配置全局工具:添加Python和浏览器驱动的安装路径。

    2.Jenkins配置UI自动化测试任务
    创建Jenkins任务
    在Jenkins的首页中,点击“新建任务”,选择“自由风格软件项目”,输入任务名称,点击“确定”。

    配置源码管理
    在任务配置页面中,选择“Git”作为源码管理方式,填写代码仓库地址和分支信息。

    配置构建触发器
    在任务配置页面中,选择“构建触发器”,配置定时构建或者代码提交构建。

    配置构建环境
    在任务配置页面中,选择“构建环境”,配置Python环境和浏览器驱动。

    配置构建步骤
    在任务配置页面中,选择“构建步骤”,配置构建脚本。

    构建脚本如下:

    1. #!/bin/bash
    2. # 安装依赖包
    3. pip install -r requirements.txt
    4. # 执行测试
    5. python run.py
    6. # 生成测试报告
    7. cp report/test_report.html $WORKSPACE
    8. # 发布测试报告
    9. echo '

      UI自动化测试报告

      '
      > report.html
    10. echo '' >> report.html
    11. cp report.html $WORKSPACE

    配置构建后操作
    在任务配置页面中,选择“构建后操作”,配置测试报告的发布方式。

    发布方式如下:

    发布HTML测试报告:选择“HTML Publisher Plugin”,设置测试报告路径为$WORKSPACE/report.html。

    3.Jenkins测试执行
    在Jenkins的任务页面中,点击“立即构建”,Jenkins将自动拉取代码,执行测试,并生成测试报告。测试报告将发布到Jenkins的测试报告页面中。

    本文主要介绍了如何使用Python Selenium框架搭建UI自动化测试框架,并给出了一个完整的目录结构示例进行参考。通过UI自动化测试框架,可以帮助团队快速构建自动化测试框架,提高测试效率和测试质量。希望本文能对你有所帮助。

  • 相关阅读:
    归并排序的简单理解
    Java计算机毕业设计德云社剧场网上售票系统源码+系统+数据库+lw文档
    javaweb 之 Request 和 Response 常见案例 用户登录和注册
    河北涿州水稻种植历史 国稻种芯·中国水稻节:保定效益双赢
    【mfc/VS2022】计图实验:绘图工具设计知识笔记2
    牛客多校2 - Link with Level Editor I(DP优化)
    【C++】队列
    原画设计邀约话术
    flink-sql读写hive
    微服务架构深入理解 | 技术栈
  • 原文地址:https://blog.csdn.net/qq_73332379/article/details/132777003