关于iOS单元测试几点Tips
相关文章:
1、走出 iOS 单元测试的困境一、单元测试有什么好处?
2、iOS单元测试--百度Hi iOS团队技术周报
文章图片
单元测试使用前后对比.png
- 单元测试使工作完成的更轻松
- 经过单元测试的代码,质量能够得到保证
- 单元测试发现的问题很容易定位。
- 修改代码犯的错,经过单元测试易发现
- 单元测试可以在早期就发现性能问题
- 单元测试使你的设计更好
- 大大减少花在调试上的时间
既然单元测试这么多好处,作为菜鸟我能做什么呢?◆ 不是所有的方法都需要测试。
? 例如:私有方法不需要测试!只有暴露在 .h 中的方法需要测试!面向对象有一个原则:开闭原则!
◆ 所有跟 UI 有关的都不需要测试,也不好测试。
? 把业务逻辑 代码封装出来!变成可以测试的代码,让程序更加健壮!
◆ 一般而言,代码的覆盖度大概在 50% ~ 70%
四、那单元测试代码覆盖率又是什么鬼?
单元测试代码覆盖率如何统计的呢?如果一个新建的单元测试想要查看显示代码覆盖率,要怎么做呢?1、修改test target的Build Setting中Generate Test Coverage Files 和Instrument Program Flow为YES;
2、在test target的Build Phases中的Compile Sources中添加需要被测量代码覆盖率的文件(.m,.mm)。
注意:不需要测量代码覆盖率之前,test target中只需要包含。
文章图片
AFNetworking单元测试代码覆盖率.png
如上图,一旦这个测试通过了,你就能知道 checkWord 这个方法,至少有一条路径是对的。但你不知道的是,还多多少没有被测试到。这就是code coverage这个工具的好处。当你打开code coverage tab后,你可以清楚的看到测试的覆盖情况。他们按找 target, file, function 进行了自动分组。打开Xcode左边窗口的Report Navigator面板,选中你刚运行的测试。然后在tab中选中 Coverage。这会展示一个你的类、方法的列表,并标示出每个的测试覆盖率。如果你将鼠标悬停在checkWord这个方法上,你可以看到测试的覆盖率是28%。双击方法的名字,Xcode会打开类的代码,并且看到code coverage的情况。
三、如何建单元测试环境呢?
关于如何建单元测试环境,很多文章都有描述,而且都有操作配图,可以自行查阅。相关文章-单元测试入门.【关于iOS单元测试几点Tips】注意:有第三方依赖的,单元测试也要配置依赖环境。
包括:
1、 单元测试的运行;
2、单元测试框架说明;
3、单元测试简单案例的实践。
推荐阅读
- 2020-04-07vue中Axios的封装和API接口的管理
- 关于QueryWrapper|关于QueryWrapper,实现MybatisPlus多表关联查询方式
- 四首关于旅行记忆的外文歌曲
- 醒不来的梦
- iOS中的Block
- 关于自我为中心的一点感想
- 「按键精灵安卓版」关于全分辨率脚本的一些理解(非游戏app)
- 记录iOS生成分享图片的一些问题,根据UIView生成固定尺寸的分享图片
- 关于Ruby的杂想
- 关于读书的思考