一个BUG的发现、定位和解决

前言

在iOS 11发布之后,出现了一系列适配相关的问题,UIScrollView在pagingEnabled=YES时滑动手势不灵敏,UITableView的滑动删除功能变动,UIImagePickerViewController的取消按钮点击区域变小等,本文介绍其中一个UIAlertView问题,分享其发现、定位和解决

正文

1、问题产生

问题的最初,是iOS 11正式版发布后不久,测试的同学提了一个iOS 11相关的BUG,表现是:在直播间内发送聊天信息,如果被禁言,会弹出“被禁言”提示,键盘收回去,然后就弹不出来。
开发在接到这个BUG的时候,先把问题抽象出来几个要素:直播间内、键盘弹出、弹出提示、键盘收回、键盘无法弹出。

弹出提示是用的UIAlertView的方式。在键盘出现时弹出UIAlertView的提示,键盘会收起,UIAlertView消失后,键盘会再次弹出,是一次正常的表现。

2、问题复现

按照复现路径做一次尝试,发现BUG可以复现,确定问题存在
根据经验,猜测问题可能出现在键盘和UIAlertView上,与“禁言”的业务无关。
在直播间内尝试其他非“禁言”的场景,同样是在键盘出现的时候,弹出UIAlertView的提示,也会造成后续键盘无法弹出的情况。

在尝试完其他非直播间的主场景之后,发现问题可以描述为:
iOS 11的机器只要弹出来一次UIAlertView,之后再通过becomeFirstResponder无法呼起键盘;必须手动点击输入区域,触发系统的键盘弹出行为,或者切入后台再切回来,才能正常弹出来键盘。

部分页面在点击评论后,会添加一层透明maskView,并弹出键盘。点击透明的maskView会调用resignFirstResponder,在键盘消失的notification中消除maskView。因为键盘无法弹出(也无法收到键盘消失的notification,但maskView还是正常添加),导致这部分页面无法进行后续的交互。

3、问题评估

在复现问题后,需要对问题的严重性进行评估,确定BUG修复的优先级。
从已知的表现来看,iOS 11下的使用影响较大(UIAlertView的提示较多)。
用iOS 11的机器下载外网版本进行测试,发现BUG竟然无法复现!
虽然很诡异,但是问题的优先级可以降到更低,排入正常的BUG解决列表中。

4、问题解析

外网版本是Xcode8编译的本,本地版本使用的Xcode9 GM编译的,难道是Xcode 9编译导致?
1、新建一个demo,只有输入框和按钮,模拟UIAlertView弹出,发现demo是正常的;
2、把app的工程设置复制到demo,把对输入框的属性设置同样复制到demo,demo依旧正常;
3、把demo代码复制到app,并把app的rootViewController赋值为demo中的VC,依旧正常;
可以确定是app中某部分代码导致的键盘无法弹出的。
经过二分注释的方式,迅速(4、5次左右)定位到问题是app中的某个Service类导致。
仔细排插Service类的属性,发现里面有一个属性的是继承UIWindow并且level比UIWindowLevelStatusBar高。
自此,根据所学和苹果UIKit的文档,我们可以对问题进行一次回溯。

5、问题回溯

苹果官网上响应链和UIWindow的说明,里面关于becomeFirstResponder()的解释是:
Asks UIKit to make this object the first responder in its window.
对于UIAlertView的iOS 11系统行为,猜测:
1、在UIAlertView弹出的时候,会抢占系统的keyWindow,所以会出现键盘在UIAlertView的时候收回(因为keyWindow改变);
2、在UIAlertView消失的时候,会遍历所有Window,找到其中z轴最高作为keyWindow,所以会出现键盘在UIAlertView消失后弹出(keyWindow变成原来的);

通过写代码调试app,确定了上面的猜测。

在iOS 11,如果UIAlertView弹出时,存在windowLevel 大于 UIWindowLevelNormal 的UIWindow,就会触发这个键盘无法弹出的BUG。

6、问题修复

1、保证app中,没有常驻的UIWindow;
2、修复键盘无法弹出时,maskView无法消除的BUG;
3、UIAlertView在后续的版本替换掉;

总结

这次问题从产生、复现、定位、评估再到修复的时间,和写这篇文章的时间差不多。
BUG的解决流程各不相同,借此提醒自己对于BUG的解决要有目的性和优先级。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,377评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,390评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,967评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,344评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,441评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,492评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,497评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,274评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,732评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,008评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,184评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,837评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,520评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,156评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,407评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,056评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,074评论 2 352

推荐阅读更多精彩内容