python+requests 搭建接口自动化测试框架【超详细】

🍅 点击文末小卡片,免费获取软件测试全套资料,资料在手,涨薪更快    

一、前言

Python是一种简单易学、功能强大的编程语言,广泛应用于各种软件开发和测试场景中。requests是Python中流行的HTTP库,支持发送HTTP请求和处理HTTP响应,它也是开发API自动化测试框架的重要组件之一。在本文中,我们将介绍如何使用Python和requests构建一个简单的接口自动化测试框架,并通过实例来详细说明其具体实现方法。

二、环境准备

在开始构建接口自动化测试框架之前,我们需要安装必要的工具和库,包括Python、requests、pytest等。以下是几个基本步骤:

下载并安装Python3.x版本。

使用pip命令安装requests和pytest库,例如:

pip install requests
pip install pytest

安装其他必需的库和插件,例如pytest-html、pytest-xdist等。

三、设计框架结构

接口自动化测试框架的设计需要考虑多种因素,例如测试目标、测试需求、测试用例设计、代码复用性等。以下是一个简单的框架结构示例:

- api_tests/
    - base.py
    - conftest.py
    - testcases/
        - test_login.py
        - test_order.py
    - utils/
        - config.py
        - logger.py
        - request.py

其中,api_tests是项目的根目录,base.py是基础测试用例类,conftest.py是Pytest的配置文件,testcases是测试用例目录,utils是工具类目录。

四、实现框架功能

接下来,我们将使用Python和requests等库实现框架的具体功能,包括配置管理、日志记录、请求封装、测试用例设计等。以下是一些关键的实现步骤:

配置管理:我们可以创建一个config.py文件,定义应用程序的配置信息,例如URL、用户名、密码等。同时,我们可以使用Python中的configparser库来读取配置信息,并在测试用例中进行引用。例如:

import configparser
 
config = configparser.ConfigParser()
config.read('config.ini')
 
url = config.get('app', 'url')
username = config.get('app', 'username')
password = config.get('app', 'password')

日志记录:我们可以创建一个logger.py文件,定义日志记录器,以记录测试过程中的关键事件和错误信息。例如:

import logging
 
logging.basicConfig(level=logging.DEBUG,
                    format='%(asctime)s - %(name)s - %(levelname)s - %(message)s')
logger = logging.getLogger(__name__)

请求封装:我们可以创建一个request.py文件,封装requests库的HTTP方法,提供统一的请求接口和响应处理。例如:

import requests
 
def get(url, params=None, headers=None):
    response = requests.get(url, params=params, headers=headers)
    return response
 
def post(url, data=None, json=None, headers=None):
    response = requests.post(url, data=data, json=json, headers=headers)
    return response

测试用例设计:我们可以创建多个测试用例,并使用Pytest进行管理和执行。例如:

import pytest
from utils.config import url, username, password
from utils.request import post
 
@pytest.mark.order
def test_login():
    data = {'username': username, 'password': password}
    response = post(url+'/api/login', json=data)
    assert response.status_code == 200
 
@pytest.mark.order
def test_order():
    headers = {'Authorization': 'Bearer '+token}
    response = get(url+'/api/order/123', headers=headers)
    assert response.status_code == 200

五、执行测试用例

完成了接口自动化测试框架的开发后,我们可以使用以下命令来执行测试用例:

pytest -s -v --html=report.html --self-contained-html --workers=4

其中,-s选项表示输出所有print语句;-v选项表示详

细输出测试结果;--html选项表示生成HTML格式的测试报告;--self-contained-html选项表示将测试报告中的所有资源文件都包含在一个文件中,方便查看和分享;--workers选项表示使用多线程运行测试用例。

执行完测试用例后,我们可以在测试报告中查看测试结果和日志信息,以评估接口的正确性和性能等指标。同时,我们也可以对测试框架进行优化和扩展,例如添加数据驱动、参数化测试、前置条件等功能,以提高测试效率和质量。

六、总结

Python和requests是构建接口自动化测试框架的重要组件之一,它们具有易于学习和使用、功能强大和灵活等优点。通过合理设计框架结构和实现关键功能,我们可以快速搭建一个简单且高效的接口自动化测试框架。在实际应用中,我们需要根据项目需求和团队技能等因素选择适当的工具和方法,并遵循最佳实践来确保测试质量和可持续性。同时,我们也可以在测试过程中添加断言、异常处理、测试装置等功能,以提高测试用例的可靠性和稳定性。例如,在实际应用中,我们通常需要验证HTTP响应状态码、响应头、响应内容等指标,通过使用Pytest框架提供的assert语句,可以方便地进行断言操作,例如:

response = requests.get('https://api.github.com')
assert response.status_code == 200
assert response.headers['content-type'] == 'application/json; charset=utf-8'

此外,在编写测试用例时,我们还可以使用数据驱动和参数化测试等技术来快速生成多个测试用例,并对测试用例进行组合和分组。例如,我们可以创建一个data.csv文件,定义多个测试数据,并通过pytest.mark.parametrize注解来引用数据,并自动生成多个测试用例。例如:

import pytest
import csv
from utils.request import post
 
@pytest.mark.parametrize('username, password', csv.reader(open('data.csv')))
def test_login(username, password):
    data = {'username': username, 'password': password}
    response = post(url+'/api/login', json=data)
    assert response.status_code == 200

总之,Python和requests提供了强大而灵活的工具和库,可以帮助我们构建简单且高效的接口自动化测试框架。通过合理设计框架结构和实现关键功能,我们可以快速编写测试用例、执行测试过程,并生成高质量的测试报告,以评估接口的正确性和性能等指标。同时,我们也可以使用最佳实践和常见技巧来优化测试过程和提高测试效率和质量。

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!凡事要趁早,特别是技术行业,一定要提升技术功底。

  • 10
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值