我正在尝试在当前应用程序中对所有网络呼叫使用午睡。
和往常一样,我正在编写UT,以确保一切正常。
我目前在午休PUT呼叫上与UT苦苦挣扎:我无法像过去使用Alamofire那样对呼叫进行存根处理。
这是午睡呼叫的代码:
func rateSession(sessionId: Int, rating: Int, completionHandler: (Bool -> Void)? = nil) {
Api.shared.resource("session/" + String(sessionId) + "/rate")
.withParam("user_id", userId)
.request(.PUT, json: ["rate": rating])
.onSuccess { _ in
print("siesta call ok")
completionHandler?(true)
}
.onFailure { _ in
print("siesta call failed")
completionHandler?(false)
}
}
这是用于存根和测试午睡呼叫的代码(使用MockingJay):
// Given
let sessionId = 42
let sessionService = SessionService(userId: "42")
var rateSessionSuccess = false
self.stub(http(.PUT, uri: "http://demo.usievents.com/api/v1/session/42/rate?user_id=42"), builder: http(204))
// When
sessionService.rateSession(sessionId, rating: 1) { success in
rateSessionSuccess = success
}
// Then
expect(rateSessionSuccess).toEventually(beTrue())
打印请求和存根请求没有任何区别。
使用alamofire代替siesta效果很好(调用了stub,我可以修改调用响应以测试所有预期的用例)。
最佳答案
与我的一位同事讨论了此问题之后,似乎Siesta没有使用默认的NSURLSession。
因此,我只是在初始化Siesta服务时添加了默认会话,并且一切正常。super.init(baseURL: environment.apiBaseAddress, networking: NSURLSessionConfiguration.defaultSessionConfiguration())