testable-mock/README.md
2021-01-02 11:10:44 +08:00

2.8 KiB
Raw Blame History

TestableMock

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

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

阅读这里了解更多故事。

特别说明

  1. 如有遇到启动报空指针异常或"Operand stack overflow"错误,请升级TestableMock版本这是BUG已修复😛
  2. 如遇到"Attempt to access none-static member in mock method"错误,参见常见问题第8条
  3. 如果有遇到其他任何使用问题和建议,请直接在Issue中提出,也可通过Pull Request提交您的代码我们将在24小时内回复并处理

版本计划

TestableMock正在持续迭代演进,以下版本计划可能在开发过程中发生调整,请以最新内容为准

  • 0.4.x 当前版本,进行中的工作内容参考Issue清单
  • 0.5 实现以"Mock方法集"为单元的Mock方法复用机制让测试类之间可以方便复用相同的Mock方法
  • 0.6 实现第四项单元测试增强能力"万能入参构造器"。不论被测方法所需的参数结构多么错综复杂、甚至没有合适的构造方法、甚至需要私有内部类对象... 呼唤TestableMock马上递给您~

目录结构

|-- 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命令安装文档生成工具。