README.md 13.9 KB
Newer Older
EyreFree's avatar
EyreFree 已提交
1 2
<div align="center">    
 <img src="https://javer.oss-cn-shanghai.aliyuncs.com/doraemon/github/DoraemonKit_github.png" width = "150" height = "150" alt="DoraemonKit" align=left />
糕冷羊's avatar
糕冷羊 已提交
3
 <img src="https://img.shields.io/github/license/didi/DoraemonKit.svg" align=left />
J
modify:  
jackjintai 已提交
4
 <img src="https://img.shields.io/badge/Android-3.2.0-blue.svg" align=left />
J
modify:  
jackjintai 已提交
5
 <img src="https://img.shields.io/badge/iOS-3.0.4-yellow.svg" align=left />
J
modify:  
jackjintai 已提交
6
 <img src="https://img.shields.io/badge/miniapp-0.0.1-red.svg" align=left />
糕冷羊's avatar
糕冷羊 已提交
7
 <img src="https://img.shields.io/badge/PRs-welcome-brightgreen.svg" align=left />
Y
yixiang 已提交
8 9
</div>

J
modify:  
jackjintai 已提交
10

Y
yixiang 已提交
11 12 13 14 15
<br/>
<br/>
<br/>
<br/>
<br/>
Y
yixiang 已提交
16 17
<br/>
<br/>
Y
yixiang 已提交
18

J
modify:  
jackjintai 已提交
19 20 21
**DoraemonKit** /'dɔ:ra:'emɔn/,简称`DoKit`,中文名 `哆啦A梦`,意味着能够像哆啦A梦一样提供给他的主人各种各样的工具。Just Do Kit

> [English Readme](README_EN.md)
EyreFree's avatar
EyreFree 已提交
22

J
modify:  
jackjintai 已提交
23
## 社区活动
J
jackjintai 已提交
24

J
modify:  
jackjintai 已提交
25 26
**DoKit官方社区分享季**
你想让你的才华被更多的人关注到吗?快来参加[DoKit官方社区分享季](https://github.com/didi/DoraemonKit/issues/658)活动吧
J
jackjintai 已提交
27

J
modify:  
jackjintai 已提交
28 29
**DoKit调研问卷**
亲爱的DoKit用户,动动你的小手指参与一下我们的官方调研活动吧。我们极度渴望听到你们的声音:
J
jackjintai 已提交
30

J
modify:  
jackjintai 已提交
31
链接:https://page.juyanwenjuan.com/jy_0CMpJzlu.html
J
jackjintai 已提交
32 33 34 35

<div align="center">    
  <img src="https://pt-starimg.didistatic.com/static/starimg/img/INLjGkp9wN1597062733948.jpg" width = "250" alt="DoKit 首页效果演示" align=center />
</div>
Y
yixiang 已提交
36

J
modify:  
jackjintai 已提交
37 38 39 40 41 42 43 44 45 46 47 48 49 50
## 外部合作

**2020中国开源年会DoKit社区合作伙伴**
[2020中国开源年会(COSCon’20)再启程:开源向善(Open Source for Good)](https://mp.weixin.qq.com/s/kgBsRZd1N3uOCX2NeSvqGQ)

[COSCon’20 讲师征集令](https://mp.weixin.qq.com/s/uAGG8o4IcAk69hFzKY98IQ) 

[COSCon’20 志愿者招募正式启动](https://mp.weixin.qq.com/s/gGlzZV_xJnsBuSc2HGh7Uw) 

[2020中国开源年会暨阿帕奇中国路演 社区合作伙伴征集令](https://mp.weixin.qq.com/s/PJq6QYp7ahIIzX4GrOQ88g) 

[百格网报名链接](https://www.bagevent.com/event/6840909)

<img src="https://pt-starimg.didistatic.com/static/starimg/img/hoEGfdsUzi1600745052153.jpg" alt="图片替换文本" width="200"  align="bottom" />
EyreFree's avatar
EyreFree 已提交
51

J
modify:  
jackjintai 已提交
52 53 54 55 56 57 58 59 60 61 62 63
## 开发背景

每一个稍微有点规模的 App,总会自带一些线下的测试功能代码,比如环境切换功能、帧率查看功能等等,这些功能的切换入口往往放在各式各样的入口中,比如一些特殊的手势,双击 statusBar,双击某一个功能区块,或者新建一个 keyWindow 始终至于 App 最上方等等,而且每一个 App 里面的线下附带功能模块很多是相似的,比如帧率查看、内存和 CPU 监控等等,但是现在基本上都是每个 App 都是自己实现了一份,经历了以上的问题之后,DoraemonKit 就有了它存在的意义。

DoraemonKit 是一个功能平台,能够让每一个 App 快速接入一些常用的或者你没有实现的一些辅助开发工具、测试效率工具、视觉辅助工具,而且能够完美在 Doraemon 面板中接入你已经实现的与业务紧密耦合的一些非通有的辅助工具,并搭配我们的[dokit](https://www.dokit.cn)平台,让功能得到延伸,接入方便,便于扩展。

**简单总结**

1、DoraemonKit 能够快速让你的业务测试代码能够在这里统一管理,统一收口;  

2、DoraemonKit 内置很多常用的工具,避免重复实现,一次接入,你将会拥有强大的工具集合;

J
jackjintai 已提交
64
3、搭配dokit平台,借助[接口Mock](https://www.dokit.cn/#/index/dataMockPage)[健康体检](https://www.dokit.cn/#/index/checkDataPage)[文件同步助手](https://www.dokit.cn/#/index/fileSyncPage)让你方便和他人协同,极大的提升研发过程中的效率。
J
modify:  
jackjintai 已提交
65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107

## 效果演示

<div align="center">    
  <img src="https://pt-starimg.didistatic.com/static/starimg/img/H1SVa0S6Zm1585189141793.jpg" width = "250" alt="DoKit 首页效果演示" align=center />
</div>

## 功能模块

### 一、平台工具(www.dokit.cn)
1. **【数据Mock】** App接口Mock解决方案,提供一套基于App网络拦截的接口Mock方案,无需修改代码即可完成对于接口数据的Mock。
2. **【健康体检】** 一键式操作,整合DoKit多项工具,数据可视化,快速准确定位问题,让你对app的性能了如指掌。
3. **【文件同步助手】** 通过终端服务,让你的终端空间在平台端完整的展现并提供强大的文件以及数据库操作能力。

### 二、常用工具

1. **【App 信息查看】** 快速查看手机信息,App 基础信息、签名相关、权限信息的渠道,避免去手机设置查找或者查看项目源代码的麻烦;
2. **【开发者选项 Android特有】** 一键跳转开发者选项,避免安卓由于平台差异导致的入口不一致
3. **【本地语言】** 一键跳转本地语言,避免安卓由于平台差异导致的入口不一致
4. **【沙盒浏览】** App 内部文件浏览的功能,支持删除和预览, 并且能通过 AirDrop 或者其他分享方式上传到 PC 中,进行更加细致的操作;
5. **【MockGPS】** App 能定位到全国各地,支持地图地位和手动输入经纬度;
6. **【H5任意门】** 开发测试同学可以快速输入 H5 页面地址,查看该页面效果;
7. **【Crash查看】** 方便本地打印出出现 Crash 的堆栈;
8. **【子线程UI】** 快速定位哪一些 UI 操作在非主线程中进行渲染,避免不必要的问题;(iOS独有)
9. **【清除本地数据】** 一键删除沙盒中所有数据;
10. **【NSLog】** 把所有 NSLog 信息打印到UI界面,避免没有开发证书无法调试的尴尬;
11. **【Lumberjack】** 每一条 CocoaLumberjack 的日志信息,都在在 App 的界面中显示出来,再也不需要导出日志这么麻烦;(iOS独有)
12. **【DBView】** 通过网页方便快捷的操作应用内数据库,让数据库的调试变得非常优雅;
13. **【模拟弱网】** 限制网速,模拟弱网环境下App的运行情况。(android独有)

### 三、性能检测

1. **【帧率】** App 帧率信息提供波形图查看功能,让帧率监控的趋势更加明显;
2. **【CPU】** App CPU 使用率信息提供波形图查看功能,让 CPU 监控的趋势更加形象;
3. **【内存】** App 内存使用量信息提供波形图查看功能,让内存监控的趋势更加鲜明;
4. **【流量监控】** 拦截 App 内部流量信息,提供波形图展示、流量概要展示、流量列表展示、流量筛选、流量详情,对流量信息统一拦截,成为我们 App 中自带的 "Charles";
5. **【卡顿】** 锁定 App 出现卡顿的时刻,打印出对应的代码调用堆栈;
6. **【大图检测】** 通过流量监测,找出所有的大小超标的图片,避免下载大图造成的流量浪费和渲染大图带来的CPU消耗。
7. **【启动耗时】** 无侵入的统计出App启动过程的总共耗时;
8. **【UI层级检查】** 检查出每一个页面中层级最深的元素;
9. **【函数耗时】** 从函数级别分析app性能瓶颈;
10. **【Load】** 找出所有的Load方法,并给出耗时分析;(iOS独有)
11. **【内存泄漏】** 找出App中所有的内存泄漏的问题。
Y
yixiang 已提交
108

J
modify:  
jackjintai 已提交
109
### 四、视觉工具
Y
yixiang 已提交
110

J
modify:  
jackjintai 已提交
111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168
1. **【颜色吸管】** 方便设计师 UI 捉虫的时候,查看每一个组件的颜色值是否设置正确;
2. **【组件检查】** 可以抓取任意一个UI控件,查看它们的详细信息,包括控件名称、控件位置、背景色、字体颜色、字体大小;
3. **【对齐标尺】** 参考 Android 系统自带测试工具,能够实时捕获屏幕坐标,并且可以查看组件是否对齐;
4. **【元素边框线】** 绘制出每一个 UI 组件的边框,对于组件布局有一定的参考意义。 

### 五、Weex专项工具(CML专项工具)

1. **【console日志查看】** 方便在端上查看每一个Weex文件中的console日志,提供分级和搜索功能;
2. **【storage缓存查看】** 将Weex中的storage模块的本地缓存数据可视化展示;
3. **【容器信息】** 查看每一个打开的Weex页面的基本信息和性能数据;
4. **【DevTool】** 快速开启Weex DevTool的扫码入口。

tips : 如果使用我们滴滴优秀的开源跨端方案 [chameleon](https://github.com/didi/chameleon) 也可以集成该工具集合

### 六、支持自定义的业务工具集成到面板中

统一维护和管理所有的测试模块,详见接入手册

### 七、微信小程序专项工具

详见 [Doraemon mini program debugger](https://github.com/didi/DoraemonKit/tree/master/miniapp)

## 使用手册
访问 [https://www.dokit.cn/](https://www.dokit.cn/),点击"使用中心"。

## 相关文档
- [iOS 研发助手 DoraemonKit 技术实现(一)](https://www.jianshu.com/p/00763123dbc4)
- [iOS 研发助手 DoraemonKit 技术实现(二)](https://www.jianshu.com/p/4091870ca3f0)
- [DoKit支持iOS本地crash查看功能](https://juejin.im/post/5d76184ce51d4561d106cc65)
- [开源组件 DoraemonKit 之 Android 版本技术实现(一)](https://juejin.im/post/5c4dcfe8518825261e1f2978)
- [开源组件 DoraemonKit 之 Android 版本技术实现(二)](https://juejin.im/post/5c73db105188256ec63f13bb)
- [DoKit支持Activity启动耗时统计方案](https://juejin.im/post/5d70bc3051882571ed61e407)
- [DoKit 微信小程序SDK对外发布](https://juejin.im/post/5d9bf252518825095c3c5e32)
- [滴滴DoKit2.0 - 泛前端开发者的百宝箱](https://juejin.im/post/5dc3cdfa51882538d22d5948)
- [滴滴正式发布开源客户端研发助手 DoKit 3.0,新特性解读](https://juejin.im/post/5e818e29f265da4804697d25)
- [滴滴DoKit Android核心原理揭秘之函数耗时](https://juejin.im/post/5eba5ce15188256d6f268c98)

## 更新日志

- [iOS-ReleaseNotes](Doc/iOS-ReleaseNotes.md)
- [Android-ReleaseNotes](Doc/android-ReleaseNotes.md)
- [微信小程序-ReleaseNotes](Doc/miniapp-ReleaseNotes.md)

## QQ 交流群

<div align="center">    
 <img src="https://javer.oss-cn-shanghai.aliyuncs.com/doraemon/github/DoraemonKitQQ.jpeg" width = "160" height = "200" alt="QQ 交流群" align=left />
</div>

<br/>
<br/>
<br/>
<br/>
<br/>
<br/>
<br/>
<br/>
<br/>
Y
readme  
yixiang 已提交
169

J
modify:  
jackjintai 已提交
170
## 微信公众号
Y
yixiangboy 已提交
171
<div align="center">    
J
modify:  
jackjintai 已提交
172
 <img src="https://javer.oss-cn-shanghai.aliyuncs.com/2020/dokit/dokitwx.jpg" width = "200" height = "200" alt="微信公众号" align=left />
Y
yixiangboy 已提交
173 174
</div>

J
modify:  
jackjintai 已提交
175 176 177 178 179 180 181 182 183 184 185 186 187
<br/>
<br/>
<br/>
<br/>
<br/>
<br/>
<br/>
<br/>
<br/>


## 项目成员

J
jackjintai 已提交
188 189 190 191
### 发起者
[yixiangboy(易翔)](https://github.com/yixiangboy)
### 负责人
[jtsky(金台)](https://github.com/jtsky) 
J
modify:  
jackjintai 已提交
192 193

### 内部核心成员
J
jackjintai 已提交
194
[yixiangboy](https://github.com/yixiangboy)
J
modify:  
jackjintai 已提交
195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232
[jtsky](https://github.com/jtsky)
[ydlsl](https://github.com/ydlsl)
[jayconscious](https://github.com/jayconscious)

### 贡献者榜单
[LinJZong](https://github.com/LinJZong)
[wanglikun7342](https://github.com/wanglikun7342)
[wenquanlebao](https://github.com/wenquanlebao)
[hiXgb](https://github.com/hiXgb)
[Chinnko](https://github.com/Chinnko)
[y644938647](https://github.com/y644938647)
[goolong](https://github.com/goolong)
[miracle9312](https://github.com/miracle9312)
[lwhsgz123](https://github.com/lwhsgz123)
[huakucha](https://github.com/huakucha)
[HuginChen](https://github.com/HuginChen)
[feng562925462](https://github.com/feng562925462)
[azhon](https://github.com/azhon)
[rex26](https://github.com/rex26)
[csc-EricWu](https://github.com/csc-EricWu)
[xiandanin](https://github.com/xiandanin)
[0xd-cc](https://github.com/0xd-cc)
[k373379320](https://github.com/k373379320)
[fabcz](https://github.com/fabcz)
[y500](https://github.com/y500)
[Knight-ZXW](https://github.com/Knight-ZXW)
[boai](https://github.com/boai)
[klone1127](https://github.com/klone1127)
[DeveloperLY](https://github.com/DeveloperLY)
[sagdragon](https://github.com/sagdragon)
[ccworld1000](https://github.com/ccworld1000)
[HDB-Li](https://github.com/HDB-Li)
[yu-jianfeng](https://github.com/yu-jianfeng)

如何成为外部贡献者? 提交有意义的PR,并被采纳。


## 协议
Y
yixiangboy 已提交
233

Y
yixiangboy 已提交
234
<img alt="Apache-2.0 license" src="https://www.apache.org/img/ASF20thAnniversary.jpg" width="128">
Y
yixiangboy 已提交
235

J
modify:  
jackjintai 已提交
236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275
DoraemonKit 基于 Apache-2.0 协议进行分发和使用,更多信息参见 [协议文件](LICENSE)

## 使用提醒
因为SDK目前会配合[dokit.cn](http://www.dokit.cn/)平台, 会产生一些网络数据,这些信息我们收集绝不用于任何恶意用途。

**以下为所有涉及到网络请求的部分**

1. 统计有多少用户集成了dokit

    Android : DoraemonStatisticsUtil#uploadUserInfo

    iOS : DoraemonStatisticsUtil#upLoadUserInfo

2. 统计每个内置kit的使用情况

    Android : DataPickManager#realPost 

    iOS : DoraemonBuriedPointManager#uploadData

3. 上传健康体检的相关数据

    Android : AppHealthInfoUtil#post

    iOS : DoraemonHealthManager#upLoadData

4. 数据mock的相关网络请求

    Android : NetWorkMockFragment 里涉及到接口mock的相关网络请求
    
    iOS : DoraemonMockManager#queryMockData&uploadSaveData


敬请各位用户知晓。


## 友情链接
1. [AoE](https://github.com/didi/AoE),一个终端侧AI集成运行时环境 
2. [Chameleon]( https://github.com/didi/chameleon),简写CML,中文意思变色龙,意味着就像变色龙一样能适应不同环境的跨端整体解决方案,达到真正意义上"一套代码,多端运行"的终极目标
3. [Mand Mobile](https://github.com/didi/mand-mobile) 一款优秀的面向金融场景的 移动端UI组件库
4. 我们部门的技术公众号(普惠出行产品技术公众号),欢迎关注。
J
jackjintai 已提交
276 277
   
**公众号介绍:这里是滴滴出行旗下普惠产品技术团队对外分享的窗口,普惠出行支撑滴滴代驾、货运等业务,建设了NodeX、Dokit、卡梅隆等开源项目,始终秉承聚心成事、聚气育人的原则。欢迎各位技术同仁一起交流,共同成长。**
J
jackjintai 已提交
278 279 280


![普惠技术公众号](https://pt-starimg.didistatic.com/static/starimg/img/oOCoP5tVJs1600416407154.jpg)