2020-11-10 13:06:48 +08:00
# TestableMock
2020-10-25 14:24:21 +08:00
2020-11-22 22:12:51 +08:00
换种思路写Mock, 让单元测试更简单。
2020-10-25 14:24:21 +08:00
2020-12-20 19:02:28 +08:00
无需初始化, 不挑测试框架, 甭管要换的是私有方法、静态方法、构造方法还是其他任何类的任何方法, 也甭管要换的对象是怎么创建的。写好Mock定义, 加个`@MockMethod`注解,一切统统搞定。
2020-11-22 22:12:51 +08:00
2020-12-22 14:54:08 +08:00
- 文档: https://alibaba.github.io/testable-mock/
2021-01-02 16:23:57 +08:00
- 国内文档镜像: http://freyrlin.gitee.io/testable-mock/ (内容延迟问题已解决)
2020-12-23 08:45:53 +08:00
阅读[这里](https://mp.weixin.qq.com/s/KyU6Eu7mDkZU8FspfSqfMw)了解更多故事。
2020-10-25 14:24:21 +08:00
2020-12-29 13:18:06 +08:00
> 特别说明
2020-12-31 07:30:21 +08:00
> 1. 如有遇到启动报空指针异常或"Operand stack overflow"错误,请升级`TestableMock`版本, 这是BUG, 已修复😛
2020-12-29 13:18:06 +08:00
> 2. 如遇到"Attempt to access none-static member in mock method"错误,参见[常见问题](https://alibaba.github.io/testable-mock/#/zh-cn/doc/frequently-asked-questions)第8条
2021-01-02 11:10:44 +08:00
> 3. 如果有遇到其他任何使用问题和建议,请直接在[Issue](https://github.com/alibaba/testable-mock/issues)中提出,也可通过[Pull Request](https://github.com/alibaba/testable-mock/pulls)提交您的代码, 我们将在24小时内回复并处理
2020-12-29 13:18:06 +08:00
2020-12-29 15:29:17 +08:00
-----
2021-01-02 11:10:44 +08:00
## 版本计划
`TestableMock` 正在持续迭代演进,以下版本计划可能在开发过程中发生调整,请以最新内容为准
- `0.4.x` 当前版本,进行中的工作内容参考[Issue](https://github.com/alibaba/testable-mock/issues)清单
- `0.5` 实现以"Mock方法集"为单元的Mock方法复用机制, 让测试类之间可以方便复用相同的Mock方法
- `0.6` 实现第四项单元测试增强能力"万能入参构造器"。不论被测方法所需的参数结构多么错综复杂、甚至没有合适的构造方法、甚至需要私有内部类对象... 呼唤TestableMock, 马上递给您~
2020-10-25 14:24:21 +08:00
## 目录结构
```bash
2020-12-08 16:22:14 +08:00
|-- testable-parent ➜ 提供各子模块的公共父pom文件
2020-12-08 15:51:51 +08:00
|-- testable-all ➜ 依赖聚合,便于一次性引用所有子模块功能
|-- testable-processor ➜ 编译期代码预处理模块,提供测试辅助功能
|-- testable-agent ➜ JavaAgent模块, 提供Mock测试相关功能
|-- testable-core ➜ 基础功能模块, 提供Mock相关注解和工具类
|-- testable-maven-plugin ➜ Maven插件模块, 用于简化JavaAgent注入
2020-10-25 14:24:21 +08:00
|-- demo
| |-- java-demo ➜ Java语言的示例代码
| `-- kotlin-demo ➜ Kotlin语言的示例代码
`-- docs ➜ 项目使用文档
```
## 构建项目
主项目使用JDK 1.6+和Maven 3+版本构建,其中`demo`子项目需要JDK 1.8+版本。
```bash
2020-11-04 11:48:07 +08:00
mvn clean install
2020-10-25 14:24:21 +08:00
```
2020-11-22 22:12:51 +08:00
## 本地生成文档
```bash
docsify serve docs
```
2020-12-12 08:42:08 +08:00
> TestableMock文档使用`docsify`工具生成,构建前请安装[nodejs](https://nodejs.org/en/download/)运行时,并使用`npm install -g docsify`命令安装文档生成工具。
2020-11-22 22:12:51 +08:00