Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

support for module dependencies #7

Open
hohwille opened this issue May 15, 2019 · 2 comments
Open

support for module dependencies #7

hohwille opened this issue May 15, 2019 · 2 comments

Comments

@hohwille
Copy link
Member

In case a context is build from a local maven project, then currently dependencies are always resolved via the local repository. If these dependencies belong to a sibling module of the same local reactor project we should resolve the code from that local module instead as the artifacts in the local repo may be missing or outdated.
The challenge is to find a way to solve this without causing a performance trap during the bootstrapping. We already spent a lot of energy to load things lazily to make first access fast. To resolve this we would need to read all modules from all parents and resolve their POMs (as effective model) what would require quite some parsing time. Also we need to be careful to check that GAV coordinates match exactly and otherwise we still need to fallback to the artifact from local repo. To boost performance we could maybe rely on some conventions or assumptions such that e.g. the groupId of module siblings may be the same, however this must not be the case and may therefore not work as expected in edge-cases.

@jdiazgon
Copy link
Contributor

jdiazgon commented May 16, 2019

To resolve this we would need to read all modules from all parents and resolve their POMs

I have started to implement a way to resolve the dependencies from sibling modules. We know that the core module in devon4j defines the api module as dependency on its POM.

Therefore, what I currently implemented is a recursive method to get the dependencies from the dependencies of our dependencies... up to 4 levels of recursiveness.

This is a heuristic solution, but I have tested it and seems to work well on devon4j project. You can find here my commit.

@hohwille
Copy link
Member Author

hohwille commented Jul 3, 2021

We can not make such assumptions as this should work for any maven project structure.
Instead we can use the maven information ("reactor") and thereby find the correct code locations (including the configurations from the pom.xml of that module that can change defaults like ./target/classes). Also we need to be aware that we only do this if the GAV coordinates match exactly. That means if the version of the local module mismatches the one from the dependency then we have to stay resolving via local repo just as maven would do.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants