我正在尝试在当前应用程序中对所有网络呼叫使用午睡。
和往常一样,我正在编写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())

10-08 06:28