I’ve got a project with Maven in which one subproject (A) wants to depend on another subproject (B) which uses “pom” packaging.
If I do this the straightforward way, where A specifies a dependency on B with <type>pom</type>, things work perfectly if I do “mvn install”, but if I run any phase earlier than install, such as mvn compile or mvn package, then it fails while trying to build A: it goes looking for B’s pom in the repository, and doesn’t find it.
I don’t really want this pom in the repository, because it’s part of our active source code and changes frequently.
For all the jar-packaged projects we build, it seems to work fine to keep them out of the repository, build with mvn package, and Maven knows how to find all the dependencies in the source and build trees it manages without resorting to the repository; however for the pom-packaged project it always wants to go to the repository.
A couple things I learned while trying to understand this:
- Maven best practices encourage you to use pom-packaged projects to group dependencies, but with the added step of “mvn install” on the POM project
- Maven lifecycle documentation says “a project that is purely metadata (packaging value is pom) only binds goals to the install and deploy phases”; maybe this is why the POM project is invisible as a dependency target unless I invoke the install phase? I tried binding the compiler plugin to the compile phase and this didn’t seem to help.
Is there a way that I can specify the POM subproject as a dependency of another subproject in the same parent project, without installing the POM project to the repository?
It isn’t purely a question of which goals are bound to which lifecycle phases for POM projects. If it were, then binding the “package” goal would solve the problem.
When building a multi-module project, Maven reads the POMs of all modules to determine dependencies between modules, so that it can build the depended-upon modules before the depending modules. It’s able to achieve this even when running the “package” goal (such that the depended-upon modules are not yet in the local repository).
Therefore, the code that constructs the classpath for builds must be managing several cases, notably:
Notice the asymmetry in the last two cases, as compared to the first two.
I can see two solutions to your problem. One is to file a bug report, or rather a request to change the behaviour (since it’s obviously intentional), perhaps only for the case of intra-project dependencies on multi-module projects. Or indeed propose a patch. But since the behaviour is intentional, you might meet a refusal. In the best of cases, you’re in for a long wait. (I’d vote for your bug report though – I’ve been stung by that same behaviour, in a different context.)
The other solution is simply to run an install on your project. I don’t really understand why you don’t want the POM project in your repository: if needs be, you can use a snapshot repository, where it doesn’t matter if things change frequently, to avoid polluting your main repository.