Swift开发ios首页投稿(暂停使用,暂停投稿)

iOS的测试

2016-07-14  本文已影响484人  GaryChow

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


产品代码设计

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

问题

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

解决方法

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


测试类型

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

单元测试

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

业务逻辑测试

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

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

显示逻辑测试

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

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

功能测试

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

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

测试特点:

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

回归测试

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

测试特点:


测试框架推荐

上一篇下一篇

猜你喜欢

热点阅读