Using RxBlocking
RxBlocking是RxSwift中另外一个单独的框架。跟RxTest一样,也需要进行pod引入框架,需要单独倒入。最初的目的是使用toBlocking(timeout:)方法转换观察者序列(observable)到BlockingObservable。
使用RxBlocking,我们可以轻松的测试异步代码。RxBlocking将阻塞当前线程一直到观察者序列(observable)终止,或者我们指定超时时间(默认情况下是nil),如果在观察者序列终止之前到达,那么将抛出错误(RxError.timeout error)。所以本质上是将异步操作转换为同步操作,这样使得测试代码更简单
RxBlocking提供了一些操作符用于测试。但是注意这些操作符仅仅是用于测试目的,不能够用于生产代码
extension ObservableType {
public func toArray() throws -> [E] {}
}
extension ObservableType {
public func first() throws -> E? {}
}
extension ObservableType {
public func last() throws -> E? {}
}
Test toArray Operator
func testToArray() {
//1
let scheduler = ConcurrentDispatchQueueScheduler(qos: .default)
//2
let toArrayObservable = Observable.of("1)","2)").subscribeOn(scheduler)
//3
XCTAssertEqual(try! toArrayObservable.toBlocking().toArray(), ["1)","2)"])
}
1:创建一个并发调度者(toArray operator )来执行异步测试,使用默认的质量服务(thedefault quality of service.)
2:创建一个观察者序列持有两个元素,并且在scheduler上订阅观察者序列
3:首先对toArrayObservable使用toBlocking(),toBlocking()源码如下:
extension ObservableConvertibleType {
/// Converts an Observable into a `BlockingObservable` (an Observable with blocking