2

我正在尝试ScalaGettableData使用 scalamock 模拟 Cassandra 对象。我需要模拟以下方法:

def getMap[K : TypeConverter, V : TypeConverter](name: String) = get[Map[K, V]](name)

TypeConverter是 aTrait并且具有隐式实现,例如:

implicit object StringConverter extends TypeConverter[String]

在我的代码中,我正在调用

scalaGettableData.getMap[String, String]("myMap")

我猜它被隐式转换为

scalaGettableData.getMap[StringConverter, StringConverter]("myMap")

我的测试代码如下:

val cassandraRow1 = mock[ScalaGettableData]
(cassandraRow1.getMap[String, String] _).expects("localizations_config").returning(Map("key1" -> "value1"))`

但我收到编译错误:

Error:(28, 26) _ must follow method; cannot follow (name: String)(implicit evidence$3: com.datastax.spark.connector.types.TypeConverter[String], implicit evidence$4: com.datastax.spark.connector.types.TypeConverter[String])Map[String,String] <and> (index: Int)(implicit evidence$3: com.datastax.spark.connector.types.TypeConverter[String], implicit evidence$4: com.datastax.spark.connector.types.TypeConverter[String])Map[String,String]

我应该如何模拟这种方法?

4

1 回答 1

5

也许这个例子有帮助:

"implicit parameters" should "be mockable" in {
  trait Bar[T]
  trait Foo {
    def getMap[K : Bar](name: String): Int
  }

  val m = mock[Foo]
  (m.getMap[Long](_: String)(_: Bar[Long])) expects(*, *) returning 42 once()

  implicit val b = new Bar[Long] {}
  m.getMap("bar")
}

实际上,K : BarScala 编译器将类型参数转换为第二个参数列表,在本示例中使用(_: Bar[Long]).

于 2017-03-05T08:21:57.230 回答