Allow muzzle directives to have extra dependencies

This commit is contained in:
Andrew Kent 2018-08-20 19:29:11 -07:00
parent f06eb57449
commit b6d1c18af9
2 changed files with 18 additions and 5 deletions

View File

@ -105,14 +105,14 @@ class MuzzlePlugin implements Plugin<Project> {
project.getLogger().info("configured pass directive: ${pass.group}:${pass.module}:${pass.versions}")
muzzleDirectiveToArtifacts(pass, system, session).collect() { Artifact singleVersion ->
runAfter = addMuzzleTask(true, singleVersion, project, runAfter, bootstrapProject, toolingProject)
runAfter = addMuzzleTask(pass, true, singleVersion, project, runAfter, bootstrapProject, toolingProject)
}
}
for (MuzzleDirective fail : project.muzzle.failDirectives) {
project.getLogger().info("configured fail directive: ${fail.group}:${fail.module}:${fail.versions}")
muzzleDirectiveToArtifacts(fail, system, session).collect() { Artifact singleVersion ->
runAfter = addMuzzleTask(false, singleVersion, project, runAfter, bootstrapProject, toolingProject)
runAfter = addMuzzleTask(fail, false, singleVersion, project, runAfter, bootstrapProject, toolingProject)
}
}
}
@ -202,12 +202,17 @@ class MuzzlePlugin implements Plugin<Project> {
*
* @return The created muzzle task.
*/
private static Task addMuzzleTask(boolean assertPass, Artifact versionArtifact, Project instrumentationProject, Task runAfter, Project bootstrapProject, Project toolingProject) {
private static Task addMuzzleTask(MuzzleDirective directive, boolean assertPass, Artifact versionArtifact, Project instrumentationProject, Task runAfter, Project bootstrapProject, Project toolingProject) {
def taskName = "muzzle-Assert${assertPass ? "Pass" : "Fail"}-$versionArtifact.groupId-$versionArtifact.artifactId-$versionArtifact.version"
def config = instrumentationProject.configurations.create(taskName)
config.dependencies.add(instrumentationProject.dependencies.create("$versionArtifact.groupId:$versionArtifact.artifactId:$versionArtifact.version") {
transitive = true
})
for (String additionalDependency : directive.additionalDependencies) {
config.dependencies.add(instrumentationProject.dependencies.create(additionalDependency) {
transitive = true
})
}
def muzzleTask = instrumentationProject.task(taskName) {
doLast {
@ -276,6 +281,10 @@ class MuzzleDirective {
String group
String module
String versions
List<String> additionalDependencies = new ArrayList<>()
void extraDependency(String compileString) {
additionalDependencies.add(compileString)
}
}
/**

View File

@ -21,12 +21,16 @@ muzzle {
pass {
group = 'com.typesafe.akka'
module = 'akka-http_2.11'
versions = "[10.0.0,10.0.12)"
versions = "[10.0.0,)"
// later versions of akka-http expect streams to be provided
extraDependency 'com.typesafe.akka:akka-stream_2.11:2.4.14'
}
pass {
group = 'com.typesafe.akka'
module = 'akka-http_2.12'
versions = "[10.0.0,10.0.12)"
versions = "[10.0.0,)"
// later versions of akka-http expect streams to be provided
extraDependency 'com.typesafe.akka:akka-stream_2.12:2.4.14'
}
}