Go to file
floraachy 05f06be1d9 update 2023-11-23 18:56:05 +08:00
attachments 针对框架的一系列优化 2023-11-07 15:14:42 +08:00
case_data 新增用例:新建疑修 2023-11-23 10:17:51 +08:00
case_utils 移除pyautogui相关代码 2023-11-23 17:26:16 +08:00
common_utils 针对框架的一系列优化 2023-11-07 15:14:42 +08:00
config 新增用例:新建疑修 2023-11-23 10:17:51 +08:00
interface 针对框架的一系列优化 2023-11-07 15:14:42 +08:00
lib/allure-2.22.0 针对框架的一系列优化 2023-11-07 15:14:42 +08:00
page_objects 移除pyautogui相关代码 2023-11-23 17:26:16 +08:00
test_case update 2023-11-23 18:56:05 +08:00
.gitignore 1. 优化allure报告,增加allure优先级 2. 增加日志显示运行结果 3. 优化run.py代码 2023-07-10 15:12:59 +08:00
Pipfile 移除pyautogui相关代码 2023-11-23 17:26:16 +08:00
README.md 针对框架的一系列优化 2023-11-07 15:14:42 +08:00
conftest.py update 2023-11-23 18:56:05 +08:00
dockerfile update 2023-11-23 18:56:05 +08:00
pytest.ini 针对框架的一系列优化 2023-11-07 15:14:42 +08:00
run.py 新增用例:新建疑修 2023-11-23 10:17:51 +08:00

README.md

一、框架介绍

本框架主要是基于 Python + pytest + selenium + pytest-html/Allure + loguru + 邮件通知/企业微信通知/钉钉通知 实现的WEB UI自动化框架。

对于框架任何问题,欢迎联系我!

二、实现功能

  • 基于PageObject设计模式结合该平台可实现测试用例的自动化执行及自动化测试报告的生成同时包括自动化测试执行时用例失败的截图操作。
  • 使用webdriver_manager自动下载webdriver告别手动下载再也不用担心webdriver版本问题了。
  • 支持通过命令行指定一个运行浏览器,切换浏览器无忧。
  • 支持通过命令行指定运行环境,实现环境一键切换,解决多环境相互影响问题
  • 采用loguru管理日志可以输出更为优雅简洁的日志
  • 钉钉、企业微信通知: 支持多种通知场景,执行成功之后,可选择发送钉钉、或者企业微信、邮箱通知
  • 使用pipenv管理虚拟环境和依赖文件可以使用pipenv install一键安装依赖包。
  • 框架支持Allure测试报告可以动态配置所需报告。
  • 支持利用allure设置用例优先级运行指定优先级的用例。

三、目录结构

├────attachments/  保存测试过程中所属附件
├────case_data/  保存测试数据
├────case_utils/  与测试相关的工具类
├────common_utils/  公共的工具类
├────config/   相关配置文件
├────interface/   平台基础接口保存目录
├────lib/   第三方模块保存的目录
├────outputs/   测试报告及测试截图,日志保存的目录
├────page_objects/    封装页面元素定位和操作
├────test_case/    测试用例保存的目录
├────Pipfile
├────pytest.ini
├────README.md
├────.gitignore
├────run.py   主运行文件入口

四、依赖库

pytest = "==6.2.5"
requests = "==2.26.0"
loguru = "*"
pytest-rerunfailures = "*"
faker = "*"
yagmail = "*"
selenium = "*"
pyautogui = "*"
allure-pytest = "*"
webdriver-manager = "*"
requests-toolbelt = "*"

五、安装教程

  1. 通过Git工具clone代码到本地 或者 直接下载压缩包ZIP
git clone https://gitlink.org.cn/floraachy/uiautotest.git
  1. 本地电脑搭建好 python环境我使用的python版本是3.9。包括allure测试报告所需的java环境安装jdk

  2. 安装pipenv

# 建议在项目根目录下执行命令安装
pip install pipenv
  1. 使用pipenv管理安装环境依赖包pipenv install (必须在项目根目录下执行)
   注意使用pipenv install会自动安装Pipfile里面的依赖包该依赖包仅安装在虚拟环境里不安装在测试机。

如上环境都已经搭建好了,包括框架依赖包也都安装好了。

六、如何创建用例

1. 修改配置文件 config.settings.py

1确认RunConfig的各项参数可以调整失败重跑次数rerun 失败重跑间隔时间reruns_delay,当达到最大失败数,停止执行max_fail 2确认测试完成后是否发送测试结果由SEND_RESULT_TYPE控制并填充对应邮件/钉钉/企业微信配置信息 3指定日志收集级别由LOG_LEVEL控制

2. 修改全局变量,增加测试数据 config.global_vars.py

  1. ENV_VARS["common"]是一些公共参数,如报告标题,报告名称,测试者,测试部门。后续会显示在测试报告上。如果还有其他,可自行添加 2ENV_VARS["test"]是保存test环境的一些测试数据。ENV_VARS["live"]是保存live环境的一些测试数据。如果还有其他环境可以继续增加例如增加ENV_VARS["dev"] = {"host": "", ......}

3. 删除框架中的示例用例数据

1删除 case_data目录下所有文件 2删除page_objects目录下所有文件 3删除 test_case目录下所有编写的用例, conftest.py中的内容可以视情况保存或修改

4. 编写测试用例

1. 在page_objects目录新建一个py文件,用于管理元素的定位以及页面操作方法

2. 在 case_data目录下新建一个py文件,用于管理测试用例中所需的测试数据

  • 测试数据中需要存在字典case_common用于配置allure报告参考如下
case_common = {
    "allure_epic": "GitLink",
    "allure_feature": "登录模块",
}
  • 用例实际执行的数据,需要参考如下:
# allure_story以及severity用于配置allure报告建议配置
# 字典命名可以自定义
# title字段建议保留涉及到报告上的显示
login_pop_success = {
    "allure_story": "弹窗登录",
    "cases":
        [
            {"title": "弹窗登录: 正确用户名和密码登录成功", "user": "${login}", "password": "${password}",
             "run": False,
             "severity": "critical"}
        ]
}

3. 在 test_case目录编写测试用例

  • 注意:测试用例命令需要遵循pytest命名规则。

七、运行自动化测试

1. 激活已存在的虚拟环境

  • 如果不存在会创建一个pipenv shell (必须在项目根目录下执行)

2. 运行

  > python run.py  (默认在test环境运行测试用例, 报告采用allure)
  > python run.py -m demo 在test环境仅运行打了标记demo用例 默认报告采用allure
  > python run.py -env live 在live环境运行测试用例
  > python run.py -env=test 在test环境运行测试用例
  > python run.py -driver chrome  (使用chrome浏览器运行测试用例)
  > python run.py -env test  -report no -driver chrome-headless  在test环境使用谷歌无头浏览器运行用例并且生成allure html report

注意:

  • 如果pycharm.interpreter拥有了框架所需的所有依赖包可以通过pycharm直接在run.py中右键运行

八 、初始化项目可能遇到的问题

赞赏

如果这个库有帮助到你并且你很想支持库的后续开发和维护,那么你可以扫描下方二维码随意打赏我,我将不胜感激

打赏