Skip to content

Commit 1c4ea7f

Browse files
committed
Add detection of scala version via 'implementation' and 'compileOnly' configurations
1 parent 924bf49 commit 1c4ea7f

File tree

11 files changed

+133
-29
lines changed

11 files changed

+133
-29
lines changed
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,43 @@
1+
package org.scoverage;
2+
3+
import org.junit.Assert;
4+
import org.junit.Test;
5+
import org.junit.runner.RunWith;
6+
import org.junit.runners.Parameterized;
7+
8+
import java.util.Arrays;
9+
import java.util.Collection;
10+
11+
@RunWith(Parameterized.class)
12+
public class DetectScalaLibraryTest extends ScoverageFunctionalTest {
13+
14+
private static final String SCALA_VERSION = "0.0";
15+
private static final String SCALA_LIBRARY_PARAMETER = "-PdetectedScalaLibraryVersion=" + SCALA_VERSION + ".0";
16+
private static final String EXPECTED_OUTPUT = "Using scoverage scalac plugin version '" + SCALA_VERSION;
17+
18+
@Parameterized.Parameter(0)
19+
public String projectDir;
20+
21+
@Parameterized.Parameters(name = "{index}: Project {0} ")
22+
public static Collection<Object[]> data() {
23+
Object[][] data = new Object[][]{{"/compile"}, {"/compileOnly"}, {"/implementation"}, {"/dependency-management"}};
24+
return Arrays.asList(data);
25+
}
26+
27+
public DetectScalaLibraryTest() {
28+
super(null);
29+
}
30+
31+
@Test
32+
public void test() {
33+
setProjectName("detect-scala-library" + projectDir);
34+
35+
// build supposed to fail since repositories are not configured
36+
AssertableBuildResult result = runAndFail("clean", SCALA_LIBRARY_PARAMETER, "--info");
37+
38+
// all we want to know is that the plugin detected our configured library version
39+
String output = result.getResult().getOutput();
40+
Assert.assertTrue(output.contains(EXPECTED_OUTPUT));
41+
}
42+
43+
}

src/functionalTest/java/org.scoverage/ScoverageFunctionalTest.java

+13-9
Original file line numberDiff line numberDiff line change
@@ -23,18 +23,12 @@
2323

2424
public abstract class ScoverageFunctionalTest {
2525

26-
private final String projectName;
27-
private final GradleRunner runner;
26+
private String projectName;
27+
private GradleRunner runner;
2828
private final XmlParser parser;
2929

3030
protected ScoverageFunctionalTest(String projectName) {
31-
32-
this.projectName = projectName;
33-
this.runner = GradleRunner.create()
34-
.withProjectDir(projectDir())
35-
.withPluginClasspath()
36-
.forwardOutput();
37-
31+
setProjectName(projectName);
3832
try {
3933
this.parser = new XmlParser();
4034
parser.setFeature("http://apache.org/xml/features/disallow-doctype-decl", false);
@@ -44,6 +38,16 @@ protected ScoverageFunctionalTest(String projectName) {
4438
}
4539
}
4640

41+
protected void setProjectName(String projectName) {
42+
if (projectName != null) {
43+
this.projectName = projectName;
44+
this.runner = GradleRunner.create()
45+
.withProjectDir(projectDir())
46+
.withPluginClasspath()
47+
.forwardOutput();
48+
}
49+
}
50+
4751
protected File projectDir() {
4852

4953
return new File("src/functionalTest/resources/projects/" + projectName);
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,9 @@
1+
plugins {
2+
id 'org.scoverage'
3+
}
4+
5+
description = 'defines scala library using the "compile" configuration'
6+
7+
dependencies {
8+
compile group: 'org.scala-lang', name: 'scala-library', version: "${detectedScalaLibraryVersion}"
9+
}

src/functionalTest/resources/projects/detect-scala-library/compile/settings.gradle

Whitespace-only changes.
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,9 @@
1+
plugins {
2+
id 'org.scoverage'
3+
}
4+
5+
description = 'defines scala library using the "compileOnly" configuration'
6+
7+
dependencies {
8+
compileOnly group: 'org.scala-lang', name: 'scala-library', version: "${detectedScalaLibraryVersion}"
9+
}

src/functionalTest/resources/projects/detect-scala-library/compileOnly/settings.gradle

Whitespace-only changes.
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,16 @@
1+
plugins {
2+
id 'io.spring.dependency-management' version "1.0.4.RELEASE"
3+
id 'org.scoverage'
4+
}
5+
6+
description = 'defines scala library using the "implementation" configuration and the dependency-management plugin'
7+
8+
dependencyManagement {
9+
dependencies {
10+
dependency group: 'org.scala-lang', name: 'scala-library', version: "${detectedScalaLibraryVersion}"
11+
}
12+
}
13+
14+
dependencies {
15+
implementation group: 'org.scala-lang', name: 'scala-library'
16+
}

src/functionalTest/resources/projects/detect-scala-library/dependency-management/settings.gradle

Whitespace-only changes.
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,9 @@
1+
plugins {
2+
id 'org.scoverage'
3+
}
4+
5+
description = 'defines scala library using the "implementation" configuration'
6+
7+
dependencies {
8+
implementation group: 'org.scala-lang', name: 'scala-library', version: "${detectedScalaLibraryVersion}"
9+
}

src/functionalTest/resources/projects/detect-scala-library/implementation/settings.gradle

Whitespace-only changes.

src/main/groovy/org/scoverage/ScoveragePlugin.groovy

+34-20
Original file line numberDiff line numberDiff line change
@@ -63,27 +63,8 @@ class ScoveragePlugin implements Plugin<PluginAware> {
6363
}
6464

6565
project.afterEvaluate {
66+
def scalaVersion = resolveScalaVersion(project)
6667
def scoverageVersion = project.extensions.scoverage.scoverageVersion.get()
67-
def scalaVersion = null
68-
69-
def scalaLibrary = project.configurations.compile.dependencies.find {
70-
it.group == "org.scala-lang" && it.name == "scala-library"
71-
}
72-
73-
if (scalaLibrary != null) {
74-
scalaVersion = scalaLibrary.version
75-
}
76-
77-
if (scalaVersion == null && project.pluginManager.hasPlugin("io.spring.dependency-management")) {
78-
scalaVersion = project.dependencyManagement.compile.managedVersions["org.scala-lang:scala-library"]
79-
}
80-
81-
if (scalaVersion == null) {
82-
scalaVersion = project.extensions.scoverage.scoverageScalaVersion.get()
83-
} else {
84-
scalaVersion = scalaVersion.substring(0, scalaVersion.lastIndexOf("."))
85-
}
86-
8768
def fullScoverageVersion = "$scalaVersion:$scoverageVersion"
8869

8970
project.logger.info("Using scoverage scalac plugin version '$fullScoverageVersion'")
@@ -319,6 +300,39 @@ class ScoveragePlugin implements Plugin<PluginAware> {
319300
}
320301
}
321302

303+
private String resolveScalaVersion(Project project) {
304+
def scalaVersion = null
305+
306+
def configurations = [
307+
project.configurations.compile,
308+
project.configurations.compileOnly,
309+
project.configurations.implementation
310+
]
311+
def dependencies = configurations.collectMany { it.dependencies }
312+
313+
def scalaLibrary = dependencies.find {
314+
it.group == "org.scala-lang" && it.name == "scala-library"
315+
}
316+
317+
if (scalaLibrary != null) {
318+
scalaVersion = scalaLibrary.version
319+
}
320+
321+
if (scalaVersion == null && project.pluginManager.hasPlugin("io.spring.dependency-management")) {
322+
scalaVersion = project.dependencyManagement.compile.managedVersions["org.scala-lang:scala-library"]
323+
}
324+
325+
if (scalaVersion == null) {
326+
project.logger.info("No scala library detected. Using property 'scoverageScalaVersion'")
327+
scalaVersion = project.extensions.scoverage.scoverageScalaVersion.get()
328+
} else {
329+
project.logger.info("Detected scala library in compilation classpath")
330+
scalaVersion = scalaVersion.substring(0, scalaVersion.lastIndexOf("."))
331+
}
332+
333+
return scalaVersion
334+
}
335+
322336
private Set<? extends Task> recursiveDependenciesOf(Task task) {
323337
if (!taskDependencies.containsKey(task)) {
324338
def directDependencies = task.getTaskDependencies().getDependencies(task)

0 commit comments

Comments
 (0)