1 package org.apache.archiva.configuration.functors;
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
12 * http://www.apache.org/licenses/LICENSE-2.0
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
22 import org.apache.archiva.configuration.ProxyConnectorConfiguration;
23 import org.apache.commons.lang.StringUtils;
25 import java.util.ArrayList;
26 import java.util.Collections;
27 import java.util.List;
29 import junit.framework.TestCase;
32 * ProxyConnectorConfigurationOrderComparatorTest
36 public class ProxyConnectorConfigurationOrderComparatorTest
39 public void testSortOfAllZeros()
41 List<ProxyConnectorConfiguration> proxies = new ArrayList<ProxyConnectorConfiguration>();
43 proxies.add( createConnector( "corporate", 0 ) );
44 proxies.add( createConnector( "snapshots", 0 ) );
45 proxies.add( createConnector( "3rdparty", 0 ) );
46 proxies.add( createConnector( "sandbox", 0 ) );
48 Collections.sort( proxies, ProxyConnectorConfigurationOrderComparator.getInstance() );
50 assertProxyOrder( new String[] { "corporate", "snapshots", "3rdparty", "sandbox" }, proxies );
53 public void testSortNormal()
55 List<ProxyConnectorConfiguration> proxies = new ArrayList<ProxyConnectorConfiguration>();
57 proxies.add( createConnector( "corporate", 3 ) );
58 proxies.add( createConnector( "snapshots", 1 ) );
59 proxies.add( createConnector( "3rdparty", 2 ) );
60 proxies.add( createConnector( "sandbox", 4 ) );
62 Collections.sort( proxies, new ProxyConnectorConfigurationOrderComparator() );
64 assertProxyOrder( new String[] { "snapshots", "3rdparty", "corporate", "sandbox" }, proxies );
67 public void testSortPartial()
69 List<ProxyConnectorConfiguration> proxies = new ArrayList<ProxyConnectorConfiguration>();
71 proxies.add( createConnector( "corporate", 3 ) );
72 proxies.add( createConnector( "snapshots", 0 ) );
73 proxies.add( createConnector( "3rdparty", 2 ) );
74 proxies.add( createConnector( "sandbox", 0 ) );
76 Collections.sort( proxies, new ProxyConnectorConfigurationOrderComparator() );
78 assertProxyOrder( new String[] { "3rdparty", "corporate", "snapshots", "sandbox" }, proxies );
81 private void assertProxyOrder( String[] ids, List<ProxyConnectorConfiguration> proxies )
83 assertEquals( "Proxies.size() == ids.length", ids.length, proxies.size() );
85 int orderFailedAt = -1;
87 for ( int i = 0; i < ids.length; i++ )
89 if ( !StringUtils.equals( ids[i], proxies.get( i ).getProxyId() ) )
96 if ( orderFailedAt >= 0 )
98 StringBuffer msg = new StringBuffer();
100 msg.append( "Failed expected order of the proxies <" );
101 msg.append( StringUtils.join( ids, ", " ) );
102 msg.append( ">, actual <" );
104 boolean needsComma = false;
105 for ( ProxyConnectorConfiguration proxy : proxies )
111 msg.append( proxy.getProxyId() );
114 msg.append( "> failure at index <" ).append( orderFailedAt ).append( ">." );
116 fail( msg.toString() );
120 private ProxyConnectorConfiguration createConnector( String id, int order )
122 ProxyConnectorConfiguration proxy = new ProxyConnectorConfiguration();
123 proxy.setProxyId( id );
124 proxy.setOrder( order );
125 proxy.setSourceRepoId( id + "_m" );
126 proxy.setTargetRepoId( id + "_r" );