接口自动化之参数快递的几种方式!

2024-06-20 03:20

本文主要是介绍接口自动化之参数快递的几种方式!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 直接在代码中硬编码

这是最简单直接的方式,直接在测试脚本中写入具体的参数值。但这种方法不灵活,难以维护,也不利于数据的复用。

def test_api_request():    response = requests.get("http://example.com/api?param=value")    assert response.status_code == 200

图片

2. 使用变量或列表循环

将参数存储在变量或列表中,通过循环遍历执行测试逻辑,适用于多个相似请求的情况。​​​​​​​

params_list = [{"param": "value1"}, {"param": "value2"}]for params in params_list:    response = requests.get("http://example.com/api", params=params)    assert response.status_code == 200

图片

3. Excel或CSV文件读取

将测试数据存储在Excel或CSV文件中,然后通过Python的pandas或csv模块读取数据,适用于大量或复杂的数据集。​​​​​​​

import pandas as pd# 读取Excel文件dataframe = pd.read_excel("test_data.xlsx")for index, row in dataframe.iterrows():    response = requests.get(f"http://example.com/api?param={row['param']}")    assert response.status_code == 200

图片

4. YAML或JSON配置文件

利用YAML或JSON格式的配置文件来管理测试数据,这些格式易于阅读和编辑,且支持复杂的嵌套结构。​​​​​​​

import jsonwith open("test_data.json") as file:    data = json.load(file)    for item in data["params"]:        response = requests.get(f"http://example.com/api?param={item['param']}")        assert response.status_code == 200

图片

5. 使用测试框架的参数化功能

很多自动化测试框架如pytest、unittest等提供了内置的参数化功能,可以直接将测试函数参数化。

pytest示例​​​​​​​

import pytest@pytest.mark.parametrize("param", ["value1", "value2"])def test_api_with_param(param):    response = requests.get(f"http://example.com/api?param={param}")    assert response.status_code == 200

图片

6. 数据库查询

当测试数据需要实时从数据库获取时,可以通过SQL查询直接在测试脚本中动态获取参数。​​​​​​​

import sqlite3connection = sqlite3.connect("test.db")cursor = connection.cursor()cursor.execute("SELECT param FROM test_data")for row in cursor.fetchall():    response = requests.get(f"http://example.com/api?param={row[0]}")    assert response.status_code == 200

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

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

在这里插入图片描述

这篇关于接口自动化之参数快递的几种方式!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1076963

相关文章

MySQL中时区参数time_zone解读

《MySQL中时区参数time_zone解读》MySQL时区参数time_zone用于控制系统函数和字段的DEFAULTCURRENT_TIMESTAMP属性,修改时区可能会影响timestamp类型... 目录前言1.时区参数影响2.如何设置3.字段类型选择总结前言mysql 时区参数 time_zon

Mybatis官方生成器的使用方式

《Mybatis官方生成器的使用方式》本文详细介绍了MyBatisGenerator(MBG)的使用方法,通过实际代码示例展示了如何配置Maven插件来自动化生成MyBatis项目所需的实体类、Map... 目录1. MyBATis Generator 简介2. MyBatis Generator 的功能3

Python如何使用seleniumwire接管Chrome查看控制台中参数

《Python如何使用seleniumwire接管Chrome查看控制台中参数》文章介绍了如何使用Python的seleniumwire库来接管Chrome浏览器,并通过控制台查看接口参数,本文给大家... 1、cmd打开控制台,启动谷歌并制定端口号,找不到文件的加环境变量chrome.exe --rem

Java后端接口中提取请求头中的Cookie和Token的方法

《Java后端接口中提取请求头中的Cookie和Token的方法》在现代Web开发中,HTTP请求头(Header)是客户端与服务器之间传递信息的重要方式之一,本文将详细介绍如何在Java后端(以Sp... 目录引言1. 背景1.1 什么是 HTTP 请求头?1.2 为什么需要提取请求头?2. 使用 Spr

Python Invoke自动化任务库的使用

《PythonInvoke自动化任务库的使用》Invoke是一个强大的Python库,用于编写自动化脚本,本文就来介绍一下PythonInvoke自动化任务库的使用,具有一定的参考价值,感兴趣的可以... 目录什么是 Invoke?如何安装 Invoke?Invoke 基础1. 运行测试2. 构建文档3.

Python数据处理之导入导出Excel数据方式

《Python数据处理之导入导出Excel数据方式》Python是Excel数据处理的绝佳工具,通过Pandas和Openpyxl等库可以实现数据的导入、导出和自动化处理,从基础的数据读取和清洗到复杂... 目录python导入导出Excel数据开启数据之旅:为什么Python是Excel数据处理的最佳拍档

SpringBoot项目启动后自动加载系统配置的多种实现方式

《SpringBoot项目启动后自动加载系统配置的多种实现方式》:本文主要介绍SpringBoot项目启动后自动加载系统配置的多种实现方式,并通过代码示例讲解的非常详细,对大家的学习或工作有一定的... 目录1. 使用 CommandLineRunner实现方式:2. 使用 ApplicationRunne

VUE动态绑定class类的三种常用方式及适用场景详解

《VUE动态绑定class类的三种常用方式及适用场景详解》文章介绍了在实际开发中动态绑定class的三种常见情况及其解决方案,包括根据不同的返回值渲染不同的class样式、给模块添加基础样式以及根据设... 目录前言1.动态选择class样式(对象添加:情景一)2.动态添加一个class样式(字符串添加:情

MYSQL行列转置方式

《MYSQL行列转置方式》本文介绍了如何使用MySQL和Navicat进行列转行操作,首先,创建了一个名为`grade`的表,并插入多条数据,然后,通过修改查询SQL语句,使用`CASE`和`IF`函... 目录mysql行列转置开始列转行之前的准备下面开始步入正题总结MYSQL行列转置环境准备:mysq

Linux(Centos7)安装Mysql/Redis/MinIO方式

《Linux(Centos7)安装Mysql/Redis/MinIO方式》文章总结:介绍了如何安装MySQL和Redis,以及如何配置它们为开机自启,还详细讲解了如何安装MinIO,包括配置Syste... 目录安装mysql安装Redis安装MinIO总结安装Mysql安装Redis搜索Red