iOS的测试

很多iOS程序员小伙伴们认为iOS客户端应用的测试难写。出现这种情况的原因是没有找到合适的测试策略。


产品代码设计

为了让代码可测试,我们需要对其进行一些设计。

问题

因为苹果一直很推荐MVC的编程框架,我们的ViewController很容易承担起了业务逻辑和显示逻辑的处理。因此MVC很容易就成了Massive ViewController。当大量的代码就集中在了ViewController当中,耦合自然就高了,测试的难度也就急剧上升。

解决方法

将业务逻辑代码从ViewController当中移除出来。那么ViewController当中就只有了显示逻辑。这在一定程度上也解耦了代码。
如何將业务逻辑代码从ViewController当中分离出来呢?一种方式是使用MVVM的设计。將业务逻辑代码封装在ViewModel当中。
那么,我们可以分别测试业务逻辑代码和显示逻辑代码。


测试类型

测试不可能覆盖所有的产品代码,那我们的目的是尽可能的覆盖复杂的、更可能出错的产品代码逻辑。

单元测试

单元测试,顾名思义,就是要以软件设计的最小模块为一个单元进行测试。而在iOS开发当中,我们的最小模块应该是一段业务逻辑或者是一个页面显示逻辑。因此,我们將业务逻辑和显示逻辑的测试都纳入到单元测试中。

业务逻辑测试

业务逻辑测试测暴露出来的方法。我们构建出需要输入的参数,验证期望的返回值。
测试特点:

  • 关注点集中
    每一个测试就仅仅是为了测试目标方法和其内部的私有方法。
  • 容易编写
    只需要构建需要的不同参数,然后测试相应的各种返回值即可。
  • 快速定位错误
    一旦测试失败,我们很容易的就能得到期望值和实际值。并且能够设置断点进行调试追踪。
  • 测试速度快
    测试仅仅是生成对象然后对其目标方法进行调用,整个过程快速稳定。

以上特点决定了这类测试的数量一定是最多的。并且测试的代码集中在测试各个ViewModel的方法。

显示逻辑测试

显示逻辑测试最后页面呈现的样式。我们可以构建出页面需要的ViewModel,传给其对应的View。将对应的View生成图片,保证每次生成的图片是一样的。
测试特点:

  • 测试粒度较大
    因为是生成图片的对比,我们一般构建整个ViewModel用来生成一个View,来对比截图。因此测试的方法不在是针对某一个方法。针对的是整个View的显示逻辑的正确性。
  • 无法驱动开发
    因为我们需要生成截图,我们无法在功能完成之前就写出对应的测试。这种测试更多的是保证显示逻辑的正确性。无法驱动开发。
  • 无法精确定位错误
    由于我们最后仅仅是对于每次测试生成的截图和预先生成的截图进行对比。当测试失败的时候,我们并不能定位错误代码的位置。仅仅能根据测试生成的截图进行推测。
  • 测试速度较快
    虽然是截图的比较,但是可以通过内存的比较来较快速的完成。因此测试速度依然是较快的。

以上特点决定了这类型的测试数量会远远低于业务逻辑测试。其测试粒度较大。但是其测试覆盖率也很容易做的很大。

功能测试

单元测试是静态的测试。我们现在来考虑模拟用户操作的的测试。这样的测试我们称为功能测试。
测试的目标为程序对用户操作的响应的正确性。
我们的应用在页面跳转的时候,通常伴随着后台数据的请求。如果这时候我们使用真是的服务器响应请求,通常会遇到两个问题。

  • 不能脱机测试。
  • 依赖于服务器的稳定性。

通常的解决方案是使用mock的API请求。

测试特点:

  • 测试速度慢
    页面跳转动画,测试框架,控件检测等特点导致测试一个feature的时间会非常的长。导致跑一次测试需要的时间会非常长。
  • 动态测试
    功能测试模拟用户使用,是抛开代码的黑盒的动态的测试。关注的点是业务流程和用户操作的正确响应。
  • 无法精确定位错误
    因为是黑盒测试,我们只能看到测试失败后的结果。从而推测可能出错的地方。

这类测试的数量是不多的,但是却可以覆盖大部分的业务流程和用户操作。其测试覆盖率也很容易做的很高。

回归测试

回归测试和功能测试几乎相同,仅仅把mock数据替换成真实数据。

测试特点:

  • 集成测试
    使用真实数据,可以发现真实环境中出现的问题。
  • 高效率
    代替手动测试,大大提高回归效率。
  • 不稳定
    替换真实数据后,测试的稳定性还会受到网络情况的影响。大大增加了不确定性,因为需要人去检查失败的结果。

测试框架推荐

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

推荐阅读更多精彩内容