我来自Java背景,我正在尝试使用Scala编写UnitTests。
我的班级如下:
import com.softwaremill.sttp.{HttpURLConnectionBackend, Uri, sttp}
class MyClient(endpoint: String, principal: String) {
private implicit val serialization = org.json4s.native.Serialization
private implicit val backend = HttpURLConnectionBackend()
def getDataSet(id: String) : Option[DataSet] = {
//sttp.get(url).send <-- will use 'bakend'
}
}这里,隐式变量‘后端’用于插件HTTP客户端实现。
在SttpBackendStub中,我应该插件UnitTest。
implicit val testingBackend = SttpBackendStub.synchronous
.whenRequestMatches(_.uri.path.startsWith("/dataSet"))
.thenRespond(dataSetJson)
val client = new MyClient("http://dummy", "dummy")然而,当我启动HttpURLConnectionBackend实例时,它仍然将使用SttpBackendStub而不是MyClient。
在测试期间,是否有办法将“testingBackend”摄入到MyClient中?
发布于 2019-07-23 03:46:50
在这里使用隐式使您认为问题比它更复杂。您将直接在HttpURLConnectionBackend中实例化MyClient,因此这是您将要得到的“后端”。如果您想使用另一种方法,则必须将其传递给MyClient。您可以为生产使用提供一个默认值,但在测试中实例化它时传递一个模拟。
class MyClient(endpoint: String, principal: String,
implicit val backend: BackendInterface = HttpURLConnectionBackend) {
private implicit val serialization = org.json4s.native.Serialization
def getDataSet(id: String) : Option[DataSet] = {
//sttp.get(url).send <-- will use 'bakend'
}
}在你的测试中:
val testingBackend = SttpBackendStub.synchronous
.whenRequestMatches(_.uri.path.startsWith("/dataSet"))
.thenRespond(dataSetJson)
val client = new MyClient("http://dummy", "dummy", testingBackend)https://stackoverflow.com/questions/57156307
复制相似问题