提高iOS审核经过率之“IPv6兼容测试”

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

原文连接:http://wetest.qq.com/lab/view/285.htmlios

1、背景

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

 

2、为何要使用IPv6

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

1. 避免了网络地址转换(NAT)的须要app

2. 经过使用简化的头提供了更快的路由经过网络框架

3. 防止网络碎片socket

4. 避免广播邻居地址解析ide

但最根本的缘由莫过于苹果审核的压力,不得不将app适配IPv6。工具

 

3、测试应该关注的点

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的地址啦,以下图所示:

 

 

4、项目实战

这里以地图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/手游在预审验收保证下,均可以快快乐乐过审,开开心心赚钱。

相关文章
相关标签/搜索