提升iOS审核通过率之“IPv6兼容测试”

作者:jingle 腾讯系统测试工程师

商业转载请联系腾讯WeTest授权,非商业转载请注明出处。

原文链接:http://wetest.qq.com/lab/view/285.html


一、背景

在WWDC2015大会上苹果宣布iOS9将支持纯IPv6的网络服务。2016年6月1号,所有提交到AppStore上的应用都必须支持IPv6,否则将通不过审核。为了确保我们的app正常提交到苹果进行审核,不耽误项目进度,我们必须在提交到AppStore前对待提交app做IPv6兼容测试


二、为什么要使用IPv6

从IPv4到IPv6,IP地址的数量从2的32次方扩展到2的128次方,这个是IPv6碾压IPv4的地方,足够地球上的每粒沙子分配一个或者多个IP地址。当然,除了IPv4本身的原因(地址枯竭)外,下面提到的几点,也说明了IPv6比IPv4更加高效,例如:


避免了网络地址转换(NAT)的需要

通过使用简化的头提供了更快的路由通过网络

防止网络碎片

避免广播邻居地址解析

但最根本的原因莫过于苹果审核的压力,不得不将app适配IPv6。


三、测试应该关注的点

1. 保证项目代码中使用的是更高层次的网络API,避免使用socket API

在苹果官网上,有这么一张图,说明了哪些框架支持IPv6,哪些不支持, 如下图所示:


图中蓝色部分默认支持IPv6,如果项目代码中使用的是WebKit或者AFNetWorking这些网络框架,那么需要改动的代码不会很多。

2. 走读代码中是否使用了IP地址

比如,检查代码中是否包含了类似于192.168.0.1的地址,如果有,需要换为其对应的域名地址。

3. 检查代码是否包含只适用于IPv4的API

确保项目代码中没有以下API:

inet_addr()

inet_aton()

inet_lnaof()

inet_makeaddr()

inet_netof()

inet_network()

inet_ntoa()

inet_ntoa_r()

bindresvport()

getipv4sourcefilter()

setipv4sourcefilter()

如果有了这些代码也不要怕,只需要将对应的API换为IPv6所支持的API即可,下表是IPv4和IPv6的对应关系表:



4. 本地搭建IPv6环境,回归app中所有网络请求的模块

我们现在连的网络,无论是wifi还是移动、联通、电信的各种不同类型的网络,都是IPv4的,也就是实际生活中和我们打交道的全是IPv4环境。但我们需要测试IPv6在iOS APP中的兼容性,是必然不能在现有的网络环境下测试的,需要测试人员自己构建测试环境。

值得欣慰的是,苹果公司在MAC OS X 10.11以后的系统中就埋下了开启IPv6环境的彩蛋。我们所要做的就是参照官方文档,在本地搭建这样的测试环境。即用MAC机建立一个热点,然后用iPhone连接该热点,回归待测模块。简单的示意图如下所示:


a)需要准备的设备:

系统是OS X 10.11以后版本的MAC机(该MAC机要使用非WIFI方式上网,且支持双网卡)一台,iPhone手机一台。这个地方有些土豪同学可能会有疑问,我的Mac本本只有无线网卡,没有有线网孔啊,这时你就需要一个苹果Thunderbolt千兆以太网转换器,如下图所示:

b)开启NAT64网络

打开“系统偏好设置”,按住option键的同时点击“共享”,如下图所示:

之后,在共享页就能看到“创建NAT64网络”的可选框了,如下图所示:

到此,我们的NAT64网络就创建完成了,剩下的就是创建热点了。

c)在MAC机上创建WiFi热点

MAC上创建WiFi热点,很简单,这里就不再详细说明了,看下面这张图也能知道怎么创建的:

这里想说明一点,也是比较关键的一点:点击上图中的“启动”button后,有些网络会出现如下图所示的共享失败情况:

出现这种情况,说明你当前使用的网络受到了802.1x协议的限制,无法共享。只能通过去802.1x保护或者换其他可以共享的网络进行共享。

如果是在公司网络,可以寻求IT进行网络切换,或者找开发他们搭建好的网络环境进行测试(ps:如果开发没有IPv6网络环境,且发版时间又比较紧张的情况下,可以和老大申请回家办公,或者随便一个咖啡馆)。

如果热点搭建成功,是可以在mac机右上角的网络状态处看到如下图所示的图标:

d)iPhone手机连接创建好的热点,连接成功后,可以查下iPhone手机的IP地址。

我这里看到的是169.254..的IP地址,这类地址属于保留地址,具体什么是保留地址,请自行百度。

e)回归待测app,确保所有的网络请求在本地搭建好的IPv6网络环境下正常的,这里说的“正常”就是指和在IPv4网络环境下的表现一致。

经测试,在IPv6网络环境下,QQ可以正常使用,微信网络连接失败(微信最新的SDK已支持IPv6)。

最后,如果感兴趣的话,可以用抓包工具看一下,IPv6的地址长什么样子,之前都是在课本中见到过,这次测试也算是头一次真正看到IPv6的地址啦,如下图所示:

四、项目实战

这里以地图SDK为例,简单说明具体的测试步骤。地图SDK,是地图软件开发工程师为特定的软件包、软件框架、硬件平台、操作系统等建立应用软件时的开发工具的集合,它包括接口API、示例代码、支持性的技术注解或者其他的支持文档,有了这些,第三方开发者可以很方便的使用这些API开发自己所需的功能,这里附上腾讯地图开放平台地址:http://lbs.qq.com/ios_v1/index.html

目前和腾讯地图SDK合作的小伙伴有京东、58同城、携程、嘀嘀等。

1. 首先需要分析该SDK使用到了哪些库

地图SDK中使用的framework如下图:

针对地图SDK中使用到的这些库,逐一确认是否支持IPv6,比如WebKit.framework框架,苹果官方文档就明确说明了支持IPv6。

2. 检查SDK源码中是否使用到了IP地址

这块主要是走查所有有网络请求的模块,是否将IP地址替换为了域名,这块一般是在代码某个配置文件中进行定义的。比如,下图所示的server地址:

3. 检查代码中是否包含只支持IPv4的API

由于SDK使用的是WebKit.framework,不存在底层的socket API,这块没有风险。

4. 本地搭建测试环境,回归SDK网络相关模块

这里,需要保证在IPv6环境下的功能与在IPv4环境下表现一致的,就可以说明测试通过。

5. 抓包确认

最后,可以通过抓包看看是否真的走的是所搭建的IPv6的测试环境,当然也可以亲眼目睹下IPv6的IP地址长什么样儿。


【腾讯WeTest iOS预审工具】

为了提高IEG苹果审核通过率,腾讯专门成立了苹果审核测试团队,打造出iOS预审工具这款产品。经过1年半的内部运营,腾讯内部应用的iOS审核通过率从平均35%提升到90%+。

现将腾讯内部产品的过审经验,以线上工具的形式共享给各位。在WeTest腾讯质量开放平台上可以在线使用。

点击链接:http://wetest.qq.com/product/ios即可立即体验!

iOS预审工具分四步进行预审服务

【一键扫描】只需提供ipa包、审核图片、审核视频、应用描述,即可在4小时内拿到一份完整的检测报告,定位问题的同时提供解决方案,助您成功通过审核。

【案例分享】集结iOS审核失败常见原因,丰富案例为您提供参考依据。

【专家服务】腾讯专家团队为您分析各种疑难杂症,提出最优解决方案。

【ASO优化】专业优化AppStore内关键字搜索结果,让产品离用户更近一步。希望App/手游在预审验收保证下,都可以快快乐乐过审,开开心心赚钱。

关注“腾讯WeTest”公众号,获取更多干货

开启赞赏

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

推荐阅读更多精彩内容

  • 研究IPv6 socket编程原因: Supporting IPv6 in iOS 9 WWDC2015苹果宣布在...
    li大鹏阅读 7,285评论 7 15
  • 原文连接 为了加深印象与理解,自己copy了一份,顺便按照自己的理解稍作修改。参考资料 自从5月初Apple明文规...
    不会游泳De鱼阅读 4,597评论 2 12
  • 随着时间的推移,人生在职场一般有三个阶段,需要三个不同的着力点。以下的时间范围仅是参考,因为有些人可以在很短时间、...
    丘一森阅读 1,385评论 0 0
  • 每一次的慢走长谈,都是我们心灵深处最柔软的地方,是的,这时候才最显示语言如此苍白,所有的安慰如此无力,但我们都知道...
    演绎主角阅读 291评论 0 0
  • 圆和方看着简单,画起来不容易。尤其是画正方体,注意透视关系的时候,最远处的那个点老是找不准。看着哪里不对,就是不知...
    围裙妈阅读 291评论 2 3