我正在尝试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]
我应该如何模拟这种方法?