mirror of https://github.com/apache/maven.git
PR: MNG-1355
Submitted By: Edwin Punzalan Reviewed By: John Casey Applied patch, with small logical fix (used getArtifactId() where getGroupId() was the intention). This patch will guard against overwriting cached models in the project builder (check for pre-existing model in cache before adding), and will validate that a POM's parent has a different groupId:artifactId than the current POM. git-svn-id: https://svn.apache.org/repos/asf/maven/components/trunk@354473 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
eeb14425c6
commit
8e85652193
|
@ -290,7 +290,14 @@ public class DefaultMavenProjectBuilder
|
||||||
// Always cache files in the source tree over those in the repository
|
// Always cache files in the source tree over those in the repository
|
||||||
MavenProject p = new MavenProject( model );
|
MavenProject p = new MavenProject( model );
|
||||||
p.setFile( projectDescriptor );
|
p.setFile( projectDescriptor );
|
||||||
modelCache.put( createCacheKey( model.getGroupId(), model.getArtifactId(), model.getVersion() ), p );
|
|
||||||
|
String modelKey = createCacheKey( model.getGroupId(), model.getArtifactId(), model.getVersion() );
|
||||||
|
if ( modelCache.containsKey( modelKey ) )
|
||||||
|
{
|
||||||
|
throw new ProjectBuildingException( model.getGroupId() + ":" + model.getArtifactId(),
|
||||||
|
"Duplicate project ID found in " + projectDescriptor.getAbsolutePath() );
|
||||||
|
}
|
||||||
|
modelCache.put( modelKey, p );
|
||||||
|
|
||||||
MavenProject project = build( projectDescriptor.getAbsolutePath(), model, localRepository,
|
MavenProject project = build( projectDescriptor.getAbsolutePath(), model, localRepository,
|
||||||
buildArtifactRepositories( getSuperModel() ),
|
buildArtifactRepositories( getSuperModel() ),
|
||||||
|
@ -852,6 +859,12 @@ public class DefaultMavenProjectBuilder
|
||||||
{
|
{
|
||||||
throw new ProjectBuildingException( projectId, "Missing artifactId element from parent element" );
|
throw new ProjectBuildingException( projectId, "Missing artifactId element from parent element" );
|
||||||
}
|
}
|
||||||
|
else if ( parentModel.getGroupId().equals( model.getGroupId() ) &&
|
||||||
|
parentModel.getArtifactId().equals( model.getArtifactId() ) )
|
||||||
|
{
|
||||||
|
throw new ProjectBuildingException( projectId, "Parent element is a duplicate of " +
|
||||||
|
"the current project " );
|
||||||
|
}
|
||||||
else if ( StringUtils.isEmpty( parentModel.getVersion() ) )
|
else if ( StringUtils.isEmpty( parentModel.getVersion() ) )
|
||||||
{
|
{
|
||||||
throw new ProjectBuildingException( projectId, "Missing version element from parent element" );
|
throw new ProjectBuildingException( projectId, "Missing version element from parent element" );
|
||||||
|
|
|
@ -21,6 +21,7 @@ import org.apache.maven.model.Build;
|
||||||
import org.apache.maven.model.Dependency;
|
import org.apache.maven.model.Dependency;
|
||||||
import org.apache.maven.model.DependencyManagement;
|
import org.apache.maven.model.DependencyManagement;
|
||||||
import org.apache.maven.model.Model;
|
import org.apache.maven.model.Model;
|
||||||
|
import org.apache.maven.model.Parent;
|
||||||
import org.apache.maven.model.Plugin;
|
import org.apache.maven.model.Plugin;
|
||||||
import org.apache.maven.model.ReportPlugin;
|
import org.apache.maven.model.ReportPlugin;
|
||||||
import org.apache.maven.model.Reporting;
|
import org.apache.maven.model.Reporting;
|
||||||
|
@ -61,6 +62,16 @@ public class DefaultModelValidator
|
||||||
"require 'pom' as packaging." );
|
"require 'pom' as packaging." );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Parent parent = model.getParent();
|
||||||
|
if ( parent != null )
|
||||||
|
{
|
||||||
|
if ( parent.getGroupId().equals( model.getGroupId() ) &&
|
||||||
|
parent.getArtifactId().equals( model.getArtifactId() ) )
|
||||||
|
{
|
||||||
|
result.addMessage( "The parent element cannot have the same ID as the project." );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
validateStringNotEmpty( "version", result, model.getVersion() );
|
validateStringNotEmpty( "version", result, model.getVersion() );
|
||||||
|
|
||||||
for ( Iterator it = model.getDependencies().iterator(); it.hasNext(); )
|
for ( Iterator it = model.getDependencies().iterator(); it.hasNext(); )
|
||||||
|
|
Loading…
Reference in New Issue