RxAlamofire: retryWhen 掉进订阅块
RxAlamofire: retryWhen drops into subscribe block
我正在尝试实现最大重试次数的 alamofire 调用。代码如下:
RxAlamofire.request(.post, URL, parameters: parameters, encoding: JSONEncoding.default)
.observeOn(MainScheduler.instance)
.retryWhen { (errors: Observable<Error>) in
return errors.flatMapWithIndex { (e, a) -> Observable<Int64> in
if a >= self.RETRY_COUNT - 1 {
return Observable.error(e)
}
print("Error: delay server call retry by \(a+1) second(s)")
return Observable<Int64>.timer(RxTimeInterval(a+1), scheduler: MainScheduler.instance)
}
}
.subscribe(
onNext: {
(result) in
print("I get here when retrying...")
},
onError: { (error) in
print(error)
}
)
.addDisposableTo(self.disposeBag)
不幸的是,在重试时,我进入了订阅中的 onNext 块 - 在得到结果之前我不想到达那里。 (在超过预期的最大重试次数后,onError 给出错误)。有人可以帮忙吗?
我已尝试重现您的场景,但以下代码不会在发生错误时触发订阅中的 onNext 关闭。
我稍微重写了你的代码,我的例子总是出错。我正在使用 RxSwift 4.0.0.
let count = 2
enum MyError: Error {
case crash
}
_ = Observable<Int>.error(MyError.crash)
.debug("prior")
.retryWhen { errors in
return errors.enumerated().flatMap { (index, error) -> Observable<Void> in
guard index < count - 1 else { return .error(error) }
print("Error: delay server call retry by \(index + 1) second(s)")
return Observable<Void>.just(()).delay(RxTimeInterval(index + 1), scheduler: MainScheduler.instance)
}
}
.debug("after")
.subscribe(onNext: { element in
print("got next element: \(element)")
})
这会导致以下输出。
2018-03-16 09:05:16.921: after -> subscribed
2018-03-16 09:05:16.924: prior -> subscribed
2018-03-16 09:05:16.924: prior -> Event error(blok)
Error: delay server call retry by 1 second(s)
2018-03-16 09:05:16.925: prior -> isDisposed
2018-03-16 09:05:17.926: prior -> subscribed
2018-03-16 09:05:17.926: prior -> Event error(blok)
2018-03-16 09:05:17.927: after -> Event error(blok)
2018-03-16 09:05:17.928: after -> isDisposed
2018-03-16 09:05:17.928: prior -> isDisposed
我正在尝试实现最大重试次数的 alamofire 调用。代码如下:
RxAlamofire.request(.post, URL, parameters: parameters, encoding: JSONEncoding.default)
.observeOn(MainScheduler.instance)
.retryWhen { (errors: Observable<Error>) in
return errors.flatMapWithIndex { (e, a) -> Observable<Int64> in
if a >= self.RETRY_COUNT - 1 {
return Observable.error(e)
}
print("Error: delay server call retry by \(a+1) second(s)")
return Observable<Int64>.timer(RxTimeInterval(a+1), scheduler: MainScheduler.instance)
}
}
.subscribe(
onNext: {
(result) in
print("I get here when retrying...")
},
onError: { (error) in
print(error)
}
)
.addDisposableTo(self.disposeBag)
不幸的是,在重试时,我进入了订阅中的 onNext 块 - 在得到结果之前我不想到达那里。 (在超过预期的最大重试次数后,onError 给出错误)。有人可以帮忙吗?
我已尝试重现您的场景,但以下代码不会在发生错误时触发订阅中的 onNext 关闭。 我稍微重写了你的代码,我的例子总是出错。我正在使用 RxSwift 4.0.0.
let count = 2
enum MyError: Error {
case crash
}
_ = Observable<Int>.error(MyError.crash)
.debug("prior")
.retryWhen { errors in
return errors.enumerated().flatMap { (index, error) -> Observable<Void> in
guard index < count - 1 else { return .error(error) }
print("Error: delay server call retry by \(index + 1) second(s)")
return Observable<Void>.just(()).delay(RxTimeInterval(index + 1), scheduler: MainScheduler.instance)
}
}
.debug("after")
.subscribe(onNext: { element in
print("got next element: \(element)")
})
这会导致以下输出。
2018-03-16 09:05:16.921: after -> subscribed
2018-03-16 09:05:16.924: prior -> subscribed
2018-03-16 09:05:16.924: prior -> Event error(blok)
Error: delay server call retry by 1 second(s)
2018-03-16 09:05:16.925: prior -> isDisposed
2018-03-16 09:05:17.926: prior -> subscribed
2018-03-16 09:05:17.926: prior -> Event error(blok)
2018-03-16 09:05:17.927: after -> Event error(blok)
2018-03-16 09:05:17.928: after -> isDisposed
2018-03-16 09:05:17.928: prior -> isDisposed