沧海一声笑,移动应用的CRASH原因我找到!
--记最新款数字化测试“星云测试“的使用攻略
世界进步那么快,很多新鲜的点子层出不穷,于是我们创业,我们做最酷的手机应用,做最轰炸的应用推广。不加国际友人,仅咱泱泱大中华14亿人口,智能手机用户目前就已经超过5亿人,并还在继续疯长中!据说到2015年1月,仅我们中国的主要应用商店APP应用累计超过400万个。感觉像我们一样优秀的IT天才们的春天已经到来!就凭咱的脑子和实力,从各种大众脸的App应用中脱颖而出那是必然的!我们肯定是笑到最后的那个团队!
但是,最近我们澎湃的理想差点儿就被现实击碎:我们耗尽心血开发的应用、精妙的设计思路,居然被闪退、崩溃等看似低级的错误卡住了喉咙!看着银行卡中越耗越少的资金,我们心如刀割。
尽管我们有思想准备:Crash很正常,62%的应用都有这样的毛病,Bala,Bala……但我们也知道,如果Crash发生在首次启动,21%的用户会立即卸载;Crash在使用过程中发生,70%的用户会给应用差评,然后卸载。难道我们伟大的理想和情怀就真的要止步于残忍的现实了吗?我们就活该举手投降了吗?No,No,No,超级无敌研发攻城狮NEO的光荣称号不允许我这么做!我要做的是:彻查BUG究竟藏身何处,然后拉出来千刀万剐,然后把它枪毙,然后和团队一起昂首进入APP热门下载排行榜!可是,世界有没有一款称心如意的软件测试工具,能快点帮助我们直接复现崩溃时刻的执行逻辑路径的详细信息?我们没日没夜的在国内外的测试工具库中找寻,跟同行打听。
在前天风大雨大极其神秘的夜晚,我假装镇静却又心急如焚的和伙伴们讨论业务方案的时候,有如神助般的点到了一个网站:星云测试。那个网站貌似刚上线不久,好几个模块都在敬请期待,网址也有点怪:www.teststars.cc,Slogan巨大而醒目:“星云测试 开创数字化测试新旅程”。啥米?什么是“数字化测试”?!“实现代码和测试用例的双向追溯“,“数字化、可视化测试过程”,看起来很牛叉的样子!我,做为一位更牛叉的、超级的、无所不能的IT高手,需要了解和批准一下。IT界的最新信息,我不先知道,太反常了!不过,还好他们好像还不算最正式的上线,平复了我傲娇的小火苗。
眼光一瞥,看到免费下载个人高级版,哈哈,甚合朕意!可以免费下载!它边上有几行呆萌的小字说明(劝君拿放大镜来看):“实现软件测试过程与结果的全数字记录与分析,快速的崩溃捕捉和代码执行路径分析“。朕心头万马奔腾!立即点开,下载页面资料还挺全:使用说明、部署说明、视频啥的,还挺全的。火速注册,立马开用!急我所急,天助我也!
感谢我的上帝之手!真的是不用则已,一用惊破天!这个免费的东东功能实在太强大了,它不仅在系统层面进行一些缺陷现场数据的搜集,还居然能深入到代码内部,很直接的直接定位问题!!一下子就把我们的致命伤-Crash点的最后50个逻辑块,条件、分支等就给我找出来了。太让我震惊了!令人叹为观止的是:它居然还真的支持测试用例到代码执行逻辑的追溯,就是说,它把一个测试用例的整个运行期间的对应的代码逻辑情况都回放出来了。简直是一个超能全景Debug神器!另外,兄弟们,重点是:它比Debug更强大:Debug需要单步运行,通常仅仅显示当前状态而不能很好地记录历史运行数据,星测上的这个神器是完整的Debug调试链的完整展示!
神啊!太强了!!朕有天助啊,吉人自有天象啊!!我们的项目可算找着慈悲的上帝打开的另一扇窗了!为了表达我的激动之情,也为了由衷的感谢这个神器,我,一个超级的、绝顶聪明的研发攻城狮必须做一个攻略,给大家分享一下,以示感谢与敬意!好贴不沉底啊!
(TIPS:由于俺们伟大的应用暂时不便公开,我索性就用一个开源程序来给大家做一个简要的举栗子,它来自于网络上开心网移动端的一个版本的代码)
我在其代码内部人为植入了一个缺陷,如下:
修改内容:
src/com/kaixin/android/activity/CheckInActivity.java
修改前:
修改后:
大家都知道,对源码的修改相当于引入了一个越界访问的缺陷,下面我们看看这个神一样的数字化测试工具,是如何在假设不知道这个缺陷的位置和原因的情况下,直接捕获和分析BUG的。
第一步:通过工具编译植入缺陷的程序,安装进入手机,打开示波器,监控运行。
第二步:进入Home界面后,点击左下角的红色羽毛按键,弹出一个弧形菜单,点击最上侧位置按钮,程序崩溃。然后停止TT示波器的搜集,回到TT的用例-代码快照视图。
第三步:查看最后错误的50块,点击最后一块执行:
分析:return语句通常不会导致程序崩溃,因为其本身并没有任何因此异常的计算(此语句其实也未实际运行,问了下星云1号技术支持,给出的解释是因为前面程序出了异常,TT目前的一些记录运行轨迹的信息和机制会认为return最后运行了,未来的版本会针对该问题进行修复)。而且显示点击倒数第二块为:
此为隐藏块,不会导致程序崩溃。点击倒数第三块:
此为隐藏块,不会导致程序错误。点击倒数第四块:
此时可能存在问题,因为正常情况块664必然会执行。点击倒数第五块:
所以出错可能这一句:
result= mKXApplication.mMyLocationResults.get(position);
分析:大家仔细观察这句代码,我们可以发现,在这个页面position对应的mKXApplication.mMyLocationResults界面的position-1位置,找到错误。
然后我们在看下最后50个条件信息,最后一个条件可以清晰的看到,出错位置的判断语句运行的结果为true,说明在缺陷发生的最后一刻进入了这个条件,而条件里面的代码正是我们在崩溃块分析结果里面的:
result =mKXApplication.mMyLocationResults.get(position);
结论:说明星测上的神器给我们的整个分析是准确无误的。
别的也不多说,反正经过我的实际使用,神器还有更多令人惊讶的表现,我还在慢慢学习,大家自己也可以用起来,咱们一起慢慢体会。那个星云测试网站上有很多使用指南,你们可以下载去看看。好东西,总是需要大家去顶,我们顶了,人多了,他们团队才更有信心和能力去做更多的事儿,咱狮子们可不希望这样优秀的团队因为没钱散了,工具也没办法升级和维护了,尽管神器已经很强大了。兄弟们,将心比心,可以想像这么复杂、强大的神器研发起来是多么的不容易!跟他们的“星云1号客服“聊,他们已经坚持三年了!真是让人肃然起敬!兄弟们,咱们一定要支持!!!因为,就连国外的一流软件测试工具在他们面前也弱爆了!!
我太激动了,我得平静一下我激动的小心脏。他们的网站:www.teststars.cc,根据我的经验,流量上去了,注册量上去了,使用量上去了,他们的机会就来了。咱们也就能一直享受这伟大的、免费的礼物了!再次向他们天才的研发团队致以最崇高的敬礼!
PS:等咱有了钱,得用他们的企业版试试,看起来,那更令人心驰神往啊!
攻略撰写人:一位天才的、壁咚的超级研发攻城狮:NEO
沧海一声笑,移动应用的CRASH原因我找到! --记最新款数字化测试“星云测试“的使用攻略
原文地址:http://threadingtest.blog.51cto.com/8887732/1661303