aboutsummaryrefslogtreecommitdiffstats
path: root/framework/src/maven/apache-maven-3.3.3/maven-core/src/test/java/org/apache/maven/project/ProjectSorterTest.java
diff options
context:
space:
mode:
Diffstat (limited to 'framework/src/maven/apache-maven-3.3.3/maven-core/src/test/java/org/apache/maven/project/ProjectSorterTest.java')
-rw-r--r--framework/src/maven/apache-maven-3.3.3/maven-core/src/test/java/org/apache/maven/project/ProjectSorterTest.java363
1 files changed, 0 insertions, 363 deletions
diff --git a/framework/src/maven/apache-maven-3.3.3/maven-core/src/test/java/org/apache/maven/project/ProjectSorterTest.java b/framework/src/maven/apache-maven-3.3.3/maven-core/src/test/java/org/apache/maven/project/ProjectSorterTest.java
deleted file mode 100644
index 5cb45279..00000000
--- a/framework/src/maven/apache-maven-3.3.3/maven-core/src/test/java/org/apache/maven/project/ProjectSorterTest.java
+++ /dev/null
@@ -1,363 +0,0 @@
-package org.apache.maven.project;
-
-/*
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership. The ASF licenses this file
- * to you under the Apache License, Version 2.0 (the
- * "License"); you may not use this file except in compliance
- * with the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing,
- * software distributed under the License is distributed on an
- * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
- * KIND, either express or implied. See the License for the
- * specific language governing permissions and limitations
- * under the License.
- */
-
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.List;
-
-import junit.framework.TestCase;
-
-import org.apache.maven.model.Build;
-import org.apache.maven.model.Dependency;
-import org.apache.maven.model.Extension;
-import org.apache.maven.model.Model;
-import org.apache.maven.model.Parent;
-import org.apache.maven.model.Plugin;
-import org.apache.maven.model.PluginManagement;
-import org.codehaus.plexus.util.dag.CycleDetectedException;
-
-/**
- * Test sorting projects by dependencies.
- *
- * @author <a href="mailto:brett@apache.org">Brett Porter</a>
- */
-public class ProjectSorterTest
- extends TestCase
-{
-
- private Parent createParent( MavenProject project )
- {
- return createParent( project.getGroupId(), project.getArtifactId(), project.getVersion() );
- }
-
- private Parent createParent( String groupId, String artifactId, String version )
- {
- Parent plugin = new Parent();
- plugin.setGroupId( groupId );
- plugin.setArtifactId( artifactId );
- plugin.setVersion( version );
- return plugin;
- }
-
- private Dependency createDependency( MavenProject project )
- {
- return createDependency( project.getGroupId(), project.getArtifactId(), project.getVersion() );
- }
-
- private Dependency createDependency( String groupId, String artifactId, String version )
- {
- Dependency depdendency = new Dependency();
- depdendency.setGroupId( groupId );
- depdendency.setArtifactId( artifactId );
- depdendency.setVersion( version );
- return depdendency;
- }
-
- private Plugin createPlugin( MavenProject project )
- {
- return createPlugin( project.getGroupId(), project.getArtifactId(), project.getVersion() );
- }
-
- private Plugin createPlugin( String groupId, String artifactId, String version )
- {
- Plugin plugin = new Plugin();
- plugin.setGroupId( groupId );
- plugin.setArtifactId( artifactId );
- plugin.setVersion( version );
- return plugin;
- }
-
- private Extension createExtension( String groupId, String artifactId, String version )
- {
- Extension extension = new Extension();
- extension.setGroupId( groupId );
- extension.setArtifactId( artifactId );
- extension.setVersion( version );
- return extension;
- }
-
- private static MavenProject createProject( String groupId, String artifactId, String version )
- {
- Model model = new Model();
- model.setGroupId( groupId );
- model.setArtifactId( artifactId );
- model.setVersion( version );
- model.setBuild( new Build() );
- return new MavenProject( model );
- }
-
- public void testShouldNotFailWhenPluginDepReferencesCurrentProject()
- throws CycleDetectedException, DuplicateProjectException
- {
- MavenProject project = createProject( "group", "artifact", "1.0" );
-
- Build build = project.getModel().getBuild();
-
- Plugin plugin = createPlugin( "other.group", "other-artifact", "1.0" );
-
- Dependency dep = createDependency( "group", "artifact", "1.0" );
-
- plugin.addDependency( dep );
-
- build.addPlugin( plugin );
-
- new ProjectSorter( Collections.singletonList( project ) );
- }
-
- public void testShouldNotFailWhenManagedPluginDepReferencesCurrentProject()
- throws CycleDetectedException, DuplicateProjectException
- {
- MavenProject project = createProject( "group", "artifact", "1.0" );
-
- Build build = project.getModel().getBuild();
-
- PluginManagement pMgmt = new PluginManagement();
-
- Plugin plugin = createPlugin( "other.group", "other-artifact", "1.0" );
-
- Dependency dep = createDependency( "group", "artifact", "1.0" );
-
- plugin.addDependency( dep );
-
- pMgmt.addPlugin( plugin );
-
- build.setPluginManagement( pMgmt );
-
- new ProjectSorter( Collections.singletonList( project ) );
- }
-
- public void testShouldNotFailWhenProjectReferencesNonExistentProject()
- throws CycleDetectedException, DuplicateProjectException
- {
- MavenProject project = createProject( "group", "artifact", "1.0" );
-
- Build build = project.getModel().getBuild();
-
- Extension extension = createExtension( "other.group", "other-artifact", "1.0" );
-
- build.addExtension( extension );
-
- new ProjectSorter( Collections.singletonList( project ) );
- }
-
- public void testMatchingArtifactIdsDifferentGroupIds()
- throws CycleDetectedException, DuplicateProjectException
- {
- List<MavenProject> projects = new ArrayList<MavenProject>();
- MavenProject project1 = createProject( "groupId1", "artifactId", "1.0" );
- projects.add( project1 );
- MavenProject project2 = createProject( "groupId2", "artifactId", "1.0" );
- projects.add( project2 );
- project1.getDependencies().add( createDependency( project2 ) );
-
- projects = new ProjectSorter( projects ).getSortedProjects();
-
- assertEquals( project2, projects.get( 0 ) );
- assertEquals( project1, projects.get( 1 ) );
- }
-
- public void testMatchingGroupIdsDifferentArtifactIds()
- throws CycleDetectedException, DuplicateProjectException
- {
- List<MavenProject> projects = new ArrayList<MavenProject>();
- MavenProject project1 = createProject( "groupId", "artifactId1", "1.0" );
- projects.add( project1 );
- MavenProject project2 = createProject( "groupId", "artifactId2", "1.0" );
- projects.add( project2 );
- project1.getDependencies().add( createDependency( project2 ) );
-
- projects = new ProjectSorter( projects ).getSortedProjects();
-
- assertEquals( project2, projects.get( 0 ) );
- assertEquals( project1, projects.get( 1 ) );
- }
-
- public void testMatchingIdsAndVersions()
- throws CycleDetectedException
- {
- List<MavenProject> projects = new ArrayList<MavenProject>();
- MavenProject project1 = createProject( "groupId", "artifactId", "1.0" );
- projects.add( project1 );
- MavenProject project2 = createProject( "groupId", "artifactId", "1.0" );
- projects.add( project2 );
-
- try
- {
- projects = new ProjectSorter( projects ).getSortedProjects();
- fail( "Duplicate projects should fail" );
- }
- catch ( DuplicateProjectException e )
- {
- // expected
- assertTrue( true );
- }
- }
-
- public void testMatchingIdsAndDifferentVersions()
- throws CycleDetectedException, DuplicateProjectException
- {
- List<MavenProject> projects = new ArrayList<MavenProject>();
- MavenProject project1 = createProject( "groupId", "artifactId", "1.0" );
- projects.add( project1 );
- MavenProject project2 = createProject( "groupId", "artifactId", "2.0" );
- projects.add( project2 );
-
- projects = new ProjectSorter( projects ).getSortedProjects();
- assertEquals( project1, projects.get( 0 ) );
- assertEquals( project2, projects.get( 1 ) );
- }
-
- public void testPluginDependenciesInfluenceSorting()
- throws Exception
- {
- List<MavenProject> projects = new ArrayList<MavenProject>();
-
- MavenProject parentProject = createProject( "groupId", "parent", "1.0" );
- projects.add( parentProject );
-
- MavenProject declaringProject = createProject( "groupId", "declarer", "1.0" );
- declaringProject.setParent( parentProject );
- declaringProject.getModel().setParent( createParent( parentProject ) );
- projects.add( declaringProject );
-
- MavenProject pluginLevelDepProject = createProject( "groupId", "plugin-level-dep", "1.0" );
- pluginLevelDepProject.setParent( parentProject );
- pluginLevelDepProject.getModel().setParent( createParent( parentProject ) );
- projects.add( pluginLevelDepProject );
-
- MavenProject pluginProject = createProject( "groupId", "plugin", "1.0" );
- pluginProject.setParent( parentProject );
- pluginProject.getModel().setParent( createParent( parentProject ) );
- projects.add( pluginProject );
-
- Plugin plugin = createPlugin( pluginProject );
-
- plugin.addDependency( createDependency( pluginLevelDepProject ) );
-
- Build build = declaringProject.getModel().getBuild();
-
- build.addPlugin( plugin );
-
- projects = new ProjectSorter( projects ).getSortedProjects();
-
- assertEquals( parentProject, projects.get( 0 ) );
-
- // the order of these two is non-deterministic, based on when they're added to the reactor.
- assertTrue( projects.contains( pluginProject ) );
- assertTrue( projects.contains( pluginLevelDepProject ) );
-
- // the declaring project MUST be listed after the plugin and its plugin-level dep, though.
- assertEquals( declaringProject, projects.get( 3 ) );
- }
-
- public void testPluginDependenciesInfluenceSorting_DeclarationInParent()
- throws Exception
- {
- List<MavenProject> projects = new ArrayList<MavenProject>();
-
- MavenProject parentProject = createProject( "groupId", "parent-declarer", "1.0" );
- projects.add( parentProject );
-
- MavenProject pluginProject = createProject( "groupId", "plugin", "1.0" );
- pluginProject.setParent( parentProject );
- pluginProject.getModel().setParent( createParent( parentProject ) );
- projects.add( pluginProject );
-
- MavenProject pluginLevelDepProject = createProject( "groupId", "plugin-level-dep", "1.0" );
- pluginLevelDepProject.setParent( parentProject );
- pluginLevelDepProject.getModel().setParent( createParent( parentProject ) );
- projects.add( pluginLevelDepProject );
-
- Plugin plugin = createPlugin( pluginProject );
-
- plugin.addDependency( createDependency( pluginLevelDepProject ) );
-
- Build build = parentProject.getModel().getBuild();
-
- build.addPlugin( plugin );
-
- projects = new ProjectSorter( projects ).getSortedProjects();
-
- System.out.println( projects );
-
- assertEquals( parentProject, projects.get( 0 ) );
-
- // the order of these two is non-deterministic, based on when they're added to the reactor.
- assertTrue( projects.contains( pluginProject ) );
- assertTrue( projects.contains( pluginLevelDepProject ) );
- }
-
- public void testPluginVersionsAreConsidered()
- throws Exception
- {
- List<MavenProject> projects = new ArrayList<MavenProject>();
-
- MavenProject pluginProjectA = createProject( "group", "plugin-a", "2.0-SNAPSHOT" );
- projects.add( pluginProjectA );
- pluginProjectA.getModel().getBuild().addPlugin( createPlugin( "group", "plugin-b", "1.0" ) );
-
- MavenProject pluginProjectB = createProject( "group", "plugin-b", "2.0-SNAPSHOT" );
- projects.add( pluginProjectB );
- pluginProjectB.getModel().getBuild().addPlugin( createPlugin( "group", "plugin-a", "1.0" ) );
-
- projects = new ProjectSorter( projects ).getSortedProjects();
-
- assertTrue( projects.contains( pluginProjectA ) );
- assertTrue( projects.contains( pluginProjectB ) );
- }
-
- public void testDependencyPrecedesProjectThatUsesSpecificDependencyVersion()
- throws Exception
- {
- List<MavenProject> projects = new ArrayList<MavenProject>();
-
- MavenProject usingProject = createProject( "group", "project", "1.0" );
- projects.add( usingProject );
- usingProject.getModel().addDependency( createDependency( "group", "dependency", "1.0" ) );
-
- MavenProject pluginProject = createProject( "group", "dependency", "1.0" );
- projects.add( pluginProject );
-
- projects = new ProjectSorter( projects ).getSortedProjects();
-
- assertEquals( pluginProject, projects.get( 0 ) );
- assertEquals( usingProject, projects.get( 1 ) );
- }
-
- public void testDependencyPrecedesProjectThatUsesUnresolvedDependencyVersion()
- throws Exception
- {
- List<MavenProject> projects = new ArrayList<MavenProject>();
-
- MavenProject usingProject = createProject( "group", "project", "1.0" );
- projects.add( usingProject );
- usingProject.getModel().addDependency( createDependency( "group", "dependency", "[1.0,)" ) );
-
- MavenProject pluginProject = createProject( "group", "dependency", "1.0" );
- projects.add( pluginProject );
-
- projects = new ProjectSorter( projects ).getSortedProjects();
-
- assertEquals( pluginProject, projects.get( 0 ) );
- assertEquals( usingProject, projects.get( 1 ) );
- }
-
-}