Skip to content

Commit

Permalink
Merge #2151 into 3.4.0-M1
Browse files Browse the repository at this point in the history
  • Loading branch information
simonbasle committed May 19, 2020
2 parents a60c682 + b40b8db commit cf38eef
Show file tree
Hide file tree
Showing 6 changed files with 197 additions and 17 deletions.
5 changes: 2 additions & 3 deletions build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,6 @@ buildscript {
maven { url "https://repo.spring.io/plugins-release" }
}
dependencies {
classpath 'org.springframework.build.gradle:propdeps-plugin:0.0.7' //still uses the old ways
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:${kotlinVersion}"
}
}
Expand All @@ -33,7 +32,7 @@ plugins {
id "de.undercouch.download" version "3.4.3"
id "org.unbroken-dome.test-sets" version "3.0.0" apply false
//note: build scan plugin now must be applied in settings.gradle
id "com.jfrog.artifactory" version "4.9.8" apply false
id "com.jfrog.artifactory" version "4.15.2" apply false
id 'biz.aQute.bnd.builder' version '5.0.1' apply false
}

Expand Down Expand Up @@ -97,7 +96,6 @@ if (System.getenv('GRADLE_ENTERPRISE_URL')) {
configure(subprojects) { p ->
apply plugin: 'java'
apply plugin: 'jacoco'
apply plugin: 'propdeps' //TODO replace with a simpler local plugin?
apply from: "${rootDir}/gradle/setup.gradle"

description = 'Non-Blocking Reactive Foundation for the JVM'
Expand Down Expand Up @@ -199,6 +197,7 @@ gradle.allprojects() { p ->
configure(subprojects) { p ->
//these apply once the above configure is done, but before project-specific build.gradle have applied
apply plugin: "io.reactor.gradle.java-conventions"
apply plugin: "io.reactor.gradle.optional-dependencies"
apply from: "${rootDir}/gradle/javadoc.gradle"

//these apply AFTER project-specific build.gradle have applied
Expand Down
30 changes: 17 additions & 13 deletions buildSrc/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -39,18 +39,22 @@ test {
}

gradlePlugin {
plugins {
customVersionPlugin {
id = "io.reactor.gradle.custom-version"
implementationClass = "io.reactor.gradle.CustomVersionPlugin"
plugins {
customVersionPlugin {
id = "io.reactor.gradle.custom-version"
implementationClass = "io.reactor.gradle.CustomVersionPlugin"
}
detectCIPlugin {
id = "io.reactor.gradle.detect-ci"
implementationClass = "io.reactor.gradle.DetectCiPlugin"
}
javaConventionsPlugin {
id = "io.reactor.gradle.java-conventions"
implementationClass = "io.reactor.gradle.JavaConventions"
}
optionalDependenciesPlugin {
id = "io.reactor.gradle.optional-dependencies"
implementationClass = "io.reactor.gradle.OptionalDependenciesPlugin"
}
}
detectCIPlugin {
id = "io.reactor.gradle.detect-ci"
implementationClass = "io.reactor.gradle.DetectCiPlugin"
}
javaConventionsPlugin {
id = "io.reactor.gradle.java-conventions"
implementationClass = "io.reactor.gradle.JavaConventions"
}
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,65 @@
/*
* Copyright (c) 2011-Present VMware Inc. or its affiliates, All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/

package io.reactor.gradle;

import org.gradle.api.Plugin;
import org.gradle.api.Project;
import org.gradle.api.artifacts.Configuration;
import org.gradle.api.attributes.Usage;
import org.gradle.api.plugins.JavaPlugin;
import org.gradle.api.plugins.JavaPluginConvention;
import org.gradle.api.tasks.SourceSetContainer;
import org.gradle.api.tasks.javadoc.Javadoc;
import org.gradle.plugins.ide.eclipse.EclipsePlugin;
import org.gradle.plugins.ide.eclipse.model.EclipseModel;

/**
* A {@code Plugin} that adds support for Maven-style optional dependencies. Creates a new
* {@code optional} configuration. The {@code optional} configuration is part of the
* project's compile and runtime classpath's but does not affect the classpath of
* dependent projects.
*
* @author Andy Wilkinson
*/
public class OptionalDependenciesPlugin implements Plugin<Project> {

/**
* Name of the {@code optional} configuration.
*/
public static final String OPTIONAL_CONFIGURATION_NAME = "optional";

@Override
public void apply(Project project) {
Configuration optional = project.getConfigurations().create(OPTIONAL_CONFIGURATION_NAME);
optional.attributes((attributes) -> attributes.attribute(Usage.USAGE_ATTRIBUTE,
project.getObjects().named(Usage.class, Usage.JAVA_RUNTIME)));
project.getPlugins().withType(JavaPlugin.class, (javaPlugin) -> {
SourceSetContainer sourceSets = project.getConvention().getPlugin(JavaPluginConvention.class)
.getSourceSets();
sourceSets.all((sourceSet) -> {
sourceSet.setCompileClasspath(sourceSet.getCompileClasspath().plus(optional));
sourceSet.setRuntimeClasspath(sourceSet.getRuntimeClasspath().plus(optional));
});
project.getTasks().withType(Javadoc.class)
.all((javadoc) -> javadoc.setClasspath(javadoc.getClasspath().plus(optional)));
});
project.getPlugins().withType(EclipsePlugin.class,
(eclipsePlugin) -> project.getExtensions().getByType(EclipseModel.class)
.classpath((classpath) -> classpath.getPlusConfigurations().add(optional)));
}

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,110 @@
/*
* Copyright (c) 2011-Present VMware Inc. or its affiliates, All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/

package io.reactor.gradle;

import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.io.PrintWriter;

import org.gradle.testkit.runner.BuildResult;
import org.gradle.testkit.runner.GradleRunner;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.io.TempDir;

import static org.assertj.core.api.Assertions.assertThat;

/**
* Integration tests for {@link OptionalDependenciesPlugin}.
*
* @author Andy Wilkinson
*/
public class OptionalDependenciesPluginTest {

private File projectDir;

private File buildFile;

@BeforeEach
public void setup(@TempDir File projectDir) throws IOException {
this.projectDir = projectDir;
this.buildFile = new File(this.projectDir, "build.gradle");
}

@Test
void optionalConfigurationIsCreated() throws IOException {
try (PrintWriter out = new PrintWriter(new FileWriter(this.buildFile))) {
out.println("plugins { id 'io.reactor.gradle.optional-dependencies' }");
out.println("task printConfigurations {");
out.println(" doLast {");
out.println(" configurations.all { println it.name }");
out.println(" }");
out.println("}");
}
BuildResult buildResult = runGradle("printConfigurations");
assertThat(buildResult.getOutput()).contains(OptionalDependenciesPlugin.OPTIONAL_CONFIGURATION_NAME);
}

@Test
void optionalDependenciesAreAddedToMainSourceSetsCompileClasspath() throws IOException {
optionalDependenciesAreAddedToSourceSetClasspath("main", "compileClasspath");
}

@Test
void optionalDependenciesAreAddedToMainSourceSetsRuntimeClasspath() throws IOException {
optionalDependenciesAreAddedToSourceSetClasspath("main", "runtimeClasspath");
}

@Test
void optionalDependenciesAreAddedToTestSourceSetsCompileClasspath() throws IOException {
optionalDependenciesAreAddedToSourceSetClasspath("test", "compileClasspath");
}

@Test
void optionalDependenciesAreAddedToTestSourceSetsRuntimeClasspath() throws IOException {
optionalDependenciesAreAddedToSourceSetClasspath("test", "runtimeClasspath");
}

public void optionalDependenciesAreAddedToSourceSetClasspath(String sourceSet, String classpath)
throws IOException {
try (PrintWriter out = new PrintWriter(new FileWriter(this.buildFile))) {
out.println("plugins {");
out.println(" id 'io.reactor.gradle.optional-dependencies'");
out.println(" id 'java'");
out.println("}");
out.println("repositories {");
out.println(" mavenCentral()");
out.println("}");
out.println("dependencies {");
out.println(" optional 'io.projectreactor.addons:reactor-extra:3.3.0.RELEASE'");
out.println("}");
out.println("task printClasspath {");
out.println(" doLast {");
out.println(" println sourceSets." + sourceSet + "." + classpath + ".files");
out.println(" }");
out.println("}");
}
BuildResult buildResult = runGradle("printClasspath");
assertThat(buildResult.getOutput()).contains("reactor-extra");
}

private BuildResult runGradle(String... args) {
return GradleRunner.create().withProjectDir(this.projectDir).withArguments(args).withPluginClasspath().build();
}

}
2 changes: 1 addition & 1 deletion reactor-core/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,7 @@ dependencies {
//Optional Metrics
optional "io.micrometer:micrometer-core:$micrometerVersion"

optional("org.jetbrains.kotlin:kotlin-stdlib:${kotlinVersion}")
optional "org.jetbrains.kotlin:kotlin-stdlib:${kotlinVersion}"

//Optional BlockHound support
optional "io.projectreactor.tools:blockhound:$blockhoundVersion"
Expand Down
2 changes: 2 additions & 0 deletions reactor-test/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,8 @@ ext {
dependencies {
compile project(":reactor-core")

optional "org.jetbrains.kotlin:kotlin-stdlib:${kotlinVersion}"

testCompile "junit:junit:$jUnitVersion"
testImplementation "org.junit.jupiter:junit-jupiter-api:${jUnitJupiterVersion}"
testRuntime "org.junit.jupiter:junit-jupiter-engine:${jUnitJupiterVersion}"
Expand Down

0 comments on commit cf38eef

Please sign in to comment.