考虑以下类型结构:
trait HasId[T] {
def id: T
}
case class Entity(id: Long) extends HasId[Long]
比方说,我们想在一些测试中模拟 Entity 类。
val entityMock = mock[Entity]
Mockito.when(entityMock.id).thenReturn(0)
播放这样的测试导致抛出 NullPointerException(在第二行),可能是因为 scala 编译器行为包装原始类型(如果我们用 String 替换 Long,测试正确执行)。
An exception or error caused a run to abort.
java.lang.NullPointerException
at com.test.Entity$MockitoMock$1085095743.id(Unknown Source)
at com.test.Test.<init>(Test.scala:23)
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
at java.lang.Class.newInstance(Class.java:442)
at org.scalatest.tools.Runner$.genSuiteConfig(Runner.scala:1422)
at org.scalatest.tools.Runner$.$anonfun$doRunRunRunDaDoRunRun$8(Runner.scala:1236)
此错误仅影响 case 类和 2.X 版本中的 mockito。
是否有任何已知的解决方案来处理这个问题?
更新:问题出现在比 2.0.8-beta 新的版本中
最佳答案
这是我的测试课:
import org.mockito.Mockito._
import org.scalatest.mockito.MockitoSugar
import org.scalatest.FlatSpec
class StackOverflowTest extends FlatSpec with MockitoSugar {
"Bla" should
"fsg ll ll" in {
val entityMock = mock[Entity]
when(entityMock.id).thenReturn(0)
foo(entityMock)
}
def foo(entity: Entity) = {
entity.id == 0
}
}
trait HasId[T] {
def id: T
}
case class Entity(id: Long) extends HasId[Long]
这是我的 sbt 文件:
name := "scalaExperiments"
version := "0.1"
scalaVersion := "2.12.4"
libraryDependencies += "org.scalatest" %% "scalatest" % "3.0.4" % Test
libraryDependencies += "org.mockito" % "mockito-all" % "2.0.2-beta" % Test
编译并成功通过。
关于scala - 使用原始类型模拟案例类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48586094/