本文翻译自Unit Testing Tutorial:Mocking Objects
将分为两部分翻译,这是Part One.
谁需要单元测试?肯定不是你—你的代码已经灰常完美.所以呢......你仅仅是为你需要学习Swift单元测试的朋友读读而已?是吧. :]
单元测试能使代码变得更好;能帮助你在开发过程中尽早地发现绝大多数的bug,更重要的是基于可测试的开发模式能使你写出更加模块化的容易维护的代码.第一准则:如果你的代码不容易测试,那么将会不容易维护和debug.
单元测试能够使"微小的特性"分离.通常你需要模拟类—提供模仿对象来实现功能上的动作—使微小的特性脱离出来便于测试.Objective-C中有许多第三方框架来实现对象的模拟和销毁.但这些来源于不断实践和总结的库,还不能在Swift中使用.未来的某天,希望会能用! :]
本教程中,你将学习如何编写自己的mocks,fakes和stubs来测试一个帮助你记忆朋友生日的app.
- 开端
下载起始项目;这是个可以连接网络后台的通讯录app.你无须编写app的核心功能;相应地,你需要编写一些测试来验证某些功能如预期一样实现.
运行程序来看下它如何使用.点击plus,在列表里增加一个人:
例子用Core Data来存储你的通讯录:
莫慌张! :] 本教程中你不需要Core Data的任何经验;也没有火箭科学(这是什么鬼?)
- 单元测试的好处和坏处
当开始测试之前,一个坏消息和一个好消息.坏消息是单元测试有许多坏处,比如下面的:
- More code: 大量的测试很容易使测试代码量超过功能性的代码量.
- More to maintain: 更多的代码意味着需要更大精力的维护成本.
- No silver bullet: 单元测试不能(也不可能)消除你所有的bug.
- Takes longer: 写测试花费更多时间(而这些时间你本可以在raywenderlicn.com学更多新奇的知识).
虽然没有银弹,但却有银线—测试有如下的好处:
- Confidence: 你可以证明你代码的可行性.
- Quick feedback: 你可以利用单元测试来使藏于你的app navigation里的深层级的代码得到快速生效运行—这在手工运行测试时非常笨重低效.
- Modularity: 单元测试能使你写出更加模块化的代码.
- Focus: 编写微小特性的测试能使你专注于小细节.
- Regression: 确保你修复的bug修复—不会在随后的bug中出现.
- Refactoring: 当Xcode能够智能地重构你的代码之前,你需要单元测试来使你重构的代码生效.
- Documentation: 单元测试能够描述你的代码用途;能作为另一种形式的代码文档.
- App的基本结构
许多例子应用的代码都基于勾选Core Data的Master-Detail Application模板.但在模板代码中可以进行一些明显改进.Xcode中打开例子代码来看下代码导航:
看下具体细节:
- 有个Person.swift和PersonInfo.swift文件.Person类是个NSManagedObject来包含每个人的一些基本信息.PersonInfo结构体包含相同的信息,但能够从地址薄中被实例化.
- PeopleList文件夹有三个文件:一个view controller,一个data provider和一个data provider protocol.
PeopleList包含的文件用来避免view controllers过于臃肿.将一些功能性的代码写成和view controllers交互的单独协议是避免view controller臃肿的好做法.你可以通过这篇文章来学习了解更多关于此话题的内容.
本例中,协议被定义在PeopleListDataProviderProtocol.swift中;打开来瞅瞅.遵从此协议的类必须有managedObjectContext属性和tableView且必须定义方法addPerson(_:)和fetch().另外,它必须继承UITableViewDataSource协议.
PeopleListViewController有一个dataProvider属性,它遵从PeopleListDataProviderProtocol协议.这个属性在AppDelegate.swift里创建了PeopleListDataProvider实例.
你通过ABPeoplePickerNavigationController来添加人员到列表中.这个类使开发者无需明确地请求许可就能获得用户的通讯录.
PeopleListDataProvider从Core Data中获得数据填充到table view中.
下一篇将具体编写单元测试的代码,晚安 :)
Girl学iOS100天 第25天