diff --git a/pom.xml b/pom.xml index 4229197c50..7073cb94c3 100644 --- a/pom.xml +++ b/pom.xml @@ -10,7 +10,7 @@ org.codehaus.mojo.versions versions - 2.18.0 + 2.18.1-SNAPSHOT pom Versions @@ -104,7 +104,7 @@ scm:git:https://github.com/mojohaus/versions.git scm:git:ssh://git@github.com/mojohaus/versions.git - 2.18.0 + HEAD https://github.com/mojohaus/versions/tree/master @@ -147,7 +147,7 @@ 0.75C - 2024-11-13T20:43:32Z + 2024-11-13T20:44:06Z diff --git a/versions-api/pom.xml b/versions-api/pom.xml index 96a20f3559..e4c91a5723 100644 --- a/versions-api/pom.xml +++ b/versions-api/pom.xml @@ -5,7 +5,7 @@ org.codehaus.mojo.versions versions - 2.18.0 + 2.18.1-SNAPSHOT versions-api diff --git a/versions-common/pom.xml b/versions-common/pom.xml index 26161efb43..0a8f28f291 100644 --- a/versions-common/pom.xml +++ b/versions-common/pom.xml @@ -4,7 +4,7 @@ org.codehaus.mojo.versions versions - 2.18.0 + 2.18.1-SNAPSHOT versions-common diff --git a/versions-common/src/main/java/org/codehaus/mojo/versions/utils/DependencyBuilder.java b/versions-common/src/main/java/org/codehaus/mojo/versions/utils/DependencyBuilder.java index adfb8b1b65..107d1cf38b 100644 --- a/versions-common/src/main/java/org/codehaus/mojo/versions/utils/DependencyBuilder.java +++ b/versions-common/src/main/java/org/codehaus/mojo/versions/utils/DependencyBuilder.java @@ -15,26 +15,42 @@ * limitations under the License. */ -import java.util.Optional; +import java.util.HashMap; +import java.util.Map; import org.apache.maven.model.Dependency; - -import static java.util.Optional.empty; -import static java.util.Optional.of; -import static java.util.Optional.ofNullable; +import org.apache.maven.model.InputLocation; /** * Builder class for {@linkplain Dependency} */ -@SuppressWarnings("OptionalUsedAsFieldOrParameterType") public class DependencyBuilder { - private Optional groupId = empty(); - private Optional artifactId = empty(); - private Optional version = empty(); - private Optional type = empty(); - private Optional classifier = empty(); - private Optional scope = empty(); - private Optional optional = empty(); + public enum Location { + GROUP_ID("groupId"), + ARTIFACT_ID("artifactId"), + VERSION("version"); + + private final String stringValue; + + Location(String stringValue) { + this.stringValue = stringValue; + } + + @Override + public String toString() { + return stringValue; + } + } + + private static final Dependency TEMPLATE = new Dependency(); + private String groupId = TEMPLATE.getGroupId(); + private String artifactId = TEMPLATE.getArtifactId(); + private String version = TEMPLATE.getVersion(); + private String type = TEMPLATE.getType(); + private String classifier = TEMPLATE.getClassifier(); + private String scope = TEMPLATE.getScope(); + private String optional = TEMPLATE.getOptional(); + private final Map inputLocationMap = new HashMap<>(); private DependencyBuilder() {} @@ -44,7 +60,7 @@ private DependencyBuilder() {} * @return builder instance */ public DependencyBuilder withGroupId(String groupId) { - this.groupId = ofNullable(groupId); + this.groupId = groupId; return this; } @@ -54,7 +70,7 @@ public DependencyBuilder withGroupId(String groupId) { * @return builder instance */ public DependencyBuilder withArtifactId(String artifactId) { - this.artifactId = ofNullable(artifactId); + this.artifactId = artifactId; return this; } @@ -64,7 +80,7 @@ public DependencyBuilder withArtifactId(String artifactId) { * @return builder instance */ public DependencyBuilder withVersion(String version) { - this.version = ofNullable(version); + this.version = version; return this; } @@ -74,7 +90,7 @@ public DependencyBuilder withVersion(String version) { * @return builder instance */ public DependencyBuilder withType(String type) { - this.type = ofNullable(type); + this.type = type; return this; } @@ -84,7 +100,7 @@ public DependencyBuilder withType(String type) { * @return builder instance */ public DependencyBuilder withClassifier(String classifier) { - this.classifier = ofNullable(classifier); + this.classifier = classifier; return this; } @@ -94,7 +110,7 @@ public DependencyBuilder withClassifier(String classifier) { * @return builder instance */ public DependencyBuilder withScope(String scope) { - this.scope = ofNullable(scope); + this.scope = scope; return this; } @@ -104,7 +120,7 @@ public DependencyBuilder withScope(String scope) { * @return builder instance */ public DependencyBuilder withOptional(String optional) { - this.optional = ofNullable(optional); + this.optional = optional; return this; } @@ -114,7 +130,12 @@ public DependencyBuilder withOptional(String optional) { * @return builder instance */ public DependencyBuilder withOptional(boolean optional) { - this.optional = of(String.valueOf(optional)); + this.optional = String.valueOf(optional); + return this; + } + + public DependencyBuilder withLocation(String element, InputLocation location) { + this.inputLocationMap.put(element, location); return this; } @@ -132,14 +153,14 @@ public static DependencyBuilder newBuilder() { */ public Dependency build() { Dependency inst = new Dependency(); - groupId.ifPresent(inst::setGroupId); - artifactId.ifPresent(inst::setArtifactId); - version.ifPresent(inst::setVersion); - type.ifPresent(inst::setType); - classifier.ifPresent(inst::setClassifier); - scope.ifPresent(inst::setScope); - optional.ifPresent(inst::setOptional); - + inst.setGroupId(groupId); + inst.setArtifactId(artifactId); + inst.setVersion(version); + inst.setType(type); + inst.setClassifier(classifier); + inst.setScope(scope); + inst.setOptional(optional); + inputLocationMap.forEach(inst::setLocation); return inst; } } diff --git a/versions-enforcer/pom.xml b/versions-enforcer/pom.xml index 5f1f249ad6..8c51930ae7 100644 --- a/versions-enforcer/pom.xml +++ b/versions-enforcer/pom.xml @@ -4,7 +4,7 @@ org.codehaus.mojo.versions versions - 2.18.0 + 2.18.1-SNAPSHOT versions-enforcer diff --git a/versions-maven-plugin/pom.xml b/versions-maven-plugin/pom.xml index f1069a819e..f3ee85ae5e 100644 --- a/versions-maven-plugin/pom.xml +++ b/versions-maven-plugin/pom.xml @@ -5,7 +5,7 @@ org.codehaus.mojo.versions versions - 2.18.0 + 2.18.1-SNAPSHOT org.codehaus.mojo diff --git a/versions-maven-plugin/src/it/it-display-dependency-updates-008-outputLineWidth/invoker.properties b/versions-maven-plugin/src/it/it-display-dependency-updates-008-outputLineWidth/invoker.properties deleted file mode 100644 index 3a78145dd3..0000000000 --- a/versions-maven-plugin/src/it/it-display-dependency-updates-008-outputLineWidth/invoker.properties +++ /dev/null @@ -1,2 +0,0 @@ -invoker.goals=${project.groupId}:${project.artifactId}:${project.version}:display-dependency-updates -invoker.mavenOpts=-Dverbose=true -Dversions.outputFile=./dependencyUpdate.txt -DoutputEncoding=UTF-8 -Dversions.outputLineWidth=120 \ No newline at end of file diff --git a/versions-maven-plugin/src/it/it-display-dependency-updates-008-outputLineWidth/pom.xml b/versions-maven-plugin/src/it/it-display-dependency-updates-008-outputLineWidth/pom.xml deleted file mode 100644 index 9955ecbc5c..0000000000 --- a/versions-maven-plugin/src/it/it-display-dependency-updates-008-outputLineWidth/pom.xml +++ /dev/null @@ -1,50 +0,0 @@ - - - 4.0.0 - localhost - it-display-dependency-updates-008-displayTerminalWidth - 1.0 - pom - display-dependency-updates - Validate usage of displayTerminalWidth parameter - http://localhost/ - - - localhost - dummy-api - 1.1 - - - - - - - localhost - dummy-maven-plugin - 1.0 - - - maven-clean-plugin - 2.2 - - - maven-deploy-plugin - 2.3 - - - maven-install-plugin - 2.2 - - - maven-site-plugin - 2.0 - - - maven-project-info-reports-plugin - 2.1 - - - - - diff --git a/versions-maven-plugin/src/it/it-display-dependency-updates-008-outputLineWidth/verify.bsh b/versions-maven-plugin/src/it/it-display-dependency-updates-008-outputLineWidth/verify.bsh deleted file mode 100644 index 956ef51dfb..0000000000 --- a/versions-maven-plugin/src/it/it-display-dependency-updates-008-outputLineWidth/verify.bsh +++ /dev/null @@ -1,27 +0,0 @@ -import java.io.*; -import org.codehaus.plexus.util.FileUtils; - -try -{ - - // validate outputFile - File outputFile = new File( basedir, "dependencyUpdate.txt" ); - if (!outputFile.exists()) { - System.out.println( "outputFile not found: " + outputFile.getPath() ); - return false; - } - buf = FileUtils.fileRead( outputFile ); - if ( !buf.contains("localhost:dummy-api ............................................................................... 1.1 ->") ) - { - System.out.println( "displayTerminalWidth parameter not respected" ); - return false; - } - -} -catch( Throwable t ) -{ - t.printStackTrace(); - return false; -} - -return true; diff --git a/versions-maven-plugin/src/it/it-display-dependency-updates-008/invoker.properties b/versions-maven-plugin/src/it/it-display-dependency-updates-008/invoker.properties new file mode 100644 index 0000000000..6d68768aa5 --- /dev/null +++ b/versions-maven-plugin/src/it/it-display-dependency-updates-008/invoker.properties @@ -0,0 +1,2 @@ +invoker.goals=${project.groupId}:${project.artifactId}:${project.version}:display-dependency-updates +invoker.mavenOpts=-Dverbose=true -Dversions.outputFile=./output.txt -DoutputEncoding=UTF-8 -Dversions.outputLineWidth=120 \ No newline at end of file diff --git a/versions-maven-plugin/src/it/it-display-dependency-updates-008/pom.xml b/versions-maven-plugin/src/it/it-display-dependency-updates-008/pom.xml new file mode 100644 index 0000000000..4f0675f020 --- /dev/null +++ b/versions-maven-plugin/src/it/it-display-dependency-updates-008/pom.xml @@ -0,0 +1,19 @@ + + + 4.0.0 + localhost + it-display-dependency-updates-008-displayTerminalWidth + 1.0 + pom + display-dependency-updates + Validate usage of displayTerminalWidth parameter + http://localhost/ + + + localhost + dummy-api + 1.0 + + + diff --git a/versions-maven-plugin/src/it/it-display-dependency-updates-008/verify.groovy b/versions-maven-plugin/src/it/it-display-dependency-updates-008/verify.groovy new file mode 100644 index 0000000000..cd00007eba --- /dev/null +++ b/versions-maven-plugin/src/it/it-display-dependency-updates-008/verify.groovy @@ -0,0 +1,2 @@ +def output = new File(basedir, "output.txt").text +assert output.contains('localhost:dummy-api ............................................................................... 1.0 ->') \ No newline at end of file diff --git a/versions-maven-plugin/src/it/it-display-dependency-updates-009-processDependencyManagementTransitive-false/invoker.properties b/versions-maven-plugin/src/it/it-display-dependency-updates-009-processDependencyManagementTransitive-false/invoker.properties deleted file mode 100644 index e4813a9162..0000000000 --- a/versions-maven-plugin/src/it/it-display-dependency-updates-009-processDependencyManagementTransitive-false/invoker.properties +++ /dev/null @@ -1,2 +0,0 @@ -invoker.goals=${project.groupId}:${project.artifactId}:${project.version}:display-dependency-updates -invoker.mavenOpts=-DprocessDependencyManagementTransitive=false diff --git a/versions-maven-plugin/src/it/it-display-dependency-updates-009-processDependencyManagementTransitive-false/verify.bsh b/versions-maven-plugin/src/it/it-display-dependency-updates-009-processDependencyManagementTransitive-false/verify.bsh deleted file mode 100644 index c44a94c018..0000000000 --- a/versions-maven-plugin/src/it/it-display-dependency-updates-009-processDependencyManagementTransitive-false/verify.bsh +++ /dev/null @@ -1,45 +0,0 @@ -import java.io.*; -import org.codehaus.plexus.util.FileUtils; -import java.util.regex.*; - -try -{ - File file = new File( basedir, "build.log" ); - String buf = FileUtils.fileRead( file ); - - Pattern p; - Matcher m; - - p = Pattern.compile( "\\Qlocalhost:dummy-api\\E\\s*\\.*\\s*1\\.1\\s+->\\s+3\\.0" ); - m = p.matcher( buf.toString() ); - if ( !m.find() ) - { - System.out.println( "Did not suggest updating dummy-api to version 3.0" ); - return false; - } - System.out.println( m.group( 0 ) ); - - p = Pattern.compile( "\\Qlocalhost:dummy-impl\\E\\s*\\.*\\s*1\\.2\\s+->\\s+2\\.2" ); - m = p.matcher( buf.toString() ); - if ( m.find() ) - { - System.out.println( "Did suggest updating dummy-impl to version 2.2" ); - return false; - } - - p = Pattern.compile( "\\Qlocalhost:dummy-api-impl-bom-pom\\E\\s*\\.*\\s*1\\.0\\s+->\\s+2\\.0" ); - m = p.matcher( buf.toString() ); - if ( !m.find() ) - { - System.out.println( "Did not suggest updating dummy-api-impl-bom-pom to version 2.0" ); - return false; - } - System.out.println( m.group( 0 ) ); -} -catch( Throwable t ) -{ - t.printStackTrace(); - return false; -} - -return true; diff --git a/versions-maven-plugin/src/it/it-display-dependency-updates-009-processDependencyManagementTransitive-true/invoker.properties b/versions-maven-plugin/src/it/it-display-dependency-updates-009-processDependencyManagementTransitive-true/invoker.properties deleted file mode 100644 index fa969d852b..0000000000 --- a/versions-maven-plugin/src/it/it-display-dependency-updates-009-processDependencyManagementTransitive-true/invoker.properties +++ /dev/null @@ -1,2 +0,0 @@ -invoker.goals=${project.groupId}:${project.artifactId}:${project.version}:display-dependency-updates -invoker.mavenOpts=-DprocessDependencyManagementTransitive=true diff --git a/versions-maven-plugin/src/it/it-display-dependency-updates-009-processDependencyManagementTransitive-true/pom.xml b/versions-maven-plugin/src/it/it-display-dependency-updates-009-processDependencyManagementTransitive-true/pom.xml deleted file mode 100644 index d22ccbd936..0000000000 --- a/versions-maven-plugin/src/it/it-display-dependency-updates-009-processDependencyManagementTransitive-true/pom.xml +++ /dev/null @@ -1,58 +0,0 @@ - - 4.0.0 - localhost - it-display-dependency-updates-001 - 1.0 - pom - display-dependency-updates - http://localhost/ - - - localhost - dummy-api - - - - - - localhost - dummy-api-impl-bom-pom - 1.0 - pom - import - - - - - - - - localhost - dummy-maven-plugin - 1.0 - - - maven-clean-plugin - 2.2 - - - maven-deploy-plugin - 2.3 - - - maven-install-plugin - 2.2 - - - maven-site-plugin - 2.0 - - - maven-project-info-reports-plugin - 2.1 - - - - - diff --git a/versions-maven-plugin/src/it/it-display-dependency-updates-009-processDependencyManagementTransitive-true/verify.bsh b/versions-maven-plugin/src/it/it-display-dependency-updates-009-processDependencyManagementTransitive-true/verify.bsh deleted file mode 100644 index 7aaf3d73b7..0000000000 --- a/versions-maven-plugin/src/it/it-display-dependency-updates-009-processDependencyManagementTransitive-true/verify.bsh +++ /dev/null @@ -1,45 +0,0 @@ -import java.io.*; -import org.codehaus.plexus.util.FileUtils; -import java.util.regex.*; - -try -{ - File file = new File( basedir, "build.log" ); - String buf = FileUtils.fileRead( file ); - - Pattern p; - Matcher m; - - p = Pattern.compile( "\\Qlocalhost:dummy-api\\E\\s*\\.*\\s*1\\.1\\s+->\\s+3\\.0" ); - m = p.matcher( buf.toString() ); - if ( !m.find() ) - { - System.out.println( "Did not suggest updating dummy-api to version 3.0" ); - return false; - } - System.out.println( m.group( 0 ) ); - - p = Pattern.compile( "\\Qlocalhost:dummy-impl\\E\\s*\\.*\\s*1\\.2\\s+->\\s+2\\.2" ); - m = p.matcher( buf.toString() ); - if ( !m.find() ) - { - System.out.println( "Did not suggest updating dummy-impl to version 2.2" ); - return false; - } - System.out.println( m.group( 0 ) ); - - p = Pattern.compile( "\\Qlocalhost:dummy-api-impl-bom-pom\\E\\s*\\.*\\s*1\\.0\\s+->\\s+2\\.0" ); - m = p.matcher( buf.toString() ); - if ( m.find() ) - { - System.out.println( "Did suggest updating dummy-api-impl-bom-pom to version 2.0" ); - return false; - } -} -catch( Throwable t ) -{ - t.printStackTrace(); - return false; -} - -return true; diff --git a/versions-maven-plugin/src/it/it-display-dependency-updates-009/invoker.properties b/versions-maven-plugin/src/it/it-display-dependency-updates-009/invoker.properties new file mode 100644 index 0000000000..626c84fe07 --- /dev/null +++ b/versions-maven-plugin/src/it/it-display-dependency-updates-009/invoker.properties @@ -0,0 +1,8 @@ +invoker.goals.1=${project.groupId}:${project.artifactId}:${project.version}:display-dependency-updates +invoker.mavenOpts.1=-DprocessDependencyManagementTransitive=false -Dversions.outputFile=./output.1.txt -DoutputEncoding=UTF-8 + +invoker.goals.2=${project.groupId}:${project.artifactId}:${project.version}:display-dependency-updates +invoker.mavenOpts.2=-DprocessDependencyManagementTransitive=true -Dversions.outputFile=./output.2.txt -DoutputEncoding=UTF-8 + +invoker.goals.3=${project.groupId}:${project.artifactId}:${project.version}:display-dependency-updates +invoker.mavenOpts.3=-DprocessDependencyManagementTransitive=true -Dverbose=true -Dversions.outputFile=./output.3.txt -DoutputEncoding=UTF-8 diff --git a/versions-maven-plugin/src/it/it-display-dependency-updates-009-processDependencyManagementTransitive-false/pom.xml b/versions-maven-plugin/src/it/it-display-dependency-updates-009/pom.xml similarity index 100% rename from versions-maven-plugin/src/it/it-display-dependency-updates-009-processDependencyManagementTransitive-false/pom.xml rename to versions-maven-plugin/src/it/it-display-dependency-updates-009/pom.xml diff --git a/versions-maven-plugin/src/it/it-display-dependency-updates-009/verify.groovy b/versions-maven-plugin/src/it/it-display-dependency-updates-009/verify.groovy new file mode 100644 index 0000000000..0e8958e30a --- /dev/null +++ b/versions-maven-plugin/src/it/it-display-dependency-updates-009/verify.groovy @@ -0,0 +1,13 @@ +def output = (1..3).collect{new File( basedir, "output." + it + ".txt").text.replaceAll( "(\n|\r)", " " ) } + +assert output[0] =~ /localhost:dummy-api \.* 1.1 -> 3.0/ +assert !(output[0] =~ /localhost:dummy-impl \.* 1.2 -> 2.2/) +assert output[0] =~ /localhost:dummy-api-impl-bom-pom \.* 1.0 -> 2.0/ + +assert output[1] =~ /localhost:dummy-api \.* 1.1 -> 3.0/ +assert output[1] =~ /localhost:dummy-impl \.* 1.2 -> 2.2/ +assert !(output[1] =~ /localhost:dummy-api-impl-bom-pom \.* 1.0 -> 2.0/) + +assert output[2] =~ /localhost:dummy-api.*\b1.1\b.*\Q(managed by localhost:dummy-api-impl-bom-pom:1.0)\E.*\b3.0\b/ +assert output[2] =~ /localhost:dummy-impl.*\b1.2\b.*\Q(managed by localhost:dummy-api-impl-bom-pom:1.0)\E.*\b2.2\b/ +assert !(output[2] =~ /localhost:dummy-api-impl-bom-pom \.* 1.0 -> 2.0/) \ No newline at end of file diff --git a/versions-maven-plugin/src/main/java/org/codehaus/mojo/versions/DisplayDependencyUpdatesMojo.java b/versions-maven-plugin/src/main/java/org/codehaus/mojo/versions/DisplayDependencyUpdatesMojo.java index f256b28de5..92bf5cc9a2 100644 --- a/versions-maven-plugin/src/main/java/org/codehaus/mojo/versions/DisplayDependencyUpdatesMojo.java +++ b/versions-maven-plugin/src/main/java/org/codehaus/mojo/versions/DisplayDependencyUpdatesMojo.java @@ -54,6 +54,8 @@ import static java.util.Collections.emptySet; import static java.util.Optional.empty; import static org.codehaus.mojo.versions.filtering.DependencyFilter.filterDependencies; +import static org.codehaus.mojo.versions.utils.DependencyBuilder.Location.ARTIFACT_ID; +import static org.codehaus.mojo.versions.utils.DependencyBuilder.Location.VERSION; import static org.codehaus.mojo.versions.utils.MavenProjectUtils.extractDependenciesFromDependencyManagement; import static org.codehaus.mojo.versions.utils.MavenProjectUtils.extractDependenciesFromPlugins; import static org.codehaus.mojo.versions.utils.MavenProjectUtils.extractPluginDependenciesFromPluginsInPluginManagement; @@ -84,7 +86,7 @@ public class DisplayDependencyUpdatesMojo extends AbstractVersionsDisplayMojo { * @since 1.2 */ @Parameter(property = "processDependencyManagement", defaultValue = "true") - private boolean processDependencyManagement; + protected boolean processDependencyManagement = true; /** * Whether to process the dependencyManagement part transitive or not. @@ -97,13 +99,12 @@ public class DisplayDependencyUpdatesMojo extends AbstractVersionsDisplayMojo { * @since 2.11 */ @Parameter(property = "processDependencyManagementTransitive", defaultValue = "true") - private boolean processDependencyManagementTransitive; + protected boolean processDependencyManagementTransitive = true; /** * Only take these artifacts into consideration. *

* Comma-separated list of extended GAV patterns. - * *

* Extended GAV: groupId:artifactId:version:type:classifier:scope *

@@ -111,7 +112,6 @@ public class DisplayDependencyUpdatesMojo extends AbstractVersionsDisplayMojo { * The wildcard "*" can be used as the only, first, last or both characters in each token. * The version token does support version ranges. *

- * *

* Example: {@code "mygroup:artifact:*,*:*:*:*:*:compile"} *

@@ -125,7 +125,6 @@ public class DisplayDependencyUpdatesMojo extends AbstractVersionsDisplayMojo { * Exclude these artifacts from consideration. *

* Comma-separated list of extended GAV patterns. - * *

* Extended GAV: groupId:artifactId:version:type:classifier:scope *

@@ -133,7 +132,6 @@ public class DisplayDependencyUpdatesMojo extends AbstractVersionsDisplayMojo { * The wildcard "*" can be used as the only, first, last or both characters in each token. * The version token does support version ranges. *

- * *

* Example: {@code "mygroup:artifact:*,*:*:*:*:*:provided,*:*:*:*:*:system"} *

@@ -149,7 +147,7 @@ public class DisplayDependencyUpdatesMojo extends AbstractVersionsDisplayMojo { * @since 1.2 */ @Parameter(property = "processDependencies", defaultValue = "true") - private boolean processDependencies; + protected boolean processDependencies; /** *

Only take the specified input dependencies into account.

@@ -157,7 +155,6 @@ public class DisplayDependencyUpdatesMojo extends AbstractVersionsDisplayMojo { * To filter output versions, please use {@link #ruleSet} or {@link #ignoredVersions}.

*

* Comma-separated list of extended GAV patterns. - * *

* Extended GAV: groupId:artifactId:version:type:classifier:scope *

@@ -165,7 +162,6 @@ public class DisplayDependencyUpdatesMojo extends AbstractVersionsDisplayMojo { * The wildcard "*" can be used as the only, first, last or both characters in each token. * The version token does support version ranges. *

- * *

* Example: {@code "mygroup:artifact:*,*:*:*:*:*:compile"} *

@@ -173,7 +169,7 @@ public class DisplayDependencyUpdatesMojo extends AbstractVersionsDisplayMojo { * @since 2.12.0 */ @Parameter(property = "dependencyIncludes", defaultValue = WildcardMatcher.WILDCARD) - private List dependencyIncludes; + protected List dependencyIncludes; /** *

Do not take the specified input dependencies into account.

@@ -181,7 +177,6 @@ public class DisplayDependencyUpdatesMojo extends AbstractVersionsDisplayMojo { * To filter output versions, please use {@link #ruleSet} or {@link #ignoredVersions}.

*

* Comma-separated list of extended GAV patterns. - * *

* Extended GAV: groupId:artifactId:version:type:classifier:scope *

@@ -189,7 +184,6 @@ public class DisplayDependencyUpdatesMojo extends AbstractVersionsDisplayMojo { * The wildcaNote:rd "*" can be used as the only, first, last or both characters in each token. * The version token does support version ranges. *

- * *

* Example: {@code "mygroup:artifact:*,*:*:*:*:*:provided,*:*:*:*:*:system"} *

@@ -197,7 +191,7 @@ public class DisplayDependencyUpdatesMojo extends AbstractVersionsDisplayMojo { * @since 2.12.0 */ @Parameter(property = "dependencyExcludes") - private List dependencyExcludes; + protected List dependencyExcludes; /** * Whether to process the dependencies sections of plugins. @@ -221,46 +215,44 @@ public class DisplayDependencyUpdatesMojo extends AbstractVersionsDisplayMojo { * @since 2.5 */ @Parameter(property = "allowMajorUpdates", defaultValue = "true") - private boolean allowMajorUpdates = true; + protected boolean allowMajorUpdates = true; /** *

Whether to allow the minor version number to be changed.

- * *

Note: {@code false} also implies {@linkplain #allowMajorUpdates} to be {@code false}

* * @since 2.5 */ @Parameter(property = "allowMinorUpdates", defaultValue = "true") - private boolean allowMinorUpdates = true; + protected boolean allowMinorUpdates = true; /** *

Whether to allow the incremental version number to be changed.

- * *

Note: {@code false} also implies {@linkplain #allowMajorUpdates} * and {@linkplain #allowMinorUpdates} to be {@code false}

* * @since 2.5 */ @Parameter(property = "allowIncrementalUpdates", defaultValue = "true") - private boolean allowIncrementalUpdates = true; + protected boolean allowIncrementalUpdates = true; /** - * Whether to show additional information such as dependencies that do not need updating. Defaults to false. + *

If {@code true}, shows dependencies that do not have updates. Also, with dependencies with + * versions managed outside the reactor, will show the location of the pom.xml managing the version.

+ *

Default is {@code false}.

* * @since 2.1 */ @Parameter(property = "verbose", defaultValue = "false") - private boolean verbose; + protected boolean verbose; /** *

Only take these artifacts into consideration:
* Comma-separated list of {@code groupId:[artifactId[:version]]} patterns

- * *

* The wildcard "*" can be used as the only, first, last or both characters in each token. * The version token does support version ranges. *

- * *

* Example: {@code "mygroup:artifact:*,othergroup:*,anothergroup"} *

@@ -273,12 +265,10 @@ public class DisplayDependencyUpdatesMojo extends AbstractVersionsDisplayMojo { /** *

Exclude these artifacts into consideration:
* Comma-separated list of {@code groupId:[artifactId[:version]]} patterns

- * *

* The wildcard "*" can be used as the only, first, last or both characters in each token. * The version token does support version ranges. *

- * *

* Example: {@code "mygroup:artifact:*,othergroup:*,anothergroup"} *

@@ -295,7 +285,6 @@ public class DisplayDependencyUpdatesMojo extends AbstractVersionsDisplayMojo { * The wildcard "*" can be used as the only, first, last or both characters in each token. * The version token does support version ranges. *

- * *

* Example: {@code "mygroup:artifact:*,othergroup:*,anothergroup"} *

@@ -308,12 +297,10 @@ public class DisplayDependencyUpdatesMojo extends AbstractVersionsDisplayMojo { /** *

Exclude these artifacts into consideration:
* Comma-separated list of {@code groupId:[artifactId[:version]]} patterns

- * *

* The wildcard "*" can be used as the only, first, last or both characters in each token. * The version token does support version ranges. *

- * *

* Example: {@code "mygroup:artifact:*,othergroup:*,anothergroup"} *

@@ -323,6 +310,16 @@ public class DisplayDependencyUpdatesMojo extends AbstractVersionsDisplayMojo { @Parameter(property = "pluginManagementDependencyExcludes") private List pluginManagementDependencyExcludes; + /** + *

Include dependencies with version set in parent or in a BOM.

+ *

Default is {@code false}.

+ *

Note: this is a behavior change compared to 2.18.0 and earlier versions.

+ * + * @since 2.18.1 + */ + @Parameter(property = "showVersionless", defaultValue = "true") + protected boolean showVersionless = true; + // --------------------- GETTER / SETTER METHODS --------------------- @Inject @@ -383,6 +380,26 @@ public boolean isVerbose() { // --------------------- Interface Mojo --------------------- + /** + * @return {@code true} if the version of the dependency is definned locally in the same project + */ + private static boolean dependencyVersionLocalToReactor(Dependency dependency) { + return dependency.getLocation(VERSION.toString()).getSource() + == dependency.getLocation(ARTIFACT_ID.toString()).getSource(); + } + + /** + * @return {@code true} if the version of the dependency is in the project + */ + private boolean dependencyVersionLocalToProject(Dependency dependency) { + return dependency + .getLocation(VERSION.toString()) + .getSource() + .getModelId() + .equals(getProject().getGroupId() + ":" + getProject().getArtifactId() + ":" + + getProject().getVersion()); + } + /** * @throws org.apache.maven.plugin.MojoExecutionException when things go wrong * @throws org.apache.maven.plugin.MojoFailureException when things go wrong in a very bad way @@ -424,6 +441,8 @@ public void execute() throws MojoExecutionException, MojoFailureException { .filter(dep -> finalDependencyManagement.stream() .noneMatch(depMan -> dependenciesMatch(dep, depMan))) + .filter(dep -> showVersionless + || dependencyVersionLocalToReactor(dep)) .collect( () -> new TreeSet<>( DependencyComparator.INSTANCE), @@ -491,6 +510,7 @@ protected void validateInput() throws MojoExecutionException { /** * Validates a list of GAV strings + * * @param gavList list of the input GAV strings * @param numSections number of sections in the GAV to verify against * @param argumentName argument name to indicate in the exception @@ -506,14 +526,24 @@ static void validateGAVList(List gavList, int numSections, String argume private void logUpdates(Map updates, String section) { List withUpdates = new ArrayList<>(); List usingCurrent = new ArrayList<>(); - for (ArtifactVersions versions : updates.values()) { + for (Map.Entry entry : updates.entrySet()) { + Dependency dep = entry.getKey(); + ArtifactVersions versions = entry.getValue(); + String left = " " + ArtifactUtils.versionlessKey(versions.getArtifact()) + " "; String currentVersion; Optional latestVersion; Optional unchangedSegment = SegmentUtils.determineUnchangedSegment( allowMajorUpdates, allowMinorUpdates, allowIncrementalUpdates, getLog()); if (versions.getCurrentVersion() != null) { - currentVersion = versions.getCurrentVersion().toString(); + currentVersion = versions.getCurrentVersion() + + (!verbose || dependencyVersionLocalToProject(entry.getKey()) + ? "" + : " (managed by " + + dep.getLocation(VERSION.toString()) + .getSource() + .getModelId() + ")"); + try { latestVersion = versions.getNewestVersion(currentVersion, unchangedSegment, allowSnapshots, false); } catch (InvalidSegmentException e) { @@ -538,6 +568,7 @@ private void logUpdates(Map updates, String sectio latestVersion = Optional.of(newVersionRestriction) .map(restriction -> versions.getNewestVersion(restriction, allowSnapshots)); } + String right = " " + latestVersion.map(v -> currentVersion + " -> " + v).orElse(currentVersion); List t = latestVersion.isPresent() ? withUpdates : usingCurrent; diff --git a/versions-maven-plugin/src/test/java/org/codehaus/mojo/versions/DisplayDependencyUpdatesMojoTest.java b/versions-maven-plugin/src/test/java/org/codehaus/mojo/versions/DisplayDependencyUpdatesMojoTest.java index 04b9f3aebe..8c275ff088 100644 --- a/versions-maven-plugin/src/test/java/org/codehaus/mojo/versions/DisplayDependencyUpdatesMojoTest.java +++ b/versions-maven-plugin/src/test/java/org/codehaus/mojo/versions/DisplayDependencyUpdatesMojoTest.java @@ -16,11 +16,14 @@ */ import java.io.File; +import java.nio.charset.Charset; import java.nio.file.Files; import java.util.Arrays; import java.util.HashMap; import java.util.List; +import org.apache.maven.model.InputLocation; +import org.apache.maven.model.InputSource; import org.apache.maven.model.Model; import org.apache.maven.plugin.MojoExecutionException; import org.apache.maven.plugin.testing.AbstractMojoTestCase; @@ -47,6 +50,7 @@ import static org.hamcrest.Matchers.containsInAnyOrder; import static org.hamcrest.Matchers.containsString; import static org.hamcrest.Matchers.hasItem; +import static org.hamcrest.Matchers.is; import static org.hamcrest.Matchers.not; import static org.hamcrest.Matchers.notNullValue; @@ -120,10 +124,13 @@ private MavenProject createProject() { setArtifactId("default-artifact"); setVersion("1.0.0-SNAPSHOT"); + InputLocation fakeLocation = new InputLocation(-1, -1, new InputSource()); setDependencies(singletonList(DependencyBuilder.newBuilder() .withGroupId("default-group") .withArtifactId("default-dependency") .withVersion("1.0.0") + .withLocation(DependencyBuilder.Location.ARTIFACT_ID.toString(), fakeLocation) + .withLocation(DependencyBuilder.Location.VERSION.toString(), fakeLocation) .build())); } }) { @@ -149,12 +156,13 @@ public void testVersionsWithQualifiersNotConsideredAsMinorUpdates() throws Excep null) { { setProject(createProject()); - setVariableValueToObject(this, "allowMajorUpdates", false); - setVariableValueToObject(this, "processDependencies", true); - setVariableValueToObject(this, "dependencyIncludes", singletonList(WildcardMatcher.WILDCARD)); - setVariableValueToObject(this, "dependencyExcludes", emptyList()); - this.allowSnapshots = true; - this.outputFile = tempFile.getPath().toFile(); + allowMajorUpdates = false; + processDependencies = true; + processDependencyManagement = false; + dependencyIncludes = singletonList(WildcardMatcher.WILDCARD); + dependencyExcludes = emptyList(); + allowSnapshots = true; + outputFile = tempFile.getPath().toFile(); setPluginContext(new HashMap<>()); session = mockMavenSession(); @@ -184,11 +192,12 @@ public void testAllowMajorUpdatesFalse() throws Exception { null) { { setProject(createProject()); - setVariableValueToObject(this, "allowMajorUpdates", false); - setVariableValueToObject(this, "processDependencies", true); - setVariableValueToObject(this, "dependencyIncludes", singletonList(WildcardMatcher.WILDCARD)); - setVariableValueToObject(this, "dependencyExcludes", emptyList()); - this.outputFile = tempFile.getPath().toFile(); + allowMajorUpdates = false; + processDependencies = true; + processDependencyManagement = false; + dependencyIncludes = singletonList(WildcardMatcher.WILDCARD); + dependencyExcludes = emptyList(); + outputFile = tempFile.getPath().toFile(); setPluginContext(new HashMap<>()); session = mockMavenSession(); @@ -216,11 +225,12 @@ public void testAllowMinorUpdatesFalse() throws Exception { null) { { setProject(createProject()); - setVariableValueToObject(this, "allowMinorUpdates", false); - setVariableValueToObject(this, "processDependencies", true); - setVariableValueToObject(this, "dependencyIncludes", singletonList(WildcardMatcher.WILDCARD)); - setVariableValueToObject(this, "dependencyExcludes", emptyList()); - this.outputFile = tempFile.getPath().toFile(); + allowMinorUpdates = false; + processDependencies = true; + processDependencyManagement = false; + dependencyIncludes = singletonList(WildcardMatcher.WILDCARD); + dependencyExcludes = emptyList(); + outputFile = tempFile.getPath().toFile(); setPluginContext(new HashMap<>()); session = mockMavenSession(); @@ -249,11 +259,12 @@ public void testAllowIncrementalUpdatesFalse() throws Exception { null) { { setProject(createProject()); - setVariableValueToObject(this, "allowIncrementalUpdates", false); - setVariableValueToObject(this, "processDependencies", true); - setVariableValueToObject(this, "dependencyIncludes", singletonList(WildcardMatcher.WILDCARD)); - setVariableValueToObject(this, "dependencyExcludes", emptyList()); - this.outputFile = tempFile.getPath().toFile(); + allowIncrementalUpdates = false; + processDependencies = true; + processDependencyManagement = false; + dependencyIncludes = singletonList(WildcardMatcher.WILDCARD); + dependencyExcludes = emptyList(); + outputFile = tempFile.getPath().toFile(); setPluginContext(new HashMap<>()); session = mockMavenSession(); @@ -285,12 +296,13 @@ public void testVersionsWithQualifiersNotConsideredAsIncrementalUpdates() throws null) { { setProject(createProject()); - setVariableValueToObject(this, "allowMinorUpdates", false); - setVariableValueToObject(this, "processDependencies", true); - setVariableValueToObject(this, "dependencyIncludes", singletonList(WildcardMatcher.WILDCARD)); - setVariableValueToObject(this, "dependencyExcludes", emptyList()); - this.allowSnapshots = true; - this.outputFile = tempFile.getPath().toFile(); + allowMinorUpdates = false; + processDependencies = true; + processDependencyManagement = false; + dependencyIncludes = singletonList(WildcardMatcher.WILDCARD); + dependencyExcludes = emptyList(); + allowSnapshots = true; + outputFile = tempFile.getPath().toFile(); setPluginContext(new HashMap<>()); session = mockMavenSession(); @@ -360,7 +372,7 @@ public void testVersionInterpolation() throws Exception { put("dummy-api", new String[] {"2.0.1"}); } }); - setVariableValueToObject(mojo, "processDependencyManagementTransitive", false); + mojo.processDependencyManagementTransitive = false; mojo.execute(); List output = Files.readAllLines(tempFile.getPath(), UTF_8); assertThat(output, not(hasItem(containsString("mycomponent.version")))); @@ -381,11 +393,12 @@ public void testAllowSnapshots() throws Exception { null) { { setProject(createProject()); - setVariableValueToObject(this, "processDependencies", true); - setVariableValueToObject(this, "dependencyIncludes", singletonList(WildcardMatcher.WILDCARD)); - setVariableValueToObject(this, "dependencyExcludes", emptyList()); - this.allowSnapshots = true; - this.outputFile = tempFile.getPath().toFile(); + processDependencies = true; + processDependencyManagement = false; + dependencyIncludes = singletonList(WildcardMatcher.WILDCARD); + dependencyExcludes = emptyList(); + allowSnapshots = true; + outputFile = tempFile.getPath().toFile(); setPluginContext(new HashMap<>()); session = mockMavenSession(); @@ -411,11 +424,12 @@ private void testAllowUpdatesFromLesserSegments(String availableVersion) throws null) { { setProject(createProject()); - setVariableValueToObject(this, "processDependencies", true); - setVariableValueToObject(this, "dependencyIncludes", singletonList(WildcardMatcher.WILDCARD)); - setVariableValueToObject(this, "dependencyExcludes", emptyList()); - setVariableValueToObject(this, "allowMajorUpdates", false); - this.outputFile = tempFile.getPath().toFile(); + processDependencies = true; + processDependencyManagement = false; + dependencyIncludes = singletonList(WildcardMatcher.WILDCARD); + dependencyExcludes = emptyList(); + allowMajorUpdates = false; + outputFile = tempFile.getPath().toFile(); setPluginContext(new HashMap<>()); session = mockMavenSession(); @@ -442,4 +456,86 @@ public void testAllowUpdatesFromLesserSegmentsIncremental() throws Exception { public void testAllowUpdatesFromLesserSegmentsSubIncremental() throws Exception { testAllowUpdatesFromLesserSegments("1.0.0-1"); } + + /* + * A dependency version is managed by a parent from outside the reactor; with showVersionsless false the output + * should not be generated at all. + */ + @Test + public void testShowVersionlessFalse() throws Exception { + try (CloseableTempFile tempFile = new CloseableTempFile("display-dependency-updates")) { + DisplayDependencyUpdatesMojo mojo = (DisplayDependencyUpdatesMojo) mojoRule.lookupConfiguredMojo( + new File("target/test-classes/org/codehaus/mojo/display-dependency-updates/" + + "version-from-parent/child"), + "display-dependency-updates"); + mojo.setPluginContext(new HashMap<>()); + mojo.showVersionless = false; + mojo.processDependencyManagement = false; + mojo.outputFile = tempFile.getPath().toFile(); + mojo.outputEncoding = Charset.defaultCharset().toString(); + mojo.repositorySystem = mockAetherRepositorySystem(new HashMap() { + { + put("dummy-api", new String[] {"1.0.0", "2.0.0"}); + } + }); + mojo.execute(); + assertThat(Files.exists(tempFile.getPath()), is(false)); + } + } + + /* + * A dependency version is managed by a parent from outside the reactor; with showVersionsless true + * and verbose, the output should contain the location of the versionless dependency. + */ + @Test + public void testShowVersionlessVerbose() throws Exception { + try (CloseableTempFile tempFile = new CloseableTempFile("display-dependency-updates")) { + DisplayDependencyUpdatesMojo mojo = (DisplayDependencyUpdatesMojo) mojoRule.lookupConfiguredMojo( + new File("target/test-classes/org/codehaus/mojo/display-dependency-updates/" + + "version-from-parent/child"), + "display-dependency-updates"); + mojo.setPluginContext(new HashMap<>()); + mojo.showVersionless = true; + mojo.verbose = true; + mojo.processDependencyManagement = false; + mojo.outputFile = tempFile.getPath().toFile(); + mojo.outputEncoding = Charset.defaultCharset().toString(); + mojo.repositorySystem = mockAetherRepositorySystem(new HashMap() { + { + put("dummy-api", new String[] {"1.0.0", "2.0.0"}); + } + }); + mojo.execute(); + + String output = String.join("", Files.readAllLines(tempFile.getPath())); + assertThat( + output, containsString("1.0.0 (managed by default-group:parent-artifact:1.0.0-SNAPSHOT) -> 2.0.0")); + } + } + + /* + * A dependency version is managed by a parent from outside the reactor; with showVersionsless false the output + * should be generated and should contain the transitive dependency + */ + @Test + public void testShowVersionlessFalseDependencyManagementTransitive() throws Exception { + try (CloseableTempFile tempFile = new CloseableTempFile("display-dependency-updates")) { + DisplayDependencyUpdatesMojo mojo = (DisplayDependencyUpdatesMojo) mojoRule.lookupConfiguredMojo( + new File("target/test-classes/org/codehaus/mojo/display-dependency-updates/" + + "dependency-management-from-parent/child"), + "display-dependency-updates"); + mojo.setPluginContext(new HashMap<>()); + mojo.showVersionless = false; + mojo.outputFile = tempFile.getPath().toFile(); + mojo.outputEncoding = Charset.defaultCharset().toString(); + mojo.repositorySystem = mockAetherRepositorySystem(new HashMap() { + { + put("dummy-api", new String[] {"1.0.0", "2.0.0"}); + } + }); + mojo.execute(); + String output = String.join("", Files.readAllLines(tempFile.getPath())); + assertThat(output, containsString("1.0.0 -> 2.0.0")); + } + } } diff --git a/versions-maven-plugin/src/test/resources/org/codehaus/mojo/display-dependency-updates/dependency-management-from-parent/child/pom.xml b/versions-maven-plugin/src/test/resources/org/codehaus/mojo/display-dependency-updates/dependency-management-from-parent/child/pom.xml new file mode 100644 index 0000000000..544da936f8 --- /dev/null +++ b/versions-maven-plugin/src/test/resources/org/codehaus/mojo/display-dependency-updates/dependency-management-from-parent/child/pom.xml @@ -0,0 +1,33 @@ + + + + 4.0.0 + + + default-group + parent-artifact + 1.0.0-SNAPSHOT + + + child-artifact + 1.0.0-SNAPSHOT + + diff --git a/versions-maven-plugin/src/test/resources/org/codehaus/mojo/display-dependency-updates/dependency-management-from-parent/pom.xml b/versions-maven-plugin/src/test/resources/org/codehaus/mojo/display-dependency-updates/dependency-management-from-parent/pom.xml new file mode 100644 index 0000000000..b0ee19c5dd --- /dev/null +++ b/versions-maven-plugin/src/test/resources/org/codehaus/mojo/display-dependency-updates/dependency-management-from-parent/pom.xml @@ -0,0 +1,37 @@ + + + + 4.0.0 + default-group + parent-artifact + 1.0.0-SNAPSHOT + pom + + + + + localhost + dummy-api + 1.0.0 + + + + diff --git a/versions-maven-plugin/src/test/resources/org/codehaus/mojo/display-dependency-updates/version-from-parent/child/pom.xml b/versions-maven-plugin/src/test/resources/org/codehaus/mojo/display-dependency-updates/version-from-parent/child/pom.xml new file mode 100644 index 0000000000..68656428cc --- /dev/null +++ b/versions-maven-plugin/src/test/resources/org/codehaus/mojo/display-dependency-updates/version-from-parent/child/pom.xml @@ -0,0 +1,40 @@ + + + + 4.0.0 + + + default-group + parent-artifact + 1.0.0-SNAPSHOT + + + child-artifact + 1.0.0-SNAPSHOT + + + + localhost + dummy-api + + + + diff --git a/versions-maven-plugin/src/test/resources/org/codehaus/mojo/display-dependency-updates/version-from-parent/pom.xml b/versions-maven-plugin/src/test/resources/org/codehaus/mojo/display-dependency-updates/version-from-parent/pom.xml new file mode 100644 index 0000000000..b0ee19c5dd --- /dev/null +++ b/versions-maven-plugin/src/test/resources/org/codehaus/mojo/display-dependency-updates/version-from-parent/pom.xml @@ -0,0 +1,37 @@ + + + + 4.0.0 + default-group + parent-artifact + 1.0.0-SNAPSHOT + pom + + + + + localhost + dummy-api + 1.0.0 + + + + diff --git a/versions-model-report/pom.xml b/versions-model-report/pom.xml index 722613a1e7..6c5f9bf07a 100644 --- a/versions-model-report/pom.xml +++ b/versions-model-report/pom.xml @@ -4,7 +4,7 @@ org.codehaus.mojo.versions versions - 2.18.0 + 2.18.1-SNAPSHOT versions-model-report diff --git a/versions-model/pom.xml b/versions-model/pom.xml index d3bd7c2490..5ac58a5f42 100644 --- a/versions-model/pom.xml +++ b/versions-model/pom.xml @@ -4,7 +4,7 @@ org.codehaus.mojo.versions versions - 2.18.0 + 2.18.1-SNAPSHOT versions-model diff --git a/versions-test/pom.xml b/versions-test/pom.xml index c37bc668d0..416d493800 100644 --- a/versions-test/pom.xml +++ b/versions-test/pom.xml @@ -22,7 +22,7 @@ org.codehaus.mojo.versions versions - 2.18.0 + 2.18.1-SNAPSHOT versions-test