8.如何实现多环境下的接口测试

我是山茶,一个探索AI+测试的程序员!

一、多环境接口测试实现的核心

实现多环境下的接口测试的核心 "在请求之前,对请求的url进行替换"

实现这一核心主要的步骤可以分为

  1. 需要二次封装requests,对请求进行定制化。

  2. 将请求的结构体的ur从一个写死的ip地址改为一个(任意的)域名。

  3. 使用一个 env 配置文件,存放各个环境的配置信息。

  4. 然后将请求结构体中的url替换为env配置文件中个人选择的url。

  5. 将env 配置文件使用yaml 进行管理。

每个步骤看起来挺简单的,但是要实施起来要做很多事情

二、实现多环境测试按步

json 复制代码
使用代码编写一个本地接口:http://127.0.0.1:8080/shancha/test_one

接口返回内容为{"name":"山茶","公众号":"程序员山茶"}
  1. 二次封装requests,对请求进行定制化

基础请求方法实现:

python 复制代码
# 一、设定基础 

# 1.引入requests模块
# 2.设计Api类
# 3.类中增加send方法,方法设定data传入参数,data为字典类型
# 4.send方法中通过requests.request()方法发送请求,request()中传入对应参数,字典key的方式获取

import requests

class Api:
    def send(self, data:dict):

        res = requests.request(method=data["method"], url=data["url"], headers=data["headers"])
        return res
        
 # 二、设定测试类
 # 1.设计TestApi类
 # 2.编写测试方法test_send(self)
 # 3.方法中通过对象引入测试方法
 # 4.设定参数data
 
 from InterfaceTestingDifferentEnv import ApiDemo

class TestApi:
    data = {
        "method": "get",
        "url": "http://127.0.0.1:8080/shancha/test_one",
        "headers": None
    }

    def test_send(self):
        api = ApiDemo.Api()
        print(api.send(self.data).text)

执行结果显示与预期结果一直

  1. 将请求的结构体的ur从一个写死的ip地址改为一个(任意的)域名

在改写参数时我们可以使用代码中的replace来替换对应url数据

kotlin 复制代码
# 修改原方法中代码块,增加第四行以及第五行数据,执行查看结果
def send(self, data:dict):

    data["url"] = str(data["url"]).replace("127.0.0.1","test_code")
    print(data["url"])
    res = requests.request(method=data["method"], url=data["url"], headers=data["headers"])
    return res

如图所示,对应的域名已经被替换为"test_code"

通过这种方式我们能够将对应的url替换为任意的环境,但是这种方式还是相对来讲较为传统,有一个明显的缺点,每执行一次,就要调整一次代码

  1. 使用一个 env 配置文件,并将请求中的url替换为 env 配置文件中选择的url

为解决第2点这个问题,我们可以将环境配置信息整合为一个env配置文件,通过调用配置的方式来替换testcode域名

python 复制代码
# 1.在原请求方法中增加env环境存储信息
# 2.在参数请求前,通过读取env配置的方法将url替换
# 一、请求方法类
import requests

class Api:
    env = {
        "default": "dev",
        "test_other": {
            "dev": "127.0.0.1",
            "test": "127.0.0.2"
        }
    }
    def send(self, data:dict):
        data["url"] = str(data["url"]).replace("testcode", self.env["test_other"][self.env["default"]])
        print("传入的url数据是::"+data["url"])
        res = requests.request(method=data["method"], url=data["url"], headers=data["headers"])
        return res
  
  # 测试类      
from InterfaceTestingDifferentEnv import ApiDemo

class TestApi:

    data = {
        "method": "get",
        "url": "http://testcode:8080/shancha/test_one",
        "headers": None
    }

    def test_send(self):
        api = ApiDemo.Api()
        print(api.send(self.data).text)

注意⚠️:

  • self.env["test_other"][self.env["default"]] 等同于 self.env["test_other"][self.env["dev"]]

点击执行,结果与第一次基础结果一致,且请求url中"testcode"被更换为指定参数,以后每次执行只要修改default内容即可,但相较于只修改配置yaml文件而言,此种方式仍存在问题

  1. 将env 配置文件使用yaml 进行管理

将 env 配置文件真正使用 yaml 数据驱动,实现多环境下的接口测试

为防止手动创建yaml文件出现问题,可以使用代码转换yaml文件

python 复制代码
# 1.创建新类,引入yaml包,打开一个文件,并赋予可写权限
# 2.使用yaml.safe_dump写入数据

import yaml

def test_yaml2():
    env = {
        "default": "dev",
        "test_other": {
            "dev": "127.0.0.1",
            "test": "127.0.0.2"
        }
    }
    with open("env.yaml", "w") as f:
        yaml.safe_dump(data=env, stream=f)

执行后yaml文件创建成功

调用方式修改,直接读取 env.yaml 文件配置

kotlin 复制代码
# 1.直接讲env变量读取修改即可
# 2.后续环境发生改变可以直接修改文件即可

import requests
import yaml


class Api:
    # env = {
    #     "default": "dev",
    #     "test_other": {
    #         "dev": "127.0.0.1",
    #         "test": "127.0.0.2"
    #     }
    # }
    env = yaml.safe_load(open("env.yaml"))
    def send(self, data:dict):
        data["url"] = str(data["url"]).replace("testcode", self.env["test_other"][self.env["default"]])
        print("传入的url数据是::"+data["url"])
        res = requests.request(method=data["method"], url=data["url"], headers=data["headers"])
        return res

与预期结果一致,结果未发生改变,但是执行确实更加便利简介

三、最后

实现在多环境下进行接口测试,同样的测试用例,我们可以选择更加简洁方便的方法来实现,使用配置文件能够解决很多代码修改问题

相关推荐
uhakadotcom几秒前
CVE-2025-25012:Kibana 原型污染漏洞解析与防护
后端·面试·github
uhakadotcom1 分钟前
揭秘ESP32芯片的隐藏命令:潜在安全风险
后端·面试·github
uhakadotcom5 分钟前
Apache Camel 漏洞 CVE-2025-27636 详解与修复
后端·面试·github
uhakadotcom8 分钟前
OpenSSH CVE-2025-26466 漏洞解析与防御
后端·面试·github
uhakadotcom16 分钟前
PostgreSQL的CVE-2025-1094漏洞解析:SQL注入与元命令执行
后端·面试·github
zhuyasen23 分钟前
Go语言开发实战:app库实现多服务启动与关闭的优雅方案
后端·go
ITlinuxP28 分钟前
2025最新Postman、Apipost和Apifox API 协议与工具选择方案解析
后端·测试工具·postman·开发工具·apipost·apifox·api协议
计算机-秋大田1 小时前
基于Spring Boot的宠物健康顾问系统的设计与实现(LW+源码+讲解)
java·vue.js·spring boot·后端·课程设计
uhakadotcom1 小时前
OpenHands:AI 驱动的软件开发框架
后端·面试·github
uhakadotcom1 小时前
FinGPT:金融领域的开源语言模型框架
后端·面试·github