how to release a project which depends on a 3rd party SNAPSHOT project in maven

Maven 2VersioningReleaseSnapshotMaven Release-Plugin

Maven 2 Problem Overview


i would like to release a snapshot project 'foo-1.0-SNAPSHOT' using the maven release plugin. The project depends on a 3rd party module 'bar-1.0-SNAPSHOT' which is not released yet. I use the option 'allowTimestampedSnapshots' in my project's pom.xml to allow timestamped snapshots but i assume that the 3rd party module (bar) is not timestamped unless i build it myself as maven still complains about unresolved SNAPSHOT dependencies.

Is there a way to release the project foo regardless of dependent SNAPSHOT projects and if not how could i add a timestamp to the 3rd party project?

Maven 2 Solutions


Solution 1 - Maven 2

Problem is with the allowTimestampedSnapshots parameter name, it's in the documentation but the plugin's source uses a different parameter name in expression - ignoreSnapshots.

So just use -DignoreSnapshots=true and the prepare goal of the release plugin will ignore snapshot dependencies.

Solution 2 - Maven 2

Using the maven-release-plugin option

-DignoreSnapshots=true

instead of

-DallowTimestampedSnapshots=true

helped in my case, this will allow to use dependencies with snapshot version to prepare and perform a release.

This option should be handled very carefully, because using snapshot versions in a release can later break your release, if the snapshot dependency is updated, which in normal case is not what you want.

Solution 3 - Maven 2

The short answer is see the following answer.... the long answer is you can work around it.

The only way I have coped in the past is to effectively fork the 3rd party library and cut a release myself. This of course is easier said than done and is just plain difficult if the library is large and complex and impossible if the 3rd party library is closed source. An easier route maybe to approach the 3rd party and ask them to cut a release.

Another option may be to copy their pom (ensure that it has no snapshots) change the version information and manually install the pom and artifact in your repository.

Solution 4 - Maven 2

The previous answer suggested changing the group and artifact id...don't do this as maven won't recognize it as the same artifact later when this dependency is released and you'll end up with two copies on the classpath. My preferred method is to change only the version and I'll do something like : [original version]-[my org name]-[svn version i pulled it from] so i get something like 1.0-SONATYPE-3425. By using the svn rev, i can always pull the source again and patch it if needed and know exactly what i'm using without pulling the whole source into my own svn.

Update - I blogged about this a while back.

Solution 5 - Maven 2

Just install the jar with a pom you own. I generally change the group and artifact id to make it clear that this is not the official version, but that's generally the best work around for your problem.

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionChristianView Question on Stackoverflow
Solution 1 - Maven 2Stevo SlavićView Answer on Stackoverflow
Solution 2 - Maven 2Oleg MayevskiyView Answer on Stackoverflow
Solution 3 - Maven 2Gareth DavisView Answer on Stackoverflow
Solution 4 - Maven 2Brian FoxView Answer on Stackoverflow
Solution 5 - Maven 2Mike DeckView Answer on Stackoverflow