【问题标题】:SBT - Test.Setup throws java.lang.ClassNotFoundExceptionSBT - Test.Setup 抛出 java.lang.ClassNotFoundException
【发布时间】:2014-04-24 02:44:41
【问题描述】:

我们目前正在使用 SBT 和 Play 做一个项目。

我们希望启动数据库并仅播放 ONCE 以减少测试时间。

SBT 提供 Tests.SetupTests.Cleanup 来执行此操作; http://www.scala-sbt.org/0.12.4/docs/Detailed-Topics/Testing.html

我在test/util/TestServer.scala中定义了以下对象

object TestServer {
  def start = println("hello")
}

为了让这个打印出来,我将它连接到 SBT 配置中:

play.Project(name = appName, applicationVersion = appVersion, dependencies = appDependencies)
    .settings(
      // snip .. wiring resolvers and template/routes imports here
      testOptions in Test += Tests.Argument("junitxml", "console"),
      testOptions in Test += Tests.Setup(_.loadClass("util.TestServer$").getMethod("start").invoke(null)),
      testOptions in Test += Tests.Cleanup(_.loadClass("util.TestServer$").getMethod("stop").invoke(null)),
      scalacOptions += "-feature",
      doc in Compile 

但是当我运行它时,它抱怨找不到 TestServer 类:

$ sh play.sh test
[info] Loading project definition from /Users/markdejong/Projects/malmberg-baps/project
[info] Set current project to Malmberg (in build file:/Users/markdejong/Projects/malmberg-baps/)
[info] Updating {file:/Users/markdejong/Projects/malmberg-baps/}core...
[info] Resolving org.fusesource.jansi#jansi;1.4 ...
[info] Done updating.
[info] Updating {file:/Users/markdejong/Projects/malmberg-baps/}macros...
[info] Resolving org.fusesource.jansi#jansi;1.4 ...
[info] Passed: Total 0, Failed 0, Errors 0, Passed 0
[info] No tests to run for core/test:test
[info] Done updating.
[info] Updating {file:/Users/markdejong/Projects/malmberg-baps/}Malmberg...
[info] Resolving org.apache.httpcomponents#httpclient;4.2 ...
[info] Passed: Total 0, Failed 0, Errors 0, Passed 0
[info] No tests to run for macros/test:test
[info] Resolving org.fusesource.jansi#jansi;1.4 ...
[info] Done updating.
java.lang.ClassNotFoundException: util.TestServer$
    at java.net.URLClassLoader$1.run(URLClassLoader.java:366)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:425)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:358)
    at ApplicationBuild$$anonfun$6$$anonfun$apply$10.apply(Build.scala:89)
    at ApplicationBuild$$anonfun$6$$anonfun$apply$10.apply(Build.scala:89)
    at sbt.ForkTests$$anonfun$sbt$ForkTests$$all$1$1.apply(ForkTests.scala:20)
    at sbt.ForkTests$$anonfun$sbt$ForkTests$$all$1$1.apply(ForkTests.scala:20)
    at sbt.std.TaskExtra$$anon$1$$anonfun$fork$1$$anonfun$apply$1.apply(TaskExtra.scala:99)
    at sbt.std.Transform$$anon$3$$anonfun$apply$2.apply(System.scala:45)
    at sbt.std.Transform$$anon$3$$anonfun$apply$2.apply(System.scala:45)
    at sbt.std.Transform$$anon$4.work(System.scala:64)
    at sbt.Execute$$anonfun$submit$1$$anonfun$apply$1.apply(Execute.scala:237)
    at sbt.Execute$$anonfun$submit$1$$anonfun$apply$1.apply(Execute.scala:237)
    at sbt.ErrorHandling$.wideConvert(ErrorHandling.scala:18)
    at sbt.Execute.work(Execute.scala:244)
    at sbt.Execute$$anonfun$submit$1.apply(Execute.scala:237)
    at sbt.Execute$$anonfun$submit$1.apply(Execute.scala:237)
    at sbt.ConcurrentRestrictions$$anon$4$$anonfun$1.apply(ConcurrentRestrictions.scala:160)
    at sbt.CompletionService$$anon$2.call(CompletionService.scala:30)
    at java.util.concurrent.FutureTask.run(FutureTask.java:262)
    at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:471)
    at java.util.concurrent.FutureTask.run(FutureTask.java:262)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
    at java.lang.Thread.run(Thread.java:745)
[error] (Malmberg/test:executeTests) java.lang.ClassNotFoundException: util.TestServer$
[error] Total time: 11 s, completed Apr 23, 2014 7:11:07 PM

这里有什么问题?

我也尝试过util.TestServer 和 util.TestServer$class,但给出了同样的错误。

使用 sbt 版本 0.13.0 和 Play 2.2.2

【问题讨论】:

标签: scala playframework sbt


【解决方案1】:

感谢 Kenji Yoshida,我找到了问题所在。

确实是 Play Framework 引入的“fork”模式。您必须将其设置为 false 才能使其适用于这些版本。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2016-05-02
    • 1970-01-01
    • 1970-01-01
    • 2019-03-04
    • 1970-01-01
    • 2019-11-09
    • 1970-01-01
    • 2017-05-18
    相关资源
    最近更新 更多