单测原则与实践

  1. Definition of Done = 单测全部通过

    任何代码(无论函数、方法、模块还是完整业务流程)只有在对应的单元测试全部通过后,才算真正"写完"。没有测试就无法验证功能完整性,也就谈不上交付。

  2. 最小粒度:函数 / 方法

    • 判定标准:该函数的单元测试是否覆盖所有分支并通过。
    • 若测试无法编写或执行失败,则说明实现仍不完整。
  3. 向上扩展:模块 / Service / 业务流程

    • 每个模块或 Service 同样必须有专属测试用例。
    • 这部分测试应聚焦业务规则,而绝不能直接依赖外部 IO(数据库、Nacos、Redis、Kafka 等)。
  4. 业务层测试禁止真实 IO,全部 Mock

    • 通过接口(Port)和 Mock/Stub 隔离外部依赖。
    • 开发者不需要在本地安装任何数据库或中间件,就能完成业务逻辑的编写与回归。
  5. 基础设施层测试才连接真实依赖

    • 只有实现 Nacos、Kafka、数据库等适配器的人,才需要在本地或 CI 中启动对应服务并写集成测试。
    • 例如开发 Nacos 适配器时,需要起一个真的 Nacos;写 Kafka 适配器时,只需要 Kafka。
  6. 开发环境最小化,测试环境全量化

    • 业务开发者的设备上可以 零中间件
    • 基础设施开发者只装自己负责的那一个依赖;
    • 只有在集成 / 冒烟测试环境(或 CI Pipeline 的后置阶段)才会拉起全部依赖,做端到端验证。
  7. 如果无法做到"业务单测不依赖 IO"

    • 说明当前代码结构或分层设计有缺陷,需要调整:

      • 把 IO 逻辑下沉到基础设施层;
      • 通过接口抽象暴露给业务层;
      • 在业务测试里用 Mock 替代真实实现。

Pomelo_刘金 按以上规则执行,可以显著降低环境配置成本、加快反馈循环,并确保业务逻辑和基础设施可以由不同成员并行开发而互不干扰。

相关推荐
qq_12498707531 分钟前
基于springboot的鸣珮乐器销售网站的设计与实现(源码+论文+部署+安装)
java·spring boot·后端·spring·毕业设计·计算机毕业设计
海南java第二人2 分钟前
SpringBoot核心注解@SpringBootApplication深度解析:启动类的秘密
java·spring boot·后端
百度地图汽车版13 分钟前
【智图译站】基于异步时空图卷积网络的不规则交通预测
前端·后端
qq_124987075317 分钟前
基于Spring Boot的“味蕾探索”线上零食购物平台的设计与实现(源码+论文+部署+安装)
java·前端·数据库·spring boot·后端·小程序
开心就好202528 分钟前
Python爬虫基础:HTTP和HTTPS协议的请求与响应过程详解
后端
悟能不能悟31 分钟前
springboot怎么将事务设置为pending,等另外一个请求ok了,再做commit
spring boot·后端
benpaodeDD33 分钟前
黑马SpringBoot2自动配置原理
java·spring boot·后端
用户26851612107561 小时前
GMP 调度器深度学习笔记
后端·go
J_liaty1 小时前
SpringBoot深度解析i18n国际化:配置文件+数据库动态实现(简/繁/英)
spring boot·后端·i18n
牧小七1 小时前
springboot 配置访问上传图片
java·spring boot·后端