作者:Natasha The Robot,原文链接,原文日期:2016-01-08
译者:littltedogboy;校对:Cee;定稿:千叶知风
作为我今年的第一个项目,我正在做 @catehstn’s iOS Unit Testing Workshop 的 Swift 版本。如果感兴趣的话,可以在这里注册。
在我写代码和测试期间,我遇到了下面的问题...
假设我使用 Swift 创建了一个简单的计数器:
// Counter.swift
struct Counter {
// `count` 在这里为一个变量
// 但是我不想把 `count` 设置为外部可访问的
// 因此我把 `count` 设置为私有的(这里有小提示!https://twitter.com/mipstian/status/685489964403003393)
private(set) var count: Int
init() {
// 我想让计数器默认从 0 开始
count = 0
}
// 我只想让 `count` 通过此函数被修改
// 通过像这样的函数
mutating func increment() {
count += 1
}
}
这个结构体超级简单,我也很容易地编写了一个 increment 测试用例。
// CounterTests.swift
import XCTest
@testable import Counter
class CounterTests: XCTestCase {
func testIncrement() {
var counter = Counter()
XCTAssertEqual(counter.count, 0)
counter.increment()
XCTAssertEqual(counter.count, 1)
}
}
测试正确,但是下面这种情况呢!
// Counter.swift
struct Counter {
private(set) var count: Int
init() {
count = 0
}
// 代码缩减 (见上面)
// 当用户进行内购
// 提升了他们的分数!
mutating func scaleBy(multiplier: Int) {
count = count * multiplier
}
}
因为 Counter 的值初始化为 0,乘法测试没有效果。
// CounterTests.swift
class CounterTests: XCTestCase {
func testScaleBy() {
var counter = Counter()
XCTAssertEqual(counter.count, 0)
counter.scaleBy(5)
// 正如我们所知,scaleBy 可以做多次乘法运算和除法运算
// 要么只是返回 count ,要么只是返回 0
XCTAssertEqual(counter.count, 0)
}
}
为了进行有效的测试,我们需要在 count 不为 0 的情况下测试我们的 scaleBy 方法,所以我们需要控制计数器的初始值。我们可以使用默认值和正确的初始值注入 init 函数(译者注:作者这里的意思是,如果初始化的时候,不给 init 函数参数,则使用默认值;反之则使用给定的初始值。):
// Counter.swift
struct Counter {
private(set) var count: Int
// 依赖注入
// 计数器的初始值是注入的
init(count: Int = 0) {
self.count = count
}
mutating func scaleBy(multiplier: Int) {
count = count * multiplier
}
}
现在测试如下!
// CounterTests.swift
class CounterTests: XCTestCase {
func testScaleBy() {
// 这次计数器从一个不为零的值开始
var counter = Counter(count: 5)
XCTAssertEqual(counter.count, 5)
counter.scaleBy(5)
XCTAssertEqual(counter.count, 25)
}
}
就是这样!通过添加一个初始值是我们想要的初始化函数,我们保持了计数器的完整性,该函数的作用是编写有效的测试!
本文由 SwiftGG 翻译组翻译,已经获得作者翻译授权,最新文章请访问 http://swift.gg。