View Javadoc
1   package org.eclipse.aether.util.graph.visitor;
2   
3   /*
4    * Licensed to the Apache Software Foundation (ASF) under one
5    * or more contributor license agreements.  See the NOTICE file
6    * distributed with this work for additional information
7    * regarding copyright ownership.  The ASF licenses this file
8    * to you under the Apache License, Version 2.0 (the
9    * "License"); you may not use this file except in compliance
10   * with the License.  You may obtain a copy of the License at
11   * 
12   *  http://www.apache.org/licenses/LICENSE-2.0
13   * 
14   * Unless required by applicable law or agreed to in writing,
15   * software distributed under the License is distributed on an
16   * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
17   * KIND, either express or implied.  See the License for the
18   * specific language governing permissions and limitations
19   * under the License.
20   */
21  
22  import static org.junit.Assert.*;
23  
24  import java.util.List;
25  
26  import org.eclipse.aether.graph.DependencyNode;
27  import org.eclipse.aether.internal.test.util.DependencyGraphParser;
28  import org.junit.Test;
29  
30  public class PostorderNodeListGeneratorTest
31  {
32  
33      private DependencyNode parse( String resource )
34          throws Exception
35      {
36          return new DependencyGraphParser( "visitor/ordered-list/" ).parseResource( resource );
37      }
38  
39      private void assertSequence( List<DependencyNode> actual, String... expected )
40      {
41          assertEquals( actual.toString(), expected.length, actual.size() );
42          for ( int i = 0; i < expected.length; i++ )
43          {
44              DependencyNode node = actual.get( i );
45              assertEquals( actual.toString(), expected[i], node.getDependency().getArtifact().getArtifactId() );
46          }
47      }
48  
49      @Test
50      public void testOrdering()
51          throws Exception
52      {
53          DependencyNode root = parse( "simple.txt" );
54  
55          PostorderNodeListGenerator visitor = new PostorderNodeListGenerator();
56          root.accept( visitor );
57  
58          assertSequence( visitor.getNodes(), "c", "b", "e", "d", "a" );
59      }
60  
61      @Test
62      public void testDuplicateSuppression()
63          throws Exception
64      {
65          DependencyNode root = parse( "cycles.txt" );
66  
67          PostorderNodeListGenerator visitor = new PostorderNodeListGenerator();
68          root.accept( visitor );
69  
70          assertSequence( visitor.getNodes(), "c", "b", "e", "d", "a" );
71      }
72  
73  }