pythonUI自动化003:POM底层框架目录

1. pythonUI自动化之组成结构

  python+pytest+allure+POM

  python:编程语言

  pytest:单元测试框架

  allure:测试报告

  POM:页面对象模型

2. pythonUI自动化之POM测试框架目录

1. base文件夹:基类,用于配置元素操作,如获取元素、输入、点击、等待等函数

2. pages_object文件夹:页面对象类,用于存放每个页面的操作对象,这也是POM框架的核心内容

3. test_cases文件夹:测试用例。每个测试用例应该单独成为一个py文件,并按照逻辑进行组织。可以根据项目需求创建不同的子文件夹来分类管理测试用例。

4. utils文件夹:用于存放工具函数或者公共方法。在编写测试时,可能会使到一些重复性高且与特定页面无关的功能,可以将其提取为工具函数并放入此文件夹中。

5. data文件夹:测试数据存放目录

6. configs文件夹:用于存放配置文件。如果需要修改测试运行参数或者设置全局变量,可以将其保存在配置文件中,然后在测试过程中引用。

7. reports文件夹:用于生成测试报告。当测试完成后,可以将测试结果输出为HTML格式的报告,并保存在此文件夹中。

8. main.py文件:主程序入口点。所有的测试任务从此处开始执行,可以选择指定要运行的测试用例集合或者整个测试模块。

9. requirements.txt文件:记录了项目所需的第三方库及版本号。可以使用pip命令安装所列出的库。

10. .gitignore文件:Git版本控制系统的忽略文件,用于指定哪些文件/文件夹不被添加到版本控制中。

11. README.md文件:项目说明文档,介绍项目名称、目录结构、使用方法等内容。

1. base文件夹:基类,用于配置元素操作,如获取元素、输入、点击、等待等函数

"""
    基类
"""


class Base:
    def __init__(self, driver):
        self.driver = driver

    # 打开网址
    def open(self, url):
        self.driver.get(url)

    # 获取元素信息
    def locator(self, **data):
        """
        data.get('name', 'xpath'): 获取data字典里的name, 如果没有则默认xpath
        :param data:
        :return:
        """
        ele = self.driver.find_element(data.get('name', 'xpath'), data['ele'])
        return ele

    # 点击
    def click(self, **data):
        self.locator(**data).click()

    # 输入
    def input(self, **data):
        self.locator(**data).send_keys(data['txt'])

2. pages_object文件夹:页面对象类,用于存放每个页面的操作对象,这也是POM框架的核心内容。自动化是否做的好,全看页面是否维护的好

假设整个系统只有(登录)和(用户)两个模块, 而(用户)模块的核心功能是(新增用户)和(删除用户), 而你想设计两条用户, 一条新增用户, 一条删除用户,那么页面对象你就可以这么设计

 接下来就可以设计我们的用例了:

用例1:新增用户

用户2:删除用户

3. test_cases文件夹:测试用例。每个测试用例应该单独成为一个py文件,并按照逻辑进行组织。可以根据项目需求创建不同的子文件夹来分类管理测试用例。

 4. configs文件夹:配置文件。可以将浏览器启动配置,数据库启动配置等其他配置都放到这个文件中

假如在以上用例中,我想让浏览器启动时就开启无痕模式,该怎么做?

然后如何导入使用呢?如下

5. main.py文件:主程序入口点。所有的测试任务从此处开始执行,可以选择指定要运行的测试用例集合或者整个测试模块。

这个是所有用例的执行文件,相当于用例执行开关,如何设计呢? 比如这里使用的是pytest

6. utils文件夹:工具文件。在编写测试时,可能会使到一些重复性高且与特定页面无关的功能,可以将其提取为工具函数并放入此文件夹中。

这个相当于一个工具文件, 比如用例有可能用到正则表达式、特殊计算公式、替换等功能时,都可以封装在这个文件中。该文件暂不代码展示

 7. reports文件夹:测试报告。当测试完成后,可以将测试结果输出为HTML格式的报告,并保存在此文件夹中。

测试报告文件, 这里使用的是allure报告,对于如何使用安装allure报告, 可以看这篇文章:https://www.cnblogs.com/FBGG/p/15491711.html

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,以下是一个基于Python + pytest 打造接口自动化POM框架的示例代码: 1. 安装pytest库 ```bash pip install pytest ``` 2. 创建项目目录结构 ``` +-- config/ | +-- __init__.py | +-- config.py +-- pages/ | +-- __init__.py | +-- base_page.py | +-- login_page.py +-- tests/ | +-- __init__.py | +-- test_login.py +-- utils/ | +-- __init__.py | +-- api.py | +-- logger.py | +-- parse_yaml.py | +-- report.py | +-- send_email.py +-- pytest.ini +-- requirements.txt ``` 3. 编写配置文件 config/config.py ```python import os # 项目根目录路径 ROOT_DIR = os.path.dirname(os.path.abspath(__file__)) # 接口基础 URL BASE_URL = "http://api.example.com" # 测试报告目录路径 REPORT_DIR = os.path.join(ROOT_DIR, "reports") # 日志文件目录路径 LOG_DIR = os.path.join(ROOT_DIR, "logs") # 邮件相关配置 MAIL_HOST = "smtp.163.com" MAIL_PORT = 465 MAIL_USER = "[email protected]" MAIL_PASSWORD = "password" MAIL_RECEIVER = ["[email protected]"] ``` 4. 编写基础页面类 pages/base_page.py ```python from utils.api import send_request class BasePage(object): def __init__(self): self.base_url = "http://api.example.com" self.session = requests.session() self.headers = { "User-Agent": "Mozilla/5.0", "Accept": "application/json", "Content-Type": "application/json", } def send_request(self, method, url, params=None, data=None, json=None, **kwargs): url = self.base_url + url res = send_request(self.session, method, url, params=params, data=data, json=json, headers=self.headers, **kwargs) return res ``` 5. 编写登录页面类 pages/login_page.py ```python from pages.base_page import BasePage class LoginPage(BasePage): def __init__(self): super(LoginPage, self).__init__() self.url = "/login" def login(self, username, password): data = {"username": username, "password": password} res = self.send_request("post", self.url, json=data) return res ``` 6. 编写测试用例 tests/test_login.py ```python import pytest from pages.login_page import LoginPage from utils.parse_yaml import parse_yaml data = parse_yaml("data/login_data.yaml") class TestLogin(object): @pytest.fixture(scope="class", autouse=True) def setup_class(self): self.login_page = LoginPage() @pytest.mark.parametrize("test_data", data) def test_login(self, test_data): res = self.login_page.login(test_data["username"], test_data["password"]) assert res["status"] == test_data["expected"] ``` 7. 编写pytest配置文件 pytest.ini ```ini [pytest] log_cli = true log_cli_level = INFO log_cli_format = %(asctime)s - %(levelname)s - %(message)s log_cli_date_format = %Y-%m-%d %H:%M:%S log_file = logs/pytest.log log_file_level = INFO log_file_format = %(asctime)s - %(levelname)s - %(message)s log_file_date_format = %Y-%m-%d %H:%M:%S addopts = -s -v --html=reports/pytest_report.html --self-contained-html ``` 8. 编写运行脚本 run.py ```python import os import pytest from config.config import REPORT_DIR, LOG_DIR, MAIL_HOST, MAIL_PORT, MAIL_USER, MAIL_PASSWORD, MAIL_RECEIVER from utils.logger import Logger from utils.report import generate_report from utils.send_email import send_mail if __name__ == "__main__": # 创建日志文件夹 if not os.path.exists(LOG_DIR): os.makedirs(LOG_DIR) # 创建测试报告文件夹 if not os.path.exists(REPORT_DIR): os.makedirs(REPORT_DIR) # 设置日志器 logger = Logger().get_logger() # 运行pytest测试用例 pytest.main(["-s", "-v", "--alluredir", "allure_report"]) # 生成测试报告 generate_report(REPORT_DIR) # 发送邮件 send_mail(MAIL_HOST, MAIL_PORT, MAIL_USER, MAIL_PASSWORD, MAIL_RECEIVER, REPORT_DIR) ``` 9. 编写运行脚本所需的依赖 requirements.txt ``` pytest allure-pytest pytest-html pytest-rerunfailures pytest-xdist requests PyYAML allure-python-commons ``` 10. 运行测试用例 在命令行中进入项目根目录,执行以下命令: ```bash python run.py ``` 以上是一个基于Python + pytest 打造接口自动化POM框架的示例代码,供你参考。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

好度

你的鼓励是我最大的创作动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值