Scott Kurz created MNG-8479:
-------------------------------

             Summary: Multi-module, intra-reactor artifact resolution doesn't 
work for 'ejb' packaged types like with 'jar' packaged types and requires 
compile
                 Key: MNG-8479
                 URL: https://issues.apache.org/jira/browse/MNG-8479
             Project: Maven
          Issue Type: Bug
          Components: Core, Reactor and Workspace
    Affects Versions: 4.0.0-rc-2, 3.9.6
            Reporter: Scott Kurz


h2. *Recreate steps*

With either a recent version of 3.9.x or 4.0.0-x, build my recreate plugin and 
use the j2ee-simple archetype to create a test project then run the test goal 
like this:
 # {{{}{}}}git clone g...@github.com:scottkurz/counter-maven-plugin.git; cd 
counter-maven-plugin; mvn install
 # mvn -B archetype:generate -DarchetypeGroupId=org.apache.maven.archetypes 
-DarchetypeArtifactId=maven-archetype-j2ee-simple -DarchetypeVersion=1.5 
-DgroupId=mygroup -DartifactId=myartifact -Dversion=1.0-SNAPSHOT -Dpackage=myco
 # cd myartifact; {{{}mvn 
mygroup:counter-maven-plugin:1.0-SNAPSHOT:countTargets{}}}{{{}{}}}

You'll see an artifact resolution failure like this: 

 

{{{}{}}}{{{}[ERROR] Failed to execute goal on project ear: Could not resolve 
dependencies for project mygroup:ear:ear:1.0-SNAPSHOT{}}}

{{[ERROR] dependency: mygroup:ejbs:jar:1.0-SNAPSHOT (compile)}}
{{[ERROR] : The following artifacts could not be resolved: 
mygroup:ejbs:jar:1.0-SNAPSHOT (absent){{{}{}}}}}

{{{}{}}}{{{}{}}}
h2. *More Details*

 

I was able to fix the issue by making this simple change to *ReactorReader.java*

[https://github.com/apache/maven/pull/2016]

 

Note my recreate/test plugin mojo looks like

 
{code:java}
@Mojo( name = "countTargets", defaultPhase = LifecyclePhase.PROCESS_SOURCES, 
requiresDependencyResolution = ResolutionScope.TEST )
@Execute(phase = LifecyclePhase.PROCESS_TEST_CLASSES)
public class MyMojo{code}
 

 

If I understand correctly, the role of the `@Execute` here is not to directly 
resolve the artifact (since this other stuff, IIUC, happens in a forked 
Maven)... but rather to enable the test in 
_*org.apache.maven.ReactorReader.find(MavenProject, Artifact)*_ to pass (the 
test we use to decide whether to employ this special technique of resolving the 
artifact to the project output dir): 

 

 
{code:java}
 if ( project.hasLifecyclePhase( "compile" ) && COMPILE_PHASE_TYPES.contains( 
type ) ){code}
 

 

I'm not really sure where the list of "types" from *ReactorReader* comes from:

 
 
{code:java}
privatestaticfinal Collection<String> COMPILE_PHASE_TYPES = new HashSet<>(
Arrays.asList("jar", "ejb-client", "war", "rar", "ejb3", "par", "sar", "wsr", 
"har", "app-client"));
{code}
 

It seems there's some overlap with packaging types but also that this is 
possibly a slightly different layer of abstraction?  

 

I wonder though if these types though should align with the types here: 

[https://github.com/apache/maven/blob/master/impl/maven-impl/src/main/java/org/apache/maven/internal/impl/resolver/type/DefaultTypeProvider.java]

e.g.

           
{code:java}
     new DefaultType("ejb", Language.JAVA_FAMILY, "jar", null, false, 
JavaPathType.CLASSES),
                new DefaultType("ejb-client", Language.JAVA_FAMILY, "jar", 
"client", false, JavaPathType.CLASSES),{code}
That's just a guess grepping through code..haven't traced it through.

 

 
h2. *References* 
 * It was working on this issue: 
[https://github.com/openrewrite/rewrite-maven-plugin/issues/920] that led me to 
investigate this.
 * I didn't take the time to digest this but it seems like there might? be some 
overlap: https://issues.apache.org/jira/browse/MNG-8097
 * The issue in which ReactorReader was changed to the relevant  code today: 
https://issues.apache.org/jira/browse/MNG-5898



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

Reply via email to