我正在尝试测试用Scala.js编写的React组件,该组件从服务器获取类别列表。我能够为组件提供替代的jQuery实例,但是jQuery模拟本身无法编译。下面是code的代码:
import org.scalajs.jquery.{JQueryXHR, JQueryStatic}
import scala.scalajs.js
import utest._
class jQueryMock extends JQueryStatic {
var awaitedRequests = Map.empty[String, PartialFunction[js.Any, js.Any]]
def whenGet(url: String)(response: PartialFunction[js.Any, js.Any]): Unit = {
awaitedRequests += (url -> response)
}
override def get(url: String, data: js.Any, success: js.Any, dataType: js.Any): JQueryXHR = {
awaitedRequests.get(url) match {
case Some(response) =>
if(response.isDefinedAt(data))
success.asInstanceOf[(js.Any) => Unit](response(data))
else
assert(false)
case None => assert(false)
}
new JQueryXHR {}
}
}根据Scala.js编译器,这段代码有两个问题:
override def get(url: String, data: js.Any, success: js.Any, dataType: js.Any): JQueryXHR = {new JQueryXHR {}是否有其他方法来模拟Scala.js中的任何本机类(或者实际上还有其他方法来测试后端查询)?
编辑
如果我抛出extends JQueryStatic和new JQueryXHR {}并更改def get的返回类型,该类就会编译得很好。通过这种方式,我可以编写处理AJAX的jQuery包装器,我将能够模拟这些东西。这是可行的,但似乎是一个很大的麻烦。还有别的办法吗?
发布于 2015-08-19 08:23:08
我使用我的外观创建了测试,它是模拟的:
正面
class Http {
def get(url: String)(success: (js.UndefOr[js.Any]) => Unit): Unit =
jQuery.getJSON(url, js.undefined, success)
}Mock
class HttpMock extends Http {
var awaitedRequests = Map.empty[String, js.Any]
def whenGet(url: String, response: js.Any): Unit = {
awaitedRequests += (url -> response)
}
def verifyNoOutstandingRequests() =
assert(awaitedRequests.isEmpty)
override def get(url: String)(success: (js.UndefOr[js.Any]) => Unit): Unit = {
awaitedRequests.get(url) match {
case Some(response) =>
success(response)
awaitedRequests -= url
case None => assert(false)
}
}
}https://stackoverflow.com/questions/32088608
复制相似问题