diff options
Diffstat (limited to 'framework/src/maven/apache-maven-3.3.3/maven-compat/src/test/java/org/apache/maven/repository/legacy/resolver/conflict/NearestConflictResolverTest.java')
-rw-r--r-- | framework/src/maven/apache-maven-3.3.3/maven-compat/src/test/java/org/apache/maven/repository/legacy/resolver/conflict/NearestConflictResolverTest.java | 107 |
1 files changed, 107 insertions, 0 deletions
diff --git a/framework/src/maven/apache-maven-3.3.3/maven-compat/src/test/java/org/apache/maven/repository/legacy/resolver/conflict/NearestConflictResolverTest.java b/framework/src/maven/apache-maven-3.3.3/maven-compat/src/test/java/org/apache/maven/repository/legacy/resolver/conflict/NearestConflictResolverTest.java new file mode 100644 index 00000000..0c7b035f --- /dev/null +++ b/framework/src/maven/apache-maven-3.3.3/maven-compat/src/test/java/org/apache/maven/repository/legacy/resolver/conflict/NearestConflictResolverTest.java @@ -0,0 +1,107 @@ +package org.apache.maven.repository.legacy.resolver.conflict; + +/* + * 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.Collections; + +import org.apache.maven.artifact.resolver.ResolutionNode; +import org.apache.maven.repository.legacy.resolver.conflict.NearestConflictResolver; + +/** + * Tests <code>NearestConflictResolver</code>. + * + * @author <a href="mailto:markhobson@gmail.com">Mark Hobson</a> + * @see NearestConflictResolver + */ +public class NearestConflictResolverTest + extends AbstractConflictResolverTest +{ + // constructors ----------------------------------------------------------- + + public NearestConflictResolverTest() + throws Exception + { + super("nearest"); + } + + // tests ------------------------------------------------------------------ + + /** + * Tests that <code>a:1.0</code> wins in the scenario: + * <pre> + * a:1.0 + * b:1.0 -> a:2.0 + * </pre> + */ + public void testDepth() + { + ResolutionNode a1n = new ResolutionNode( a1, Collections.EMPTY_LIST ); + ResolutionNode b1n = new ResolutionNode( b1, Collections.EMPTY_LIST ); + ResolutionNode a2n = new ResolutionNode( a2, Collections.EMPTY_LIST, b1n ); + + assertResolveConflict( a1n, a1n, a2n ); + } + + /** + * Tests that <code>a:1.0</code> wins in the scenario: + * <pre> + * b:1.0 -> a:2.0 + * a:1.0 + * </pre> + */ + public void testDepthReversed() + { + ResolutionNode b1n = new ResolutionNode( b1, Collections.EMPTY_LIST ); + ResolutionNode a2n = new ResolutionNode( a2, Collections.EMPTY_LIST, b1n ); + ResolutionNode a1n = new ResolutionNode( a1, Collections.EMPTY_LIST ); + + assertResolveConflict( a1n, a2n, a1n ); + } + + /** + * Tests that <code>a:1.0</code> wins in the scenario: + * <pre> + * a:1.0 + * a:2.0 + * </pre> + */ + public void testEqual() + { + ResolutionNode a1n = new ResolutionNode( a1, Collections.EMPTY_LIST ); + ResolutionNode a2n = new ResolutionNode( a2, Collections.EMPTY_LIST ); + + assertResolveConflict( a1n, a1n, a2n ); + } + + /** + * Tests that <code>a:2.0</code> wins in the scenario: + * <pre> + * a:2.0 + * a:1.0 + * </pre> + */ + public void testEqualReversed() + { + ResolutionNode a2n = new ResolutionNode( a2, Collections.EMPTY_LIST ); + ResolutionNode a1n = new ResolutionNode( a1, Collections.EMPTY_LIST ); + + assertResolveConflict( a2n, a2n, a1n ); + } +} |