Sbt 未在 Intellij IDEA 上解析 Scalatest

Sbt not resolving Scalatest on Intellij IDEA

我知道已经有关于这个问题的答案,但它们对我不起作用,可能是因为它们现在太老了。

所以我正在 Intellij IDEA Ultimate (SDK 16.0.1) 上创建一个 Scala 项目。我使用 sbt 编译它。我在 src/test/scala 中创建了一个 MainTest class,内容如下:

import org.scalatest.funsuite.AnyFunSuite

class MainTest extends AnyFunSuite {
  test("Example") {
    assert(1 == 1)
  }
}

在我的 build.sbt 文件中我有:

name := "my-scala-project"

version := "0.1"

scalaVersion := "3.0.0-M2"

libraryDependencies += "org.scalatest" %% "scalatest" % "1.4.RC2" % Test

我还通过文件 > 项目结构... > 项目设置 > 库 window

从 Maven 安装了库 org.scalatest:scalatest_2.11:3.1.0

在编辑器上,我可以看到 Intellij 无法解析我的测试文件中的导入,因为它被标记为红色。当我 运行 sbt clean test 时,我收到此错误消息:

[error] -- [E006] Not Found Error: path\to\project\src\test\scala\MainTest.scala:4:2
[error] 4 |  test("Example") {
[error]   |  ^^^^
[error]   |  Not found: test
[error] one error found
[error] one error found
[error] (Test / compileIncremental) Compilation failed

为什么它不起作用?我以为我已经按照预期做了一切。理想情况下,我想使用最新的 3.2.9 版本的 Scalatest。

谢谢

您需要做两件事来修复您的代码:

  1. 更新build.sbt以使用正确的依赖项;和
  2. 用必要的特征扩展你的测试class。

对于 1:

使用以下内容导入 Scalatest 库:

libraryDependencies += "org.scalatest" %% "scalatest" % "3.2.10" % Test

当您在当前配置中使用 _2.11 时,您要求 SBT 为 Scala 2.11 找到您的 scalatest 版本,但您使用的是 Scala 3.1.0。 %% 是一个帮助程序,可以为您的 Scala 版本引入正确的 Scalatest 版本。

对于 2:

将您的文件 as per the documention 更改为:

class MainTest extends AnyFunSuite {
  test("Example") {
    assert(1 == 1)
  }
}

首先,你要把scalaVersion改成3.0.0,这是最新支持的。

就依赖关系而言,正如 Jarrod 提到的,您可以使用

"org.scalatest" %% "scalatest" % "3.2.10" % Test 

当使用 groupID %% artifactID % revision 时,你告诉 sbt 获取适合你提供的 scala 版本的 artifactID,在本例中,3.0.0-M2.

您也可以使用 groupID % artifactID % revision。就像您的问题一样,如果 scalatest_2.11 是 artifactID,则意味着将下载 scala 版本 2.11.xscalatest

我综合了评论中得到的所有帮助:

我不得不在 build.sbt 文件中写这个:

name := "meteo-france-client"

version := "0.1"

scalaVersion := "3.0.0-M2"

libraryDependencies += "org.scalatest" %% "scalatest" % "3.3.0-SNAP3" % Test

然后 sbt reloadsbt clean compile 就可以了。但是我现在得到了这个例外:

[info] compiling 1 Scala source to C:\Users\adrie\OneDrive\Documents\dev\meteo-france-client\target\scala-3.0.0-M2\test-classes ...
[error] ## Exception when compiling 1 sources to C:\Users\adrie\OneDrive\Documents\dev\meteo-france-client\target\scala-3.0.0-M2\test-classes
[error] java.lang.NoClassDefFoundError: scala/collection/immutable/List
[error] xsbt.CachedCompilerImpl.run(CachedCompilerImpl.java:65)
[error] xsbt.CompilerInterface.run(CompilerInterface.java:41)
[error] java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
[error] java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:78)
[error] java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
[error] java.base/java.lang.reflect.Method.invoke(Method.java:567)
[error] sbt.internal.inc.AnalyzingCompiler.invoke(AnalyzingCompiler.scala:329)
[error] sbt.internal.inc.AnalyzingCompiler.compile(AnalyzingCompiler.scala:112)
[error] sbt.internal.inc.MixedAnalyzingCompiler.$anonfun$compile(MixedAnalyzingCompiler.scala:192)
[error] scala.runtime.java8.JFunction0$mcV$sp.apply(JFunction0$mcV$sp.java:23)
[error] sbt.internal.inc.MixedAnalyzingCompiler.timed(MixedAnalyzingCompiler.scala:247)
[error] sbt.internal.inc.MixedAnalyzingCompiler.$anonfun$compile(MixedAnalyzingCompiler.scala:182)
[error] sbt.internal.inc.MixedAnalyzingCompiler.$anonfun$compile$adapted(MixedAnalyzingCompiler.scala:163)
[error] sbt.internal.inc.JarUtils$.withPreviousJar(JarUtils.scala:239)
[error] sbt.internal.inc.MixedAnalyzingCompiler.compileScala(MixedAnalyzingCompiler.scala:163)
[error] sbt.internal.inc.MixedAnalyzingCompiler.compile(MixedAnalyzingCompiler.scala:210)
[error] sbt.internal.inc.IncrementalCompilerImpl.$anonfun$compileInternal(IncrementalCompilerImpl.scala:528)
[error] sbt.internal.inc.IncrementalCompilerImpl.$anonfun$compileInternal$adapted(IncrementalCompilerImpl.scala:528)
[error] sbt.internal.inc.Incremental$.$anonfun$apply(Incremental.scala:175)
[error] sbt.internal.inc.Incremental$.$anonfun$apply$adapted(Incremental.scala:173)
[error] sbt.internal.inc.Incremental$$anon.run(Incremental.scala:459)
[error] sbt.internal.inc.IncrementalCommon$CycleState.next(IncrementalCommon.scala:116)
[error] sbt.internal.inc.IncrementalCommon$$anon.next(IncrementalCommon.scala:56)
[error] sbt.internal.inc.IncrementalCommon$$anon.next(IncrementalCommon.scala:52)
[error] sbt.internal.inc.IncrementalCommon.cycle(IncrementalCommon.scala:263)
[error] sbt.internal.inc.Incremental$.$anonfun$incrementalCompile(Incremental.scala:414)
[error] sbt.internal.inc.Incremental$.withClassfileManager(Incremental.scala:501)
[error] sbt.internal.inc.Incremental$.incrementalCompile(Incremental.scala:401)
[error] sbt.internal.inc.Incremental$.apply(Incremental.scala:167)
[error] sbt.internal.inc.IncrementalCompilerImpl.compileInternal(IncrementalCompilerImpl.scala:528)
[error] sbt.internal.inc.IncrementalCompilerImpl.$anonfun$compileIncrementally(IncrementalCompilerImpl.scala:482)
[error] sbt.internal.inc.IncrementalCompilerImpl.handleCompilationError(IncrementalCompilerImpl.scala:332)
[error] sbt.internal.inc.IncrementalCompilerImpl.compileIncrementally(IncrementalCompilerImpl.scala:420)
[error] sbt.internal.inc.IncrementalCompilerImpl.compile(IncrementalCompilerImpl.scala:137)
[error] sbt.Defaults$.compileIncrementalTaskImpl(Defaults.scala:2357)
[error] sbt.Defaults$.$anonfun$compileIncrementalTask(Defaults.scala:2314)
[error] sbt.internal.io.Retry$.apply(Retry.scala:46)
[error] sbt.internal.io.Retry$.apply(Retry.scala:28)
[error] sbt.internal.io.Retry$.apply(Retry.scala:23)
[error] sbt.internal.server.BspCompileTask$.compute(BspCompileTask.scala:31)
[error] sbt.Defaults$.$anonfun$compileIncrementalTask(Defaults.scala:2310)
[error] scala.Function1.$anonfun$compose(Function1.scala:49)
[error] sbt.internal.util.$tilde$greater.$anonfun$$u2219(TypeFunctions.scala:62)
[error] sbt.std.Transform$$anon.work(Transform.scala:68)
[error] sbt.Execute.$anonfun$submit(Execute.scala:282)
[error] sbt.internal.util.ErrorHandling$.wideConvert(ErrorHandling.scala:23)
[error] sbt.Execute.work(Execute.scala:291)
[error] sbt.Execute.$anonfun$submit(Execute.scala:282)
[error] sbt.ConcurrentRestrictions$$anon.$anonfun$submitValid(ConcurrentRestrictions.scala:265)
[error] sbt.CompletionService$$anon.call(CompletionService.scala:64)
[error] java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264)
[error] java.base/java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:515)
[error] java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264)
[error] java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1130)
[error] java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:630)
[error] java.base/java.lang.Thread.run(Thread.java:831)
[error]
[error] stack trace is suppressed; run 'last Test / compileIncremental' for the full output
[error] (Test / compileIncremental) java.lang.NoClassDefFoundError: scala/collection/immutable/List
[error] Total time: 0 s, completed 26 nov. 2021, 13:33:34

我会再做一个 post :

在此感谢所有帮助过我的人