您还未登录! 登录 | 注册 | 帮助  

您的位置: 首页 > 软件测试技术 > 功能测试 > 正文

VKDebugConsole App黑盒控制台

发表于:2017-01-09 作者:网络转载 来源:

  简介
  App内控制台,可以在脱离Xcode debug的情况下,调试内存,打印数据,修改UI等
  方便在黑盒测试+内部体验的环境下,发现Bug后,直接在Bug现场调试内存,分析问题
  先大体看一下GIF动画如何使用

  Git地址 VKDebugConsole
  恩 基于JSPatch做的 ?(?_?)?
  吐槽:界面好难看。。NSLog很多的时候有点乱。。
  基本上初步的功能都补全了,能在自己项目里用上了,还算方便
  后续优化指令,优化功能,优化界面,还需要持续进行(眼下这个看着太难看,指令也太难用了)
  基本使用
  <!--more-->
  · [VKDebugConsole showBt]方法会在window上增加一个debug按钮
  · 点一下会变成select状态,触摸屏幕中任何view可以选择一个target
  · 选择target后,console控制台打开,按钮变为Hidden
  · 上部分为输入区,输入调试代码
  · 下部分为输出区,输出调试信息,NSLog信息,调试错误(未来还会扩展其他
  · 再次点击Hidden按钮会退出控制台
  调试代码
  因为是基于JSPatch的,所有JSPatch的语法规则这里都一模一样可以使用,可以参考一下动画中的用法,不过大部分用法还是遵从JSPatch,戳这里看如何使用 JSPatch语法
  除了JSPatch支持的基本语法,还支持如下几条命令
  · target():获取刚才通过手选的界面View
  · targetVC()获取刚才通过手选的界面View所在的VC
  · getParentVC(v)输入一个View,获取所在的VC
  · print(item)输出一个对象到控制台,单独处理了Label和View的描述信息,更加方便直观(可以扩展更多单独处理的对象类型)
  · changeSelect()重新手选获取新target
  · exit()退出控制台
  · clearOutput()清空控制台输出区
  · clearInput()清空控制台输入区
  · 支持剪贴板
  很明显,在APP黑盒的情况下,写代码是非常不方便的,用手机上面的软键盘,于是支持了剪贴板
  · 打开控制台
  · 在电脑上的编辑器里写好代码
  · 无论以QQ微信等各种形式发到手机上,在手机上复制
  · 切回APP显示控制台的时候,会自动把剪贴板的内容,复制到输入区
  支持NSLog
  写一个这样的宏在你的pch里面,覆盖NSLog
  #ifndef __OPTIMIZE__
  #import "VKLogManager.h"
  #define NSLog(...) NSLog(__VA_ARGS__);
  VKLog(__VA_ARGS__)
  #else
  #define NSLog(...) {}
  #endif
  在执行NSLog的同时,再自动执行一次VKLog,这样所有NSLog的打印就都同时打印在LLDB上和VKDebugConsole上了
  支持了 红(出错) 黄(console.log) 白(系统NSlog)三种颜色
  开启控制台后,程序再次输出的NSLog也能进入控制台区域方便查看
  编译控制
  所有的代码在debug模式下会生效,在release模式下会自动不参与编译,直接失效,不用担心发版前忘记关掉代码,导致线上暴露的问题
  TODO LIST:
  · 指令更易输入,能支持输入oc的方括号语法
  · 界面更好看点吧,至少整理下控制台输出界面,可读性太差
  · 扩展更多地方便调试的接口和指令
  · 支持网络日志,所有的网络请求接口以及返回数据,会以网络日志的方式,在console里面查询
  ......