Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • Home
  • SEARCH
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 6659659
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 26, 20262026-05-26T02:03:32+00:00 2026-05-26T02:03:32+00:00

Consider a Maven project with multiple interdependent modules: let’s say, three jar modules A,

  • 0

Consider a Maven project with multiple interdependent modules: let’s say, three jar modules A, B, and C, which are dependencies for a war module Z. I have a separate Hudson build for each of these modules, so that only modules that have changed are re-built.

My issue is that if I commit a changeset that changes both module A and module Z, Z may be built before A and fail, before A completes and triggers a rebuild of Z which now passes. Allowing builds to regularly fail for reasons to do with build ordering rather than “real” failures desensitizes us to real failures; we end up ignoring builds which have legitimately broken because we are used to assuming it will eventually flip back.

I have been managing this through the use of quiet periods, blocking when upstream builds are running, etc. But in practice, my build has more modules than the example I’ve given, many of which take a while to build and test. I also have a small horde of diligent developers making frequent commits.

This means my jar modules are constantly building, only rarely leaving a gap for my war module(s) to build. So the war doesn’t build very frequently, meaning it takes a long time to find out when we’ve broken it, and also takes longer to identify which change broke it.

Also, the constant running of builds means that if I commit a change that touches jars A and B, the war file Z may be built once for jar A (which builds quickly), and then again for jar B (which takes longer). This makes it hard to understand the results of a given commit.

I’ve considered using the join plugin, but this appears to require all of the modules to build every time. Since I actually have quite a few jar modules, I really don’t want to have to build them all every time, I only want to build the ones that have changed for a given commit.

Are there any better ways to handle this?

Thanks

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-26T02:03:33+00:00Added an answer on May 26, 2026 at 2:03 am

    The approach we’re now looking at is combining some Maven modules into single Hudson jobs, rather than having a one to one mapping of modules to jobs.

    Specifically, if a war module’s dependencies are fairly small and quick to build on their own, building them in the same job with the war ensures that all of the code from a single commit is built together, at least for that given war file.

    This does result in duplication – we have multiple war files using the same jars, so the jars are essentially rebuilt for every war, rather than once only. But in practice, the jars are quick to build, and this makes the war files conceptually cleaner.

    This would be less attractive if the jars took a while to build and test, since the combined jars + war job would then be quite long, giving us long feedback loops for problems within the jars. Getting the balance right is important.

    So my takeaway: don’t assume that one Hudson/Jenkins job per module is the best way to go, and don’t be afraid to rebuild the same code in multiple jobs.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

Consider this problem: I have a program which should fetch (let's say) 100 records
I have a maven project with a module /myProject pom.xml /myModule pom.xml /foo bar.txt
Consider an ivy.xml like the following: <ivy-module version=2.0> <info organisation=com.foo module=FooBar /> <dependencies> <dependency
Maven 2 does not seem to consider my @Test and @Ignore annotations. How do
I'm very new to Maven, and have a question about building multiple Maven projects.
consider this class,with no instance variables and only methods which are non-synchronous can we
I'm starting a new project. I intend to use Maven for the first time.
Consider the following function, which does not work in Python, but I will use
Consider this unhygienic Scheme macro: (define-macro for (lambda (i i1 i2 . body) (let
How do you layout your Maven modules when doing DDD projects? Do you fit

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.