Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

multi module maven project with parent pom and svn layout

I currently have about 16 projects that I build with maven that get deployed to the same application server that make up something like a "portal". I have built a parent pom to handle common dependencies and plugin configurations. Currently, my SVN structure looks similar to this:

portal_root
    +project1
        +tags
        +branches
        +trunk
    +project2
        .
        .
        .
    +projectn
    pom.xml

The individual projects are each separately deployed. That is, project1 doesn't have a dependency on project2 and each can be modified and deployed without having to modify anything else.

This presents a problem with SVN as if another developer wanted to check out the entire "portal" root (to also get the parent pom) they would also by default pull down copies of all the tags and branches! Not really ideal.

The only other thing I can think of is to use something like this:

 portal_root
     +tags
     +branches
     +trunk
         +project1
              +src
              pom.xml
         +project2
             .
             .
             .
         pom.xml

However, now all project changes will be tracked in the tags folder. This isn't a huge problem for me, but branching now seems to become a pain.

I am also currently working on hooking up Teamcity into this as well which would be a bit easier now, since I would only have to watch a single directory (e.g. tags) to catch everything that needs to be built. I am also deploying artifacts to a enterprise Nessus repository.

I'm hoping someone could give me some suggestions here as I have been unable to find any decent documentation that talks about the entire build lifecycle and best practices here.

I like the idea of being able to build and deploy all the projects with a single maven command. I also like having all the common dependencies, repository information and plugin information in one place.

like image 603
Casey Avatar asked Dec 14 '10 16:12

Casey


2 Answers

You can use following layout:

+parent-project
  pom.xml
+child-project-1
  pom.xml
+child-project-2
  pom.xml

In parent project pom add:

<modules>
    <module>../child-project-1</module>
    <module>../child-project-2</module>
</modules>

In children projects pom add:

<parent>
    <artifactId><!-- parent artifactId --></artifactId>
    <groupId><!-- parent groupdId --></groupId>
    <version><!-- parent version --></version>
    <relativePath>../parent-project</relativePath>
</parent>

Children Projects can optionally be dependent.

Following links may also help:

  • http://maven.apache.org/guides/introduction/introduction-to-the-pom.html
  • Maven parent pom vs modules pom
like image 99
Ali Shakiba Avatar answered Sep 19 '22 12:09

Ali Shakiba


A variation to JohnS's approach would be to use svn:externals to hook appropriate trunk/tags/branches of your subprojects to the appropriate trunk/tag/branch of your parent project. In this way checking out one variant of your parent would pull out all the right version of the other projects.

This makes sense only if it's reasonable to checkout all your projects together.

like image 38
Nicola Musatti Avatar answered Sep 20 '22 12:09

Nicola Musatti