https://github.com/alibaba/testable-mock
换种思路写Mock,让单元测试更简单
https://github.com/alibaba/testable-mock
mock unittest
Last synced: 9 months ago
JSON representation
换种思路写Mock,让单元测试更简单
- Host: GitHub
- URL: https://github.com/alibaba/testable-mock
- Owner: alibaba
- License: mit
- Created: 2020-11-10T03:06:47.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2023-05-17T11:09:55.000Z (over 2 years ago)
- Last Synced: 2025-04-14T06:02:01.783Z (9 months ago)
- Topics: mock, unittest
- Language: Java
- Homepage: https://alibaba.github.io/testable-mock/
- Size: 1.49 MB
- Stars: 1,840
- Watchers: 35
- Forks: 307
- Open Issues: 67
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-java - TestableMock
README
# TestableMock
换种思路写Mock,让单元测试更简单。
无需初始化,不挑服务框架,甭管要换的是私有方法、静态方法、构造方法还是其他任何类的任何方法,也甭管要换的对象是怎么创建的。写好Mock定义,加个`@MockInvoke`注解,一切统统搞定。
- 文档:https://alibaba.github.io/testable-mock/
- 国内文档镜像:http://freyrlin.gitee.io/testable-mock/
阅读[这里](https://mp.weixin.qq.com/s/KyU6Eu7mDkZU8FspfSqfMw)了解更多故事。
**0.7版本已发布**,从`0.6.x`升级到`0.7.x`版本请参考[版本升级指南](https://alibaba.github.io/testable-mock/#/zh-cn/doc/upgrade-guide)
-----
## 项目维护说明
由于当前并行项目较多,此项目暂时转入维护阶段,在此期间`TestableMock`会继续提供不定期的版本更新。
如果有遇到其他任何使用问题和建议,请直接在[Issues](https://github.com/alibaba/testable-mock/issues)中提出,也可通过[Pull Request](https://github.com/alibaba/testable-mock/pulls)提交您的代码,我们将尽快回复并处理。
## 目录结构
```bash
|-- testable-parent ➜ 提供各子模块的公共父pom文件
|-- testable-all ➜ 依赖聚合,便于一次性引用所有子模块功能
|-- testable-processor ➜ 编译期代码预处理模块,提供测试辅助功能
|-- testable-agent ➜ JavaAgent模块,提供Mock测试相关功能
|-- testable-core ➜ 基础功能模块,提供Mock相关注解和工具类
|-- testable-maven-plugin ➜ Maven插件模块,用于简化JavaAgent注入
|-- tool ➜ 项目开发过程中的工具脚本
|-- demo
| |-- java-demo ➜ Java语言的示例代码
| |-- kotlin-demo ➜ Kotlin语言的示例代码
| |-- android-demo ➜ Android项目的示例代码
| `-- spock-demo ➜ Spock测试框架的示例代码
`-- docs ➜ 项目使用文档
```
## 构建项目
主项目使用JDK 1.6+和Maven 3+版本构建,其中`demo`子项目需要JDK 1.8+版本。
```bash
mvn clean install
```
## 本地生成文档
```bash
docsify serve docs
```
> TestableMock文档使用`docsify`工具生成,构建前请安装[nodejs](https://nodejs.org/en/download/)运行时,并使用`npm install -g docsify`命令安装文档生成工具。