From 7407ec63de6fa7fe74c7ce86778085c07c7de286 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bendix=20S=C3=A4ltz?= Date: Sat, 26 Nov 2022 22:40:13 +0100 Subject: [PATCH] Address deprecations in FeedbackTest (#709) * Address deprecations in FeedbackTest * Cleanup build.sbt --- build.sbt | 14 +++------ .../com/sksamuel/scapegoat/FeedbackTest.scala | 29 +++++++++++-------- .../inspections/BooleanParameterTest.scala | 4 +-- 3 files changed, 23 insertions(+), 24 deletions(-) diff --git a/build.sbt b/build.sbt index fe33d2f0..4dc3d69e 100644 --- a/build.sbt +++ b/build.sbt @@ -35,21 +35,17 @@ crossTarget := { ThisBuild / useCoursier := false val scalac13Options = Seq( - "-Xlint:adapted-args", "-Xlint:inaccessible", "-Xlint:infer-any", - "-Xlint:nullary-unit", "-Xlint:strict-unsealed-patmat", "-Yrangepos", "-Ywarn-unused", "-Xsource:3" ) val scalac12Options = Seq( - "-Xlint:adapted-args", "-Ywarn-inaccessible", "-Ywarn-infer-any", "-Xlint:nullary-override", - "-Xlint:nullary-unit", "-Xmax-classfile-name", "254" ) @@ -61,15 +57,13 @@ scalacOptions := { "-feature", "-encoding", "utf8", - "-Xlint" + "-Xlint", + "-Xlint:adapted-args", + "-Xlint:nullary-unit" ) common ++ (scalaBinaryVersion.value match { case "2.12" => scalac12Options - case "2.13" => - scalac13Options ++ (scalaVersion.value.split('.') match { - case Array(_, _, patch) if Set("0", "1", "2")(patch) => Seq("-Xlint:nullary-override") - case _ => Seq.empty[String] - }) + case "2.13" => scalac13Options }) } javacOptions ++= Seq("-source", "1.8", "-target", "1.8") diff --git a/src/test/scala/com/sksamuel/scapegoat/FeedbackTest.scala b/src/test/scala/com/sksamuel/scapegoat/FeedbackTest.scala index 4faf4ad3..7661c66a 100644 --- a/src/test/scala/com/sksamuel/scapegoat/FeedbackTest.scala +++ b/src/test/scala/com/sksamuel/scapegoat/FeedbackTest.scala @@ -1,6 +1,7 @@ package com.sksamuel.scapegoat import scala.reflect.internal.util.NoPosition +import scala.tools.nsc.Settings import scala.tools.nsc.reporters.StoreReporter import org.scalatest.freespec.AnyFreeSpec @@ -31,17 +32,18 @@ class FeedbackTest extends AnyFreeSpec with Matchers with OneInstancePerTest wit "This is description.", "This is explanation." ) - val reporter = new StoreReporter + val reporter = new StoreReporter(new Settings()) val feedback = new Feedback(reporter, testConfiguration(consoleOutput = true, defaultSourcePrefix)) feedback.warn(position, inspection) reporter.infos should contain( - reporter.Info( + StoreReporter.Info( position, "[scapegoat] [DummyInspection] My default is Error\n This is explanation.", reporter.ERROR ) ) } + "for warning" in { val inspection = new DummyInspection( "My default is Warning", @@ -49,17 +51,18 @@ class FeedbackTest extends AnyFreeSpec with Matchers with OneInstancePerTest wit "This is description.", "This is explanation." ) - val reporter = new StoreReporter + val reporter = new StoreReporter(new Settings()) val feedback = new Feedback(reporter, testConfiguration(consoleOutput = true, defaultSourcePrefix)) feedback.warn(position, inspection) reporter.infos should contain( - reporter.Info( + StoreReporter.Info( position, "[scapegoat] [DummyInspection] My default is Warning\n This is explanation.", reporter.WARNING ) ) } + "for info" in { val inspection = new DummyInspection( "My default is Info", @@ -67,11 +70,11 @@ class FeedbackTest extends AnyFreeSpec with Matchers with OneInstancePerTest wit "This is description.", "This is explanation." ) - val reporter = new StoreReporter + val reporter = new StoreReporter(new Settings()) val feedback = new Feedback(reporter, testConfiguration(consoleOutput = true, defaultSourcePrefix)) feedback.warn(position, inspection) reporter.infos should contain( - reporter.Info( + StoreReporter.Info( position, "[scapegoat] [DummyInspection] My default is Info\n This is explanation.", reporter.INFO @@ -79,10 +82,11 @@ class FeedbackTest extends AnyFreeSpec with Matchers with OneInstancePerTest wit ) } } + "should use proper paths" - { "for `src/main/scala`" in { val normalizeSourceFile = PrivateMethod[String](Symbol("normalizeSourceFile")) - val reporter = new StoreReporter + val reporter = new StoreReporter(new Settings()) val feedback = new Feedback(reporter, testConfiguration(consoleOutput = true, defaultSourcePrefix)) val source = "src/main/scala/com/sksamuel/scapegoat/Test.scala" val result = feedback invokePrivate normalizeSourceFile(source) @@ -91,7 +95,7 @@ class FeedbackTest extends AnyFreeSpec with Matchers with OneInstancePerTest wit "for `app`" in { val normalizeSourceFile = PrivateMethod[String](Symbol("normalizeSourceFile")) - val reporter = new StoreReporter + val reporter = new StoreReporter(new Settings()) val feedback = new Feedback(reporter, testConfiguration(consoleOutput = true, "app/")) val source = "app/com/sksamuel/scapegoat/Test.scala" val result = feedback invokePrivate normalizeSourceFile(source) @@ -100,13 +104,14 @@ class FeedbackTest extends AnyFreeSpec with Matchers with OneInstancePerTest wit "should add trailing / to the sourcePrefix automatically" in { val normalizeSourceFile = PrivateMethod[String](Symbol("normalizeSourceFile")) - val reporter = new StoreReporter + val reporter = new StoreReporter(new Settings()) val feedback = new Feedback(reporter, testConfiguration(consoleOutput = true, "app/custom")) val source = "app/custom/com/sksamuel/scapegoat/Test.scala" val result = feedback invokePrivate normalizeSourceFile(source) result should ===("com.sksamuel.scapegoat.Test.scala") } } + "should use minimal warning level in reports" - { "for `info`" in { val inspectionError = new DummyInspection( @@ -128,7 +133,7 @@ class FeedbackTest extends AnyFreeSpec with Matchers with OneInstancePerTest wit "This is explanation." ) val inspections = Seq(inspectionError, inspectionWarning, inspectionInfo) - val reporter = new StoreReporter + val reporter = new StoreReporter(new Settings()) val feedback = new Feedback(reporter, testConfiguration(consoleOutput = true, defaultSourcePrefix, Levels.Info)) inspections.foreach(inspection => feedback.warn(position, inspection)) @@ -155,7 +160,7 @@ class FeedbackTest extends AnyFreeSpec with Matchers with OneInstancePerTest wit "This is explanation." ) val inspections = Seq(inspectionError, inspectionWarning, inspectionInfo) - val reporter = new StoreReporter + val reporter = new StoreReporter(new Settings()) val feedback = new Feedback( reporter, @@ -187,7 +192,7 @@ class FeedbackTest extends AnyFreeSpec with Matchers with OneInstancePerTest wit "This is explanation." ) val inspections = Seq(inspectionError, inspectionWarning, inspectionInfo) - val reporter = new StoreReporter + val reporter = new StoreReporter(new Settings()) val feedback = new Feedback(reporter, testConfiguration(consoleOutput = false, defaultSourcePrefix, Levels.Error)) inspections.foreach(inspection => feedback.warn(position, inspection)) diff --git a/src/test/scala/com/sksamuel/scapegoat/inspections/BooleanParameterTest.scala b/src/test/scala/com/sksamuel/scapegoat/inspections/BooleanParameterTest.scala index 59d78803..f168e257 100644 --- a/src/test/scala/com/sksamuel/scapegoat/inspections/BooleanParameterTest.scala +++ b/src/test/scala/com/sksamuel/scapegoat/inspections/BooleanParameterTest.scala @@ -10,8 +10,8 @@ class BooleanParameterTest extends InspectionTest { "should report info" - { "for methods using Boolean parameter" in { val code = """class Test { - def foo(bool: Boolean) = 4 - } """.stripMargin + def foo(bool: Boolean) = 4 + }""".stripMargin compileCodeSnippet(code) compiler.scapegoat.feedback.warnings.size shouldBe 1