一、为什么要进行单元测试
单元测试是指开发者编写代码,去验证被测代码是否正确的一种手段,其实就是用代码去检测代码。合理的利用单元测试可以提高软件的质量。
二、苹果自带的单元测试
图中已对方法进行了说明
自带测试的断言
//通用断言
XCTAssert(expression, format...)
//常用断言:
XCTAssertTrue(expression, format...)
XCTAssertFalse(expression, format...)
XCTAssertEqual(expression1, expression2, format...)
XCTAssertNotEqual(expression1, expression2, format...)
XCTAssertEqualWithAccuracy(expression1, expression2, accuracy, format...)
XCTAssertNotEqualWithAccuracy(expression1, expression2, accuracy, format...)
XCTAssertNil(expression, format...)
XCTAssertNotNil(expression, format...)
XCTFail(format...) //直接Fail的断言
异步测试的栗子
三、为什么使用Quick+Nimble?
主要是由于苹果官方框架的测试方法及断言不明确,可读性不好,难以分辨,交接项目需要花费的时间很多,所以建议采用三方测试框架
目前主流的三方测试框架主要有:
oc中:kiwi
、specta
、cedar
swift:quick+nimble
、Sleipnir
由于项目是使用的swift语言,所以主要采用quick+nimble,用于单元测试和断言。
如果你的项目是OC的,推荐使用kiwi。
Quick+Nimble介绍
Quick 是一个建立在XCTest 上,为 Swift 和 Objective-C 设计的测试框架,对测试使用Swift编写的App非常友好,对 Swift 使用者来说,Quick 是最佳选择。
它通过 DSL
去编写非常类似于 RSpec
的测试用例。
Nimble
就像是 Quick
的搭档,它提供了匹配器作为断言,用于编写匹配模式。
配置 Quick+Nimble
使用Quick+Nimble
1、在测试文件中导入框架
import Quick
import Nimble
2、在测试文件中导入需要测试的项目的target
@testable import UnitTest
这样对于 Swift 中受保护的属性、方法等都可以暴露使用了
3、将测试文件的继承类 改成 QuickSpec
,必须确保我们的 class 是QuickSpec
的子类,它也是原本 XCTestCase
的子类
4、简单的测试用例
在此只是引导简单的使用,具体在测试过程中如何设计编写需要看自己的需求。
Quick关键字说明
关键字 | 用途 |
---|---|
describe | 描述类和类的方法 |
context | 用于指定条件或状态 |
it | 用于描述测试的方法名 |
beforeEach/afterEach | 相当于setUp/tearDown |
beforeSuite/afterSuite | 相当于全局setUp/teardown |
在describe 、context、it前加“x” | 表示可以屏蔽此方法的测试 |
在describe 、context、it前加“f” | 表示可以只测试这些带f的测试 |
Nimble关键字说明
Nimble一般使用 expect(...).to 和 expect(...).notTo的写法
Nimble中的匹配函数
针对不同的业务场景,使用不同的函数,在此就不一一列举了。