0

0

Pact JVM:为可选数组字段(null 或非空)编写弹性响应契约测试

心靈之曲

心靈之曲

发布时间:2026-02-06 08:55:59

|

155人浏览过

|

来源于php中文网

原创

Pact JVM:为可选数组字段(null 或非空)编写弹性响应契约测试

在 pact jvm 中,当 api 响应中某个字段可能为 `null` 或一个非空数组(如 `contents: null` 或 `contents: [...]`)时,无法通过单个 `pactdsljsonbody` 表达“或”逻辑;正确做法是为两种值态分别定义独立的交互契约测试用例。

Pact 的核心设计哲学强调契约的确定性与可验证性——它不支持运行时模糊匹配(如 or(null, eachLike(...))),因为这会削弱契约对提供方行为的精确约束力。尽管 PactDslJsonBody.or() 方法存在,但它仅用于并列的、结构完全一致的可选值类型(例如 stringType("status") 或 integerType("status")),不适用于混合类型场景(如 null vs. array of objects),且 Pact V3 规范本身禁止在单个交互中对同一路径声明歧义性匹配。

因此,针对 contents 字段可能为 null 或非空数组的场景,必须采用双契约模式:为同一请求路径(如 GET /item?name=item-1)注册两个独立的 Interaction,分别描述两种合法响应形态:

Motiff
Motiff

Motiff是由猿辅导旗下的一款界面设计工具,定位为“AI时代设计工具”

下载
// Case 1: contents is null
builder
  .given("Item 'item-1' has no contents")
  .uponReceiving("a request for item-1 with null contents")
  .path("/item")
  .query("name=item-1")
  .method("GET")
  .willRespondWith(200)
  .body(new PactDslJsonBody()
    .object("metadata")
      .stringValue("name", "item-1")
      .integerType("index", 1)
      .nullValue("contents") // ✅ 显式声明为 null
    .closeObject()
  );
// Case 2: contents is a non-empty array
builder
  .given("Item 'item-1' has contents")
  .uponReceiving("a request for item-1 with populated contents")
  .path("/item")
  .query("name=item-1")
  .method("GET")
  .willRespondWith(200)
  .body(new PactDslJsonBody()
    .object("metadata")
      .stringValue("name", "item-1")
      .integerType("index", 1)
      .eachLike("contents") // ✅ 使用 eachLike 描述数组元素结构
        .stringType("param")
        .stringType("value")
      .closeArray()
    .closeObject()
  );
⚠️ 关键注意事项:两个交互必须具有唯一且语义清晰的 uponReceiving 描述,便于提供方理解上下文;given 状态(如 "Item 'item-1' has no contents")需在提供方测试中被真实模拟(例如通过 WireMock stub 或数据库预置),确保其能返回对应形态;对于 120 个 item,可通过参数化循环生成这两组交互(推荐使用 JUnit 5 @ParameterizedTest + @MethodSource),避免硬编码冗余;切勿尝试用 regexType() 或 booleanType() 替代 nullValue() —— Pact 不允许对 null 进行类型通配,nullValue("contents") 是唯一合规方式。

这种模式看似增加测试数量,实则提升了契约的可读性、可调试性与提供方实现的明确性。Pact 报告将清晰指出:“当状态为 X 时,期望 contents 为 null;当状态为 Y 时,期望 contents 为符合 schema 的数组”,从而真正驱动前后端就边界条件达成共识。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
软件测试常用工具
软件测试常用工具

软件测试常用工具有Selenium、JUnit、Appium、JMeter、LoadRunner、Postman、TestNG、LoadUI、SoapUI、Cucumber和Robot Framework等等。测试人员可以根据具体的测试需求和技术栈选择适合的工具,提高测试效率和准确性 。

446

2023.10.13

java测试工具有哪些
java测试工具有哪些

java测试工具有JUnit、TestNG、Mockito、Selenium、Apache JMeter和Cucumber。php还给大家带来了java有关的教程,欢迎大家前来学习阅读,希望对大家能有所帮助。

303

2023.10.23

Java 单元测试
Java 单元测试

本专题聚焦 Java 在软件测试与持续集成流程中的实战应用,系统讲解 JUnit 单元测试框架、Mock 数据、集成测试、代码覆盖率分析、Maven 测试配置、CI/CD 流水线搭建(Jenkins、GitHub Actions)等关键内容。通过实战案例(如企业级项目自动化测试、持续交付流程搭建),帮助学习者掌握 Java 项目质量保障与自动化交付的完整体系。

20

2025.10.24

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

240

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

580

2024.03.01

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

362

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2087

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

352

2023.08.31

1688阿里巴巴货源平台入口与批发采购指南
1688阿里巴巴货源平台入口与批发采购指南

本专题整理了1688阿里巴巴批发进货平台的最新入口地址与在线采购指南,帮助用户快速找到官方网站入口,了解如何进行批发采购、货源选择以及厂家直销等功能,提升采购效率与平台使用体验。

21

2026.02.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.9万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号