You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@maven.apache.org by og...@apache.org on 2009/02/04 08:25:16 UTC

svn commit: r740646 - /maven/mercury/trunk/mercury-it/src/test/java/org/apache/maven/mercury/repository/tests/ComplexRepositoryTest.java

Author: ogusakov
Date: Wed Feb  4 07:25:16 2009
New Revision: 740646

URL: http://svn.apache.org/viewvc?rev=740646&view=rev
Log:
adding a thorough repository test: multiple remote, multiple local

Added:
    maven/mercury/trunk/mercury-it/src/test/java/org/apache/maven/mercury/repository/tests/ComplexRepositoryTest.java   (with props)

Added: maven/mercury/trunk/mercury-it/src/test/java/org/apache/maven/mercury/repository/tests/ComplexRepositoryTest.java
URL: http://svn.apache.org/viewvc/maven/mercury/trunk/mercury-it/src/test/java/org/apache/maven/mercury/repository/tests/ComplexRepositoryTest.java?rev=740646&view=auto
==============================================================================
--- maven/mercury/trunk/mercury-it/src/test/java/org/apache/maven/mercury/repository/tests/ComplexRepositoryTest.java (added)
+++ maven/mercury/trunk/mercury-it/src/test/java/org/apache/maven/mercury/repository/tests/ComplexRepositoryTest.java Wed Feb  4 07:25:16 2009
@@ -0,0 +1,156 @@
+/*
+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.
+*/
+
+package org.apache.maven.mercury.repository.tests;
+
+import java.io.File;
+import java.net.URL;
+import java.util.ArrayList;
+import java.util.List;
+
+import org.apache.maven.mercury.MavenDependencyProcessor;
+import org.apache.maven.mercury.artifact.Artifact;
+import org.apache.maven.mercury.artifact.ArtifactBasicMetadata;
+import org.apache.maven.mercury.artifact.DefaultArtifact;
+import org.apache.maven.mercury.builder.api.DependencyProcessor;
+import org.apache.maven.mercury.repository.local.m2.LocalRepositoryM2;
+import org.apache.maven.mercury.repository.remote.m2.RemoteRepositoryM2;
+import org.apache.maven.mercury.transport.api.Credentials;
+import org.apache.maven.mercury.transport.api.Server;
+import org.apache.maven.mercury.util.FileUtil;
+import org.codehaus.plexus.PlexusTestCase;
+
+import junit.framework.TestCase;
+
+/**
+ * This set of UTs covers a complex use case,
+ * involving majority of Mercury repository functionality
+ *
+ * @author Oleg Gusakov
+ * @version $Id$
+ *
+ */
+public class ComplexRepositoryTest
+extends PlexusTestCase
+{
+    WebDavServer _server1;
+    File         _base1;
+    static final String _context1 = "/webdav1";
+    int _port1;
+    RemoteRepositoryM2 _rr1;
+    
+    WebDavServer _server2;
+    File         _base2;
+    static final String _context2 = "/webdav2";
+    int _port2;
+    RemoteRepositoryM2 _rr2;
+    
+    File _lbase1;
+    static final String _local1 = "./target/webdav1local";
+    LocalRepositoryM2 _lr1;
+    
+    File _lbase2;
+    static final String _local2 = "./target/webdav2local";
+    LocalRepositoryM2 _lr2;
+    
+    static final String _resourceBase = "./target/test-classes";
+    
+    
+    @Override
+    protected void setUp()
+        throws Exception
+    {
+        super.setUp();
+        
+        DependencyProcessor dp = new MavenDependencyProcessor();
+        Credentials user = new Credentials("foo","bar");
+        
+        _base1 = new File( "./target/webdav1" );
+        FileUtil.delete( _base1 );
+        _base1.mkdirs();
+        _server1 = new WebDavServer( 0, _base1, _context1, getContainer(), 9, "mercury-test-1" );
+        _server1.start();
+        _port1 = _server1.getPort();
+        
+        Server server = new Server("rr1", new URL("http://localhost:"+_port1+_context1), false, false, user );
+        _rr1 = new RemoteRepositoryM2( server, dp );
+        
+        _base2 = new File( "./target/webdav2" );
+        FileUtil.delete( _base2 );
+        _base2.mkdirs();
+        _server2 = new WebDavServer( 0, _base2, _context2, getContainer(), 9, "mercury-test-2" );
+        _server2.start();
+        _port2 = _server2.getPort();
+        
+        server = new Server("rr2", new URL("http://localhost:"+_port2+_context2), false, false, user );
+        _rr2 = new RemoteRepositoryM2( server, dp );
+        
+        _lbase1 = new File( _local1 );
+        FileUtil.delete( _lbase1 );
+        _lbase1.mkdirs();
+        _lr1 = new LocalRepositoryM2( "lr1", _lbase1, dp );
+        
+        _lbase2 = new File( _local2 );
+        FileUtil.delete( _lbase2 );
+        _lbase2.mkdirs();
+        _lr2 = new LocalRepositoryM2( "lr2", _lbase2, dp );
+        
+    }
+
+    @Override
+    protected void tearDown()
+        throws Exception
+    {
+        super.tearDown();
+        
+        if( _server1 != null )
+            try
+            {
+                _server1.stop();
+                _server1.destroy();
+            }
+            catch( Exception e ) {}
+            finally { _server1 = null; }
+            
+        if( _server2 != null )
+            try
+            {
+                _server2.stop();
+                _server2.destroy();
+            }
+            catch( Exception e ) {}
+            finally { _server2 = null; }
+    }
+    
+    public void testWriteReadArtifact()
+    throws Exception
+    {
+        File af = new File( _resourceBase, "maven-core-2.0.9.jar" );
+        File ap = new File( _resourceBase, "maven-core-2.0.9.pom" );
+        
+        DefaultArtifact da = new DefaultArtifact( new ArtifactBasicMetadata("org.apache.maven:maven-core:2.0.9") );
+        
+        da.setPomBlob( FileUtil.readRawData( ap ) );
+        da.setFile( af );
+        List<Artifact> al = new ArrayList<Artifact>();
+        al.add( da );
+        
+        _rr2.getWriter().writeArtifacts( al );
+    }
+}

Propchange: maven/mercury/trunk/mercury-it/src/test/java/org/apache/maven/mercury/repository/tests/ComplexRepositoryTest.java
------------------------------------------------------------------------------
    svn:eol-style = native

Propchange: maven/mercury/trunk/mercury-it/src/test/java/org/apache/maven/mercury/repository/tests/ComplexRepositoryTest.java
------------------------------------------------------------------------------
    svn:keywords = Author Date Id Revision