testable-mock/README.md
2021-02-01 23:49:16 +08:00

2.5 KiB
Raw Blame History

TestableMock

换种思路写Mock让单元测试更简单。

无需初始化不挑测试框架甭管要换的是私有方法、静态方法、构造方法还是其他任何类的任何方法也甭管要换的对象是怎么创建的。写好Mock定义加个@MockMethod注解,一切统统搞定。

阅读这里了解更多故事。

特别说明

  1. 如遇到"Attempt to access non-static member in mock method"错误,参见常见问题第8条
  2. 如果有遇到其他任何使用问题和建议,请直接在Issue中提出,也可通过Pull Request提交您的代码我们将在24小时内回复并处理

版本计划

TestableMock正在持续迭代演进,以下版本计划可能在开发过程中发生调整

  • 0.4 当前版本,进行中的工作内容参考Issue清单
  • 0.5 实现以"独立Mock类"为单元的Mock方法复用机制让测试类之间可以方便复用相同的Mock方法
  • 0.6 实现将Mock方法的默认生效范围缩小至当前被测类避免Mock方法在测试类之间相互影响
  • 1.0 功能稳定,一个崭新的开始

目录结构

|-- testable-parent       ➜ 提供各子模块的公共父pom文件
|-- testable-all          ➜ 依赖聚合,便于一次性引用所有子模块功能
|-- testable-processor    ➜ 编译期代码预处理模块,提供测试辅助功能
|-- testable-agent        ➜ JavaAgent模块提供Mock测试相关功能
|-- testable-core         ➜ 基础功能模块提供Mock相关注解和工具类
|-- testable-maven-plugin ➜ Maven插件模块用于简化JavaAgent注入
|-- demo
|   |-- java-demo         ➜ Java语言的示例代码
|   `-- kotlin-demo       ➜ Kotlin语言的示例代码
`-- docs                  ➜ 项目使用文档

构建项目

主项目使用JDK 1.6+和Maven 3+版本构建,其中demo子项目需要JDK 1.8+版本。

mvn clean install

本地生成文档

docsify serve docs

TestableMock文档使用docsify工具生成,构建前请安装nodejs运行时,并使用npm install -g docsify命令安装文档生成工具。