From 767fcfecbfd53c507152f6cf15c846176bae561d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marco=20Zu=CC=88hlke?= Date: Wed, 8 May 2024 22:56:36 +0200 Subject: [PATCH] Fix Scala 3 check the artifact contains a cross version, so only comparing the artifact name leads to the correct result adapt lowest Scala 3 NEXT version --- .../org/scalasteward/core/data/package.scala | 2 +- .../org/scalasteward/core/update/FilterAlg.scala | 5 +++-- .../scalasteward/core/update/FilterAlgTest.scala | 15 ++++++++++++--- 3 files changed, 16 insertions(+), 6 deletions(-) diff --git a/modules/core/src/main/scala/org/scalasteward/core/data/package.scala b/modules/core/src/main/scala/org/scalasteward/core/data/package.scala index 57c5dde690..3ab49444d8 100644 --- a/modules/core/src/main/scala/org/scalasteward/core/data/package.scala +++ b/modules/core/src/main/scala/org/scalasteward/core/data/package.scala @@ -37,5 +37,5 @@ package object data { val scalaLangModules: List[(GroupId, ArtifactId)] = scala2LangModules ++ scala3LangModules - val scalaNextMinVersion: Version = Version("3.4.0") + val scalaNextMinVersion: Version = Version("3.4.0-NIGHTLY") } diff --git a/modules/core/src/main/scala/org/scalasteward/core/update/FilterAlg.scala b/modules/core/src/main/scala/org/scalasteward/core/update/FilterAlg.scala index 1440fef1ec..ca600df4e2 100644 --- a/modules/core/src/main/scala/org/scalasteward/core/update/FilterAlg.scala +++ b/modules/core/src/main/scala/org/scalasteward/core/update/FilterAlg.scala @@ -79,13 +79,14 @@ object FilterAlg { val filteredVersions = update.newerVersions.filterNot(_ >= scalaNextMinVersion) if (filteredVersions.nonEmpty) Right(update.copy(newerVersions = Nel.fromListUnsafe(filteredVersions))) - else Left(IgnoreScalaNext(update)) + else + Left(IgnoreScalaNext(update)) } } def isScala3Lang(update: Update.ForArtifactId): Boolean = scala3LangModules.exists { case (g, a) => - update.groupId == g && update.artifactIds.exists(_ == a) + update.groupId == g && update.artifactIds.exists(_.name == a.name) } private def globalFilter(update: Update.ForArtifactId, repoConfig: RepoConfig): FilterResult = diff --git a/modules/core/src/test/scala/org/scalasteward/core/update/FilterAlgTest.scala b/modules/core/src/test/scala/org/scalasteward/core/update/FilterAlgTest.scala index b1bd71da65..c3065f4de7 100644 --- a/modules/core/src/test/scala/org/scalasteward/core/update/FilterAlgTest.scala +++ b/modules/core/src/test/scala/org/scalasteward/core/update/FilterAlgTest.scala @@ -254,17 +254,26 @@ class FilterAlgTest extends FunSuite { test("scalaLTSFilter: LTS, filter versions") { val update = - ("org.scala-lang".g % "scala3-compiler".a % "3.3.2" %> Nel.of("3.3.3", "3.4.0")).single + ("org.scala-lang".g % ("scala3-compiler", "scala3-compiler_3").a % "3.3.2" %> Nel.of( + "3.3.3", + "3.4.0" + )).single assertEquals(scalaLTSFilter(update), Right(update.copy(newerVersions = Nel.of("3.3.3".v)))) } test("scalaLTSFilter: Next") { - val update = ("org.scala-lang".g % "scala3-compiler".a % "3.4.0" %> Nel.of("3.4.1")).single + val update = + ("org.scala-lang".g % ("scala3-compiler", "scala3-compiler_3").a % "3.4.0" %> Nel.of( + "3.4.1" + )).single assertEquals(scalaLTSFilter(update), Right(update)) } test("isScala3Lang: true") { - val update = ("org.scala-lang".g % "scala3-compiler".a % "3.3.3" %> Nel.of("3.4.0")).single + val update = + ("org.scala-lang".g % ("scala3-compiler", "scala3-compiler_3").a % "3.3.3" %> Nel.of( + "3.4.0" + )).single assert(isScala3Lang(update)) }