Cuckoo/Tests/Swift/ProtocolTest.swift

181 lines
4.9 KiB
Swift

import XCTest
import Cuckoo
class ProtocolTest: XCTestCase {
private var mock: MockTestedProtocol!
override func setUp() {
super.setUp()
mock = MockTestedProtocol()
}
func testReadOnlyProperty() {
stub(mock) { mock in
when(mock.readOnlyProperty.get).thenReturn("a")
}
XCTAssertEqual(mock.readOnlyProperty, "a")
verify(mock).readOnlyProperty.get()
}
func testReadWriteProperty() {
var called = false
stub(mock) { mock in
when(mock.readWriteProperty.get).thenReturn(1)
when(mock.readWriteProperty.set(anyInt())).then { _ in called = true }
}
mock.readWriteProperty = 0
XCTAssertEqual(mock.readWriteProperty, 1)
XCTAssertTrue(called)
verify(mock).readWriteProperty.get()
verify(mock).readWriteProperty.set(0)
}
func testOptionalProperty() {
var called = false
stub(mock) { mock in
when(mock.optionalProperty.get).thenReturn(nil)
when(mock.optionalProperty.set(anyInt())).then { _ in called = true }
}
mock.optionalProperty = 0
XCTAssertNil(mock.optionalProperty)
XCTAssertTrue(called)
verify(mock).optionalProperty.get()
verify(mock).optionalProperty.set(equal(to: 0))
}
func testNoReturn() {
var called = false
stub(mock) { mock in
when(mock.noReturn()).then { _ in called = true }
}
mock.noReturn()
XCTAssertTrue(called)
verify(mock).noReturn()
}
func testCountCharacters() {
stub(mock) { mock in
when(mock.count(characters: "a")).thenReturn(1)
}
XCTAssertEqual(mock.count(characters: "a"), 1)
verify(mock).count(characters: "a")
}
func testWithThrows() {
stub(mock) { mock in
when(mock.withThrows()).thenThrow(TestError.unknown)
}
var catched = false
do {
_ = try mock.withThrows()
} catch {
catched = true
}
XCTAssertTrue(catched)
verify(mock).withThrows()
}
func testWithNoReturnThrows() {
stub(mock) { mock in
when(mock.withNoReturnThrows()).thenThrow(TestError.unknown)
}
var catched = false
do {
try mock.withNoReturnThrows()
} catch {
catched = true
}
XCTAssertTrue(catched)
verify(mock).withNoReturnThrows()
}
func testWithClosure() {
stub(mock) { mock in
when(mock.withClosure(anyClosure())).then { $0("a") }
}
XCTAssertEqual(mock.withClosure { _ in 1 }, 1)
verify(mock).withClosure(anyClosure())
}
func testWithEscape() {
var called = false
stub(mock) { mock in
when(mock.withEscape(anyString(), action: anyClosure())).then { text, closure in closure(text) }
}
mock.withEscape("a") { called = $0 == "a" }
XCTAssertTrue(called)
verify(mock).withEscape(anyString(), action: anyClosure())
}
func testWithOptionalClosure() {
var called = false
stub(mock) { mock in
when(mock.withOptionalClosure(anyString(), closure: anyClosure())).then { text, closure in closure?(text) }
}
mock.withOptionalClosure("a") { called = $0 == "a" }
XCTAssertTrue(called)
verify(mock).withOptionalClosure(anyString(), closure: anyClosure())
}
func testWithLabel() {
var called = false
stub(mock) { mock in
when(mock.withLabelAndUnderscore(labelA: anyString(), anyString())).then { _ in called = true }
}
mock.withLabelAndUnderscore(labelA: "a", "b")
XCTAssertTrue(called)
verify(mock).withLabelAndUnderscore(labelA: anyString(), anyString())
}
func testWithImplicitlyUnwrappedOptional() {
stub(mock) { mock in
when(mock.withImplicitlyUnwrappedOptional(i: anyInt())).thenReturn("test")
}
XCTAssertEqual(mock.withImplicitlyUnwrappedOptional(i: 5), "test")
verify(mock).withImplicitlyUnwrappedOptional(i: equal(to: 5))
}
func testEmptyLabels() {
let mock = MockEmptyLabelProtocol<Bool>()
stub(mock) { mock in
when(mock.empty(anyString())).thenReturn(420)
when(mock.empty(anyString())).then { print("OK: \($0)") }
when(mock.empty(any())).thenReturn(true)
}
XCTAssertEqual(mock.empty("hello there"), 420)
mock.empty("here") as Void
XCTAssertTrue(mock.empty(false))
// the calls are ambiguous if we do not specify the input and output types
_ = verify(mock).empty(anyString()) as __DoNotUse<String, Int>
_ = verify(mock).empty(anyString()) as __DoNotUse<String, Void>
_ = verify(mock).empty(any()) as __DoNotUse<Bool, Bool>
}
private enum TestError: Error {
case unknown
}
}