Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Facilitate using the plugin for custom reports #121

Open
wants to merge 5 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion build.sbt
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ inThisBuild(List(
url("https://github.com/alexarchambault")
)
),
versionPolicyIntention := Compatibility.BinaryAndSourceCompatible,
versionPolicyIntention := Compatibility.BinaryCompatible,
libraryDependencySchemes += "com.typesafe" %% "mima-core" % "semver-spec"
))

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ package sbtversionpolicy
import coursier.version.VersionCompatibility
import sbt._
import sbt.librarymanagement.DependencyBuilders.OrganizationArtifactName
import sbtversionpolicy.internal.DependencyCheck

import scala.util.matching.Regex

Expand All @@ -13,6 +14,7 @@ trait SbtVersionPolicyKeys {
final val versionPolicyCheck = taskKey[Unit]("Runs both versionPolicyReportDependencyIssues and versionPolicyMimaCheck")
final val versionPolicyMimaCheck = taskKey[Unit]("Runs Mima to check backward or forward compatibility depending on the intended change defined via versionPolicyIntention.")
final val versionPolicyForwardCompatibilityCheck = taskKey[Unit]("Report forward binary compatible issues from Mima.")
final val versionPolicyDependencyIssuesReporter = taskKey[DependencyCheck.Reporter]("Helper to find issues in the library dependencies.")
final val versionPolicyFindDependencyIssues = taskKey[Seq[(ModuleID, DependencyCheckReport)]]("Compatibility issues in the library dependencies.")
final val versionCheck = taskKey[Unit]("Checks that the version is consistent with the intended compatibility level defined via versionPolicyIntention")

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ object SbtVersionPolicyMima extends AutoPlugin {
private def moduleName(m: ModuleID, sv: String, sbv: String): String =
moduleName(m.crossVersion, sv, sbv, m.name)

private lazy val previousVersionsFromRepo = Def.setting {
lazy val previousVersionsFromRepo = Def.setting {
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
lazy val previousVersionsFromRepo = Def.setting {
private[sbtversionpolicy] lazy val previousVersionsFromRepo = Def.setting {


val projId = Keys.projectID.value
val sv = Keys.scalaVersion.value
Expand Down Expand Up @@ -103,18 +103,20 @@ object SbtVersionPolicyMima extends AutoPlugin {
},

mimaPreviousArtifacts := {
val projId = Keys.projectID.value.withExplicitArtifacts(Vector.empty)
val previousVersions0 = versionPolicyPreviousVersions.value

previousVersions0.toSet.map { version =>
projId
.withExtraAttributes {
projId.extraAttributes
.filter(!_._1.stripPrefix("e:").startsWith("info."))
}
.withRevision(version)
}
computePreviousArtifacts(Keys.projectID.value, versionPolicyPreviousVersions.value)
}
)

def computePreviousArtifacts(projectID: ModuleID, previousVersions: Seq[String]) = {
val projId = projectID.withExplicitArtifacts(Vector.empty)

previousVersions.toSet.map { version =>
projId
.withExtraAttributes {
projId.extraAttributes
.filter(!_._1.stripPrefix("e:").startsWith("info."))
}
.withRevision(version)
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -93,22 +93,25 @@ object SbtVersionPolicySettings {

def previousArtifactsSettings = Def.settings(
versionPolicyPreviousArtifactsFromMima := {
import Ordering.Implicits._
MimaPlugin.autoImport.mimaPreviousArtifacts.value
.toVector
.map { mod =>
val splitVersion = mod.revision.split('.').map(s => Try(s.toInt).getOrElse(-1)).toSeq
(splitVersion, mod)
}
.sortBy(_._1)
.map(_._2)
fromMimaArtifacts(MimaPlugin.autoImport.mimaPreviousArtifacts.value)
},

versionPolicyPreviousArtifacts := versionPolicyPreviousArtifactsFromMima.value
)

def fromMimaArtifacts(artifacts: Set[sbt.ModuleID]) = {
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
def fromMimaArtifacts(artifacts: Set[sbt.ModuleID]) = {
private def fromMimaArtifacts(artifacts: Set[sbt.ModuleID]) = {

import Ordering.Implicits.*
artifacts
.toVector
.map { mod =>
val splitVersion = mod.revision.split('.').map(s => Try(s.toInt).getOrElse(-1)).toSeq
(splitVersion, mod)
}
.sortBy(_._1)
.map(_._2)
}

def findIssuesSettings = Def.settings(
versionPolicyFindDependencyIssues := {
versionPolicyDependencyIssuesReporter := {
val log = streams.value.log
val sv = scalaVersion.value
val sbv = scalaBinaryVersion.value
Expand All @@ -117,9 +120,6 @@ object SbtVersionPolicySettings {
sys.error("Compile configuration not found in update report")
}

val compatibilityIntention =
versionPolicyIntention.?.value
.getOrElse(throw new MessageOnlyException("Please set the key versionPolicyIntention to declare the compatibility you want to check"))
val depRes = versionPolicyDependencyResolution.value
val scalaModuleInf = versionPolicyScalaModuleInfo.value
val updateConfig = versionPolicyUpdateConfiguration.value
Expand All @@ -140,42 +140,32 @@ object SbtVersionPolicySettings {
log
)

new DependencyCheck.Reporter(
excludedModules,
currentDependencies,
reconciliations,
VersionCompatibility.Strict,
sv,
sbv,
depRes,
scalaModuleInf,
updateConfig,
warningConfig,
log
)
},
versionPolicyFindDependencyIssues := {
val compatibilityIntention = requirePolicyIntentionOrThrow(versionPolicyIntention.?.value)
val previousModuleIds = versionPolicyPreviousArtifacts.value

// Skip dependency check if no compatibility is intended
if (compatibilityIntention == Compatibility.None) Nil else {

previousModuleIds.map { previousModuleId =>

val report0 = DependencyCheck.report(
compatibilityIntention,
excludedModules,
currentDependencies,
previousModuleId,
reconciliations,
VersionCompatibility.Strict,
sv,
sbv,
depRes,
scalaModuleInf,
updateConfig,
warningConfig,
log
)

(previousModuleId, report0)
}
}
versionPolicyDependencyIssuesReporter.value.apply(compatibilityIntention, previousModuleIds)
},
versionPolicyReportDependencyIssues := {
val log = streams.value.log
val sv = scalaVersion.value
val sbv = scalaBinaryVersion.value
val direction = versionPolicyCheckDirection.value
val reports = versionPolicyFindDependencyIssues.value
val intention =
versionPolicyIntention.?.value
.getOrElse(throw new MessageOnlyException("Please set the key versionPolicyIntention to declare the compatibility you want to check"))
val intention = requirePolicyIntentionOrThrow(versionPolicyIntention.?.value)
val currentModule = projectID.value
val formattedPreviousVersions = formatVersions(versionPolicyPreviousVersions.value)

Expand Down Expand Up @@ -263,9 +253,7 @@ object SbtVersionPolicySettings {
},
versionPolicyMimaCheck := Def.taskDyn {
import Compatibility._
val compatibility =
versionPolicyIntention.?.value
.getOrElse(throw new MessageOnlyException("Please set the key versionPolicyIntention to declare the compatibility you want to check"))
val compatibility = requirePolicyIntentionOrThrow(versionPolicyIntention.?.value)
val log = streams.value.log
val currentModule = projectID.value
val formattedPreviousVersions = formatVersions(versionPolicyPreviousVersions.value)
Expand Down Expand Up @@ -302,6 +290,14 @@ object SbtVersionPolicySettings {
}.value
)

private def requirePolicyIntentionOrThrow(maybeCompatibility: Option[Compatibility]) =
maybeCompatibility
.getOrElse(
throw new MessageOnlyException(
"Please set the key versionPolicyIntention to declare the compatibility you want to check"
)
)

def skipSettings = Seq(
versionCheck / skip := (publish / skip).value,
versionPolicyCheck / skip := (publish / skip).value
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,47 @@ object DependencyCheck {
log
)

class Reporter(
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Would you mind adding some documentation?

excludedModules: Set[(String, String)],
currentDependencies: Map[(String, String), String],
reconciliations: Seq[(ModuleMatchers, VersionCompatibility)],
defaultReconciliation: VersionCompatibility,
sv: String,
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
sv: String,
scalaVersion: String,

scalaBinaryVersion: String,
depRes: DependencyResolution,
scalaModuleInf: Option[ScalaModuleInfo],
updateConfig: UpdateConfiguration,
warningConfig: UnresolvedWarningConfiguration,
log: Logger
) {
def apply(compatibilityIntention: Compatibility, previousModuleIds: Seq[ModuleID]) =
// Skip dependency check if no compatibility is intended
if (compatibilityIntention == Compatibility.None) Nil else {

previousModuleIds.map { previousModuleId =>

val report0 = report(
compatibilityIntention,
excludedModules,
currentDependencies,
previousModuleId,
reconciliations,
defaultReconciliation,
sv,
sbv,
depRes,
scalaModuleInf,
updateConfig,
warningConfig,
log
)

(previousModuleId, report0)
}
}

}

private[sbtversionpolicy] def report(
compatibilityIntention: Compatibility,
excludedModules: Set[(String, String)],
Expand Down