当前位置: 首页 > news >正文

聊一聊接口测试时遇到上下游依赖时该如何测试

目录

一、手工测试时的处理方法

1.1沟通协调法

1.2模拟数据法

二、自动化测试时的处理方法

2.1 数据关联法(变量提取)

2.2 Mock数据法

2.3自动化框架中的依赖管理

三、实施示例(以订单接口测试为例)

3.1Mock依赖接口:

3.2前置数据准备:​​​​​​​

3.3数据库直接操作:​​​​​​​

四、关键注意事项


在我们进行接口测试时,运行某个接口有的时候无法单独完成,总会用到上下游依赖,就像有一个订单系统,创建订单的接口可能依赖于用户信息和库存信息。用户信息可能来自用户服务,库存信息来自库存服务。这时候测试订单接口,就需要这些依赖的服务返回正确的数据,否则测试可能失败或者不准确。

如果这些依赖的服务在测试环境中不可用,或者数据不稳定,该怎么办呢?比如,用户服务可能因为维护无法访问,或者库存服务的数据被其他测试用例修改,导致库存数量变化,影响订单接口的测试结果。

可以模拟这些依赖的服务,也就是使用Mock或者Stub。这样,在测试订单接口的时候,不调用真实的用户服务和库存服务,而是用模拟的数据代替。这样可以避免依赖服务不可用的问题,也能控制返回的数据,确保测试的稳定性和可重复性。

一、手工测试时的处理方法

1.1沟通协调法

核心思路:通过与开发团队沟通,明确上下游接口的数据流转逻辑和依赖关系。

具体步骤:

了解依赖关系:明确上游接口生成哪些关键数据(如订单号、Token、用户ID等),下游接口需要哪些参数。

手动调用上游接口:通过工具(如Postman)先调用上游接口,记录其返回的依赖数据。

传递数据到下游接口:将上游接口返回的数据手动填入下游接口的请求参数中进行测试。

示例:

电商系统中,先调用“用户下单接口”生成订单号,再将该订单号填入“订单查询接口”的请求参数中进行测试。

1.2模拟数据法

核心思路:当无法直接调用上游接口时,手动构造或通过数据库操作生成模拟数据。

具体步骤:

直接操作数据库:在测试数据库中插入或更新下游接口所需的模拟数据(如订单号、用户ID)。

使用工具生成数据:利用工具(如Postman的预请求脚本、数据库工具)生成符合格式要求的模拟数据。

示例:

银行系统中,若无法调用“开户接口”,可在数据库中手动插入一个账户编号,直接用于“账户查询接口”的测试。

二、自动化测试时的处理方法

2.1 数据关联法(变量提取)

核心思路:通过自动化工具提取上游接口返回的数据,并将其存储为变量供下游接口使用。

工具示例:

Postman:

使用 Tests 脚本提取上游接口返回的JSON数据(如订单号),并存储为环境变量:​​​​​​​

pm.test("Extract Order ID", function () {    pm.response.json().order_id;    pm.environment.set("order_id", pm.response.json().order_id);});

在下游接口中直接引用变量:{{order_id}}。

Python(requests库):​​​​​​​

import requests# 调用上游接口获取订单号response_upstream = requests.post("https://api.example.com/create_order")order_id = response_upstream.json()["order_id"]# 将订单号传递给下游接口payload = {"order_id": order_id}response_downstream = requests.get("https://api.example.com/query_order", params=payload)

2.2 Mock数据法

核心思路:模拟上游接口的响应数据,避免因上游接口未完成或不可用导致测试阻塞。

工具与实现:​​​​​​​

MockServer/WireMock:定义模拟响应规则,例如:// 模拟用户登录接口返回TokenMockServerClient mockServer = new MockServerClient("localhost", 1080);mockServer.when(    request().withPath("/login"),    Times.unlimited()).respond(    response().withBody("{\"token\": \"mock_token_123\"}"));

Flask简易Mock服务:​​​​​​​

from flask import Flask, jsonifyapp = Flask(__name__)@app.route('/mock_data', methods=['GET'])def mock_data():    return jsonify({"user_id": "U123456"})if __name__ == '__main__':    app.run(port=5000)

2.3自动化框架中的依赖管理

核心思路:在测试框架中通过代码逻辑处理依赖关系,确保接口调用顺序和数据传递。

实现方式:

测试用例依赖标记:在测试用例中声明依赖关系(如Excel/数据库中记录依赖的Case ID)。

动态参数注入:通过代码提取依赖数据并注入到下游接口的请求参数中。​​​​​​​

#示例代码(Python):class TestOrderAPI:    def test_create_order(self):        # 调用上游接口,获取订单号        response = requests.post("/create_order")        self.order_id = response.json()["order_id"]    def test_query_order(self):        # 使用上游接口返回的订单号        response = requests.get(f"/query_order?order_id={self.order_id}")        assert response.status_code == 200

三、实施示例(以订单接口测试为例)

场景:测试创建订单接口,依赖用户服务和库存服务。

步骤:

3.1Mock依赖接口:​​​​​​​

# 使用requests-mock模拟用户服务返回200及用户数据def test_create_order(mocker):    mocker.get("http://user-service/user/123", json={"id": 123, "name": "test_user"})    mocker.post("http://inventory-service/reserve", json={"success": True})    # 调用订单接口并断言响应

3.2前置数据准备:​​​​​​​

# 测试前通过API创建用户和设置库存POST /users { "name": "test_user" } → 获取userId=123PUT /inventory/itemA { "quantity": 10 }# 执行订单测试POST /orders { "userId": 123, "item": "itemA" }# 测试后删除数据DELETE /users/123

3.3数据库直接操作:​​​​​​​

-- 测试前插入数据INSERT INTO users (id, name) VALUES (123, 'test_user');UPDATE inventory SET quantity = 10 WHERE item = 'itemA';-- 执行测试后删除DELETE FROM orders WHERE user_id = 123;DELETE FROM users WHERE id = 123;

四、关键注意事项

数据隔离:确保每个测试用例使用独立数据,避免并行测试冲突。

异常覆盖:通过Mock模拟依赖服务的异常响应(如500错误、超时),验证接口容错逻辑。

自动化清理:集成测试框架的setup/teardown机制,自动创建和清理数据。

环境策略:单元/组件测试优先使用Mock,提升速度;集成测试结合真实服务与Fake Service,验证流程正确性。

相关文章:

  • Spring Boot项目信创国产化适配指南
  • 前沿科技:社会性交互技术原理与核心概念解析
  • docker快捷打包脚本(ai版)
  • Java中的列表(List):操作与实现详解
  • java基础 迭代Iterable接口以及迭代器Iterator
  • 【开题报告+论文+源码】基于springboot的教师评价系统的设计与实现
  • S130N-ISI 全栈方案与云平台深度协同:重构 PLC 开发新范式
  • 设计模式 --- 观察者模式
  • 计算机网络 实验二 VLAN 的配置与应用
  • 【回眸】Linux 内核 (十四)进程间通讯 之 信号量
  • RAGFlow 本地知识库 环境配置
  • java开发环境搭建
  • 关于weaviate的关键词和向量搜索优劣
  • react实现鼠标悬停在SVG地图上某个区域时,其上方呈现柱形图
  • docker部署jenkins并成功自动化部署微服务
  • Linux: network :创建raw socket的时候
  • [GN] sigrokdecode 模块
  • 【Java面试系列】Spring Boot中自动配置原理与自定义Starter开发实践详解 - 3-5年Java开发必备知识
  • Python第七章10:异常、模块、包的综合案例
  • 【组件封装-优化】vue+element plus:二次封装select组件,实现下拉列表有分页、自定义是否可搜索的一系列功能
  • 如今做知乎类网站怎么样/百度网络营销的概念
  • 做商城网站要哪些流程/百度广告联盟平台的使用知识
  • 怎么查看网站死链/搜索引擎优化工作
  • 上海智能网站建设设计/咸宁网站seo
  • 上海网站论坛建设/seo优化排名技术百度教程
  • 东莞做微网站建设/网站建设山东聚搜网络