Python+pytest+requests 自动化测试框架

本文介绍了如何使用 Python、pytest 和 requests 构建自动化测试框架。从环境准备、简单 Demo 到日志记录和框架封装,详细阐述了如何创建数据层、业务层和测试用例层,并提供了 yml 文件读取功能。最后,文章分享了自动化测试的进阶资源。
摘要由CSDN通过智能技术生成

目录

前言:

环境准备

简单 Demo

yml 文件读取功能

数据层

业务层

测试用例层


前言:

在本文中,我们将介绍如何使用 Python+pytest+requests 自动化测试框架。 

环境准备

本次选用的是Python+Pytest+requests来搭建自动化框架,需要有 Python 环境(3.x 版本),安装pytestrequests,不会安装的自行去网上搜教程。

关于 Pytest 的基本使用,这里不作讲解,不清楚的可以看我之前的文章。

简单 Demo

我们先创建一个项目,取名api-test,然后在下面创建一个test_api.py的文件

# test_api.py

import pytest
import requests


def test_01():
    response = requests.get('http://127.0.0.1:5000/login').json()
    print(response)
    assert response.get('success') == 'ok'

if __name__ == '__main__':
    pytest.main()

直接运行,结果如下

============================= test session starts =============================
platform win32 -- Python 3.7.1, pytest-6.2.1, py-1.10.0, pluggy-0.13.1
rootdir: D:\study\api-test
plugins: allure-pytest-2.8.31, dependency-0.5.1, forked-1.3.0, ordering-0.6, rerunfailures-9.1.1, xdist-2.2.1collected 1 item

test_api.py .{'success': 'ok', 'token': 'sdkhasgdhgasjhdgasgda'}
                                                            [100%]

============================== 1 passed in 0.16s ==============================
Process finished with exit code 0

一个简单的测试用例就完成了。

自动化测试工作中,往往会有很多测试文件,每次都需要导入 requests 库吗?

域名都是写在用例一起吗?

如果要记录日志,每次都在用例里面记录吗?

测试数据也写在用例里吗?

等等,答案显然是否定的,下面就让我们一起踏上框架封装之路。

首先我们创建一个包:base,用于存放最基础的封装方法,在包下创建一个模块http_client.py,此处用于封装 requests 发送请求的方法。

封装思路:

  • 创建 HttpClient 类,方便后续 api 继承后直接调用类下面的 get 和 post 方法
  • 创建__request 私有方法,作为发送请求公共方法,方便后面日志搜集请求信息和返回信息
  • 使用 requests.session(),requests 库的 session 会话对象可以跨请求保持某些参数
# base/http_client.py

import requests


class HttpClient():

    def __init__(self):
        self.__session = requests.session()

    def get(self, path, **kwargs):
        return self.__request(path, 'GET', **kwargs)

    def post(self, path, data=None, json=None, **kwargs):
        return self.__request(path, 'POST', data, json, **kwargs)

    def __request(self, url, method, data=None, json=None, **kwa
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值