Author: ogusakov
Date: Sat Feb 7 00:29:09 2009
New Revision: 741799
URL: http://svn.apache.org/viewvc?rev=741799&view=rev
Log:
added coverage configuration to ITs
Added:
maven/mercury/trunk/mercury-it/src/test/java/org/apache/maven/mercury/repository/tests/AbstractRepositoryTest.java
(with props)
Modified:
maven/mercury/trunk/mercury-it/pom.xml
maven/mercury/trunk/mercury-it/src/test/java/org/apache/maven/mercury/all/it/AllTestCases.java
maven/mercury/trunk/pom.xml
Modified: maven/mercury/trunk/mercury-it/pom.xml
URL:
http://svn.apache.org/viewvc/maven/mercury/trunk/mercury-it/pom.xml?rev=741799&r1=741798&r2=741799&view=diff
==============================================================================
--- maven/mercury/trunk/mercury-it/pom.xml (original)
+++ maven/mercury/trunk/mercury-it/pom.xml Sat Feb 7 00:29:09 2009
@@ -215,25 +215,105 @@
</testResources>
<plugins>
+
+
<plugin>
- <artifactId>maven-dependency-plugin</artifactId>
- <version>2.0</version>
+ <groupId>org.apache.maven.plugins</groupId>
+ <artifactId>maven-surefire-plugin</artifactId>
+
+ <configuration>
+ <includes>
+
<include>org/apache/maven/mercury/all/it/AllTestCases.java</include>
+ </includes>
+ </configuration>
+<!--
<executions>
+
<execution>
- <id>unpack-bundle</id>
- <phase>generate-resources</phase>
+ <id>test</id>
+ <phase>test</phase>
<goals>
- <goal>unpack-dependencies</goal>
+ <goal>test</goal>
</goals>
<configuration>
- <includeArtifactIds>nexus-webapp</includeArtifactIds>
- <outputDirectory>${bundle-expanded-dir}</outputDirectory>
- <excludes>**/conf/plexus.properties</excludes>
+ <includes>
+
<include>org/apache/maven/mercury/all/it/AllTestCases.java</include>
+ </includes>
</configuration>
</execution>
-
</executions>
+ -->
</plugin>
+
+ <plugin>
+ <groupId>org.sonatype.maven.plugin</groupId>
+ <artifactId>emma4it-maven-plugin</artifactId>
+ <version>${emma4it.plugin.version}</version>
+ </plugin>
+
+
</plugins>
</build>
+
+ <reporting>
+ <plugins>
+
+ <plugin>
+ <groupId>org.sonatype.maven.plugin</groupId>
+ <artifactId>emma4it-maven-plugin</artifactId>
+ <version>${emma4it.plugin.version}</version>
+
+ <configuration>
+ <searchPath>${basedir}</searchPath>
+
+ <sourceFolders>
+
<sourceFolder>${basedir}/../mercury-artifact/src/main/java</sourceFolder>
+
<sourceFolder>${basedir}/../mercury-crypto/mercury-crypto-api/src/main/java</sourceFolder>
+
<sourceFolder>${basedir}/../mercury-crypto/mercury-crypto-basic/src/main/java</sourceFolder>
+
<sourceFolder>${basedir}/../mercury-event/src/main/java</sourceFolder>
+
<sourceFolder>${basedir}/../mercury-external/src/main/java</sourceFolder>
+
<sourceFolder>${basedir}/../mercury-logging/src/main/java</sourceFolder>
+
<sourceFolder>${basedir}/../mercury-md/mercury-md-shared/src/main/java</sourceFolder>
+
<sourceFolder>${basedir}/../mercury-md/mercury-md-sat/src/main/java</sourceFolder>
+
<sourceFolder>${basedir}/../mercury-plexus/src/main/java</sourceFolder>
+
<sourceFolder>${basedir}/../mercury-repo/mercury-repo-api/src/main/java</sourceFolder>
+
<sourceFolder>${basedir}/../mercury-repo/mercury-repo-cache-fs/src/main/java</sourceFolder>
+
<sourceFolder>${basedir}/../mercury-repo/mercury-repo-flat/src/main/java</sourceFolder>
+
<sourceFolder>${basedir}/../mercury-repo/mercury-repo-local-m2/src/main/java</sourceFolder>
+
<sourceFolder>${basedir}/../mercury-repo/mercury-repo-local-map/src/main/java</sourceFolder>
+
<sourceFolder>${basedir}/../mercury-repo/mercury-repo-remote-m2/src/main/java</sourceFolder>
+
<sourceFolder>${basedir}/../mercury-repo/mercury-repo-virtual/src/main/java</sourceFolder>
+
<sourceFolder>${basedir}/../mercury-transport/mercury-transport-api/src/main/java</sourceFolder>
+
<sourceFolder>${basedir}/../mercury-transport/mercury-transport-http/src/main/java</sourceFolder>
+
<sourceFolder>${basedir}/../mercury-util/src/main/java</sourceFolder>
+ </sourceFolders>
+
+ <jarFiles>
+
<jarFile>${basedir}/../mercury-artifact/target/mercury-artifact-${project.version}.jar</jarFile>
+
<jarFile>${basedir}/../mercury-crypto/mercury-crypto-api/target/mercury-crypto-api-${project.version}.jar</jarFile>
+
<jarFile>${basedir}/../mercury-crypto/mercury-crypto-basic/target/mercury-crypto-basic-${project.version}.jar</jarFile>
+
<jarFile>${basedir}/../mercury-event/target/mercury-event-${project.version}.jar</jarFile>
+
<jarFile>${basedir}/../mercury-external/target/mercury-external-${project.version}.jar</jarFile>
+
<jarFile>${basedir}/../mercury-logging/target/mercury-logging-${project.version}.jar</jarFile>
+
<jarFile>${basedir}/../mercury-md/mercury-md-shared/target/mercury-md-shared-${project.version}.jar</jarFile>
+
<jarFile>${basedir}/../mercury-md/mercury-md-sat/target/mercury-md-sat-${project.version}.jar</jarFile>
+
<jarFile>${basedir}/../mercury-plexus/target/mercury-plexus-${project.version}.jar</jarFile>
+
<jarFile>${basedir}/../mercury-repo/mercury-repo-api/target/mercury-repo-api-${project.version}.jar</jarFile>
+
<jarFile>${basedir}/../mercury-repo/mercury-repo-cache-fs/target/mercury-repo-cache-fs-${project.version}.jar</jarFile>
+
<jarFile>${basedir}/../mercury-repo/mercury-repo-local-m2/target/mercury-repo-local-m2-${project.version}.jar</jarFile>
+
<jarFile>${basedir}/../mercury-repo/mercury-repo-local-map/target/mercury-repo-local-map-${project.version}.jar</jarFile>
+
<jarFile>${basedir}/../mercury-repo/mercury-repo-remote-m2/target/mercury-repo-remote-m2-${project.version}.jar</jarFile>
+
<jarFile>${basedir}/../mercury-repo/mercury-repo-remote-virtual/target/mercury-repo-remote-virtual-${project.version}.jar</jarFile>
+
<jarFile>${basedir}/../mercury-transport/mercury-transport-api/target/mercury-transport-api-${project.version}.jar</jarFile>
+
<jarFile>${basedir}/../mercury-transport/mercury-transport-http/target/mercury-transport-http-${project.version}.jar</jarFile>
+
<jarFile>${basedir}/../mercury-util/target/mercury-util-${project.version}.jar</jarFile>
+ </jarFiles>
+ </configuration>
+
+ </plugin>
+
+ </plugins>
+ </reporting>
+
+
</project>
Modified:
maven/mercury/trunk/mercury-it/src/test/java/org/apache/maven/mercury/all/it/AllTestCases.java
URL:
http://svn.apache.org/viewvc/maven/mercury/trunk/mercury-it/src/test/java/org/apache/maven/mercury/all/it/AllTestCases.java?rev=741799&r1=741798&r2=741799&view=diff
==============================================================================
---
maven/mercury/trunk/mercury-it/src/test/java/org/apache/maven/mercury/all/it/AllTestCases.java
(original)
+++
maven/mercury/trunk/mercury-it/src/test/java/org/apache/maven/mercury/all/it/AllTestCases.java
Sat Feb 7 00:29:09 2009
@@ -19,6 +19,18 @@
package org.apache.maven.mercury.all.it;
+import org.apache.maven.mercury.dependency.tests.DependencyTreeBuilderTest;
+import org.apache.maven.mercury.plexus.DefaultPlexusMercuryTest;
+import org.apache.maven.mercury.repository.tests.ComprehensiveRepositoryTest;
+import org.apache.maven.mercury.repository.tests.DavServerTest;
+import org.apache.maven.mercury.repository.tests.LocalRepositoryReaderM2Test;
+import org.apache.maven.mercury.repository.tests.LocalRepositoryWriterM2Test;
+import org.apache.maven.mercury.repository.tests.ReadWriteTest;
+import
org.apache.maven.mercury.repository.tests.RemoteRepositoryCachingReaderM2Test;
+import org.apache.maven.mercury.repository.tests.RemoteRepositoryReaderM2Test;
+import org.apache.maven.mercury.repository.tests.RemoteRepositoryWriterM2Test;
+import
org.apache.maven.mercury.repository.tests.VirtualRepositoryReaderIntegratedTest;
+
import junit.framework.Test;
import junit.framework.TestSuite;
@@ -58,7 +70,7 @@
/*
* This must be the first one to ensure the local repository is
properly setup.
*/
-// suite.addTestSuite( MercuryITBootstrapTest.class );
+ suite.addTestSuite( DavServerTest.class );
/*
* Add tests in reverse alpha order by number below. This makes
testing new
@@ -66,6 +78,16 @@
* the tests are to finishing. Newer tests are also more likely to
fail, so this is
* a fail fast technique as well.
*/
+ suite.addTestSuite( LocalRepositoryReaderM2Test.class );
+ suite.addTestSuite( LocalRepositoryWriterM2Test.class );
+ suite.addTestSuite( ReadWriteTest.class );
+ suite.addTestSuite( RemoteRepositoryCachingReaderM2Test.class );
+ suite.addTestSuite( RemoteRepositoryReaderM2Test.class );
+ suite.addTestSuite( RemoteRepositoryWriterM2Test.class );
+ suite.addTestSuite( DependencyTreeBuilderTest.class );
+ suite.addTestSuite( VirtualRepositoryReaderIntegratedTest.class );
+ suite.addTestSuite( DefaultPlexusMercuryTest.class );
+ suite.addTestSuite( ComprehensiveRepositoryTest.class );
/*
Added:
maven/mercury/trunk/mercury-it/src/test/java/org/apache/maven/mercury/repository/tests/AbstractRepositoryTest.java
URL:
http://svn.apache.org/viewvc/maven/mercury/trunk/mercury-it/src/test/java/org/apache/maven/mercury/repository/tests/AbstractRepositoryTest.java?rev=741799&view=auto
==============================================================================
---
maven/mercury/trunk/mercury-it/src/test/java/org/apache/maven/mercury/repository/tests/AbstractRepositoryTest.java
(added)
+++
maven/mercury/trunk/mercury-it/src/test/java/org/apache/maven/mercury/repository/tests/AbstractRepositoryTest.java
Sat Feb 7 00:29:09 2009
@@ -0,0 +1,655 @@
+/*
+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.api.ArtifactBasicResults;
+import org.apache.maven.mercury.repository.api.ArtifactResults;
+import org.apache.maven.mercury.repository.api.Repository;
+import org.apache.maven.mercury.repository.local.m2.LocalRepositoryM2;
+import org.apache.maven.mercury.repository.remote.m2.RemoteRepositoryM2;
+import org.apache.maven.mercury.repository.virtual.VirtualRepositoryReader;
+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;
+
+/**
+ * This set of UTs covers a comprehensive use case,
+ * involving majority of Mercury repository functionality
+ *
+ * @author Oleg Gusakov
+ * @version $Id$
+ *
+ */
+public abstract class AbstractRepositoryTest
+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";
+
+ static final File af = new File( _resourceBase, "maven-core-2.0.9.jar" );
+ static final File ap = new File( _resourceBase, "maven-core-2.0.9.pom" );
+
+ List<Repository> _rrs;
+ List<Repository> _lrs;
+ List<Repository> _repos;
+
+
+ @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 );
+
+ _rrs = new ArrayList<Repository>(2);
+ _rrs.add( _rr1 );
+ _rrs.add( _rr2 );
+
+ _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 );
+
+ _lrs = new ArrayList<Repository>(2);
+ _lrs.add( _lr1 );
+ _lrs.add( _lr2 );
+
+ _repos = new ArrayList<Repository>();
+ _repos.addAll( _rrs );
+ _repos.addAll( _lrs );
+
+ }
+
+ @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; }
+ }
+
+ protected void writeName( String name, Repository repo )
+ throws Exception
+ {
+ writeArtifact( name, af, ap, repo );
+ }
+
+ public void writeArtifact( String name, File af, File ap, Repository repo )
+ throws Exception
+ {
+ DefaultArtifact da = new DefaultArtifact( new
ArtifactBasicMetadata(name) );
+
+ da.setPomBlob( FileUtil.readRawData( ap ) );
+ da.setFile( af );
+ List<Artifact> al = new ArrayList<Artifact>();
+ al.add( da );
+
+ repo.getWriter().writeArtifacts( al );
+ }
+
+ public List<Artifact> readArtifact( String name , List<Repository> repos )
+ throws Exception
+ {
+ ArtifactBasicMetadata bmd = new ArtifactBasicMetadata(name);
+
+ List<ArtifactBasicMetadata> al = new
ArrayList<ArtifactBasicMetadata>();
+ al.add( bmd );
+
+ VirtualRepositoryReader vr = new VirtualRepositoryReader( repos );
+
+ ArtifactResults res = vr.readArtifacts( al );
+
+ assertNotNull( res );
+
+ if( res.hasExceptions() )
+ System.out.println( res.getExceptions() );
+
+ assertTrue( res.hasResults(bmd) );
+
+ return res.getResults( bmd );
+ }
+
+ public List<ArtifactBasicMetadata> readVersions( String name ,
List<Repository> repos )
+ throws Exception
+ {
+ ArtifactBasicMetadata bmd = new ArtifactBasicMetadata(name);
+
+ List<ArtifactBasicMetadata> al = new
ArrayList<ArtifactBasicMetadata>();
+ al.add( bmd );
+
+ VirtualRepositoryReader vr = new VirtualRepositoryReader( repos );
+
+ ArtifactBasicResults res = vr.readVersions( al );
+
+ assertNotNull( res );
+
+ if( res.hasExceptions() )
+ System.out.println( res.getExceptions() );
+
+ assertTrue( res.hasResults(bmd) );
+
+ return res.getResult( bmd );
+ }
+
+ public void testWriteReadArtifact()
+ throws Exception
+ {
+ String name = "org.apache.maven:maven-core:2.0.9";
+
+ File aJar1 = new File( _base1,
"org/apache/maven/maven-core/2.0.9/maven-core-2.0.9.jar");
+ File aJar2 = new File( _base2,
"org/apache/maven/maven-core/2.0.9/maven-core-2.0.9.jar");
+
+ assertFalse( aJar1.exists() );
+ assertFalse( aJar2.exists() );
+
+ writeArtifact( name, af, ap, _rr2 );
+
+ assertFalse( aJar1.exists() );
+ assertTrue( aJar2.exists() );
+
+ List<Artifact> al = readArtifact( name, _rrs );
+
+ System.out.println(al);
+
+ File localRepo1Jar = new File( _lbase1,
"org/apache/maven/maven-core/2.0.9/maven-core-2.0.9.jar" );
+ File localRepo2Jar = new File( _lbase2,
"org/apache/maven/maven-core/2.0.9/maven-core-2.0.9.jar" );
+
+ assertFalse( localRepo1Jar.exists() );
+ assertFalse( localRepo2Jar.exists() );
+
+ al = readArtifact( name, _repos );
+
+ assertTrue( localRepo1Jar.exists() );
+ assertFalse( localRepo2Jar.exists() );
+ }
+
+ public void testWriteReadTimeStamp()
+ throws Exception
+ {
+ String name = "org.apache.maven:maven-core:2.0.9-20090204.232323-23";
+
+ File af = new File( _resourceBase, "maven-core-2.0.9.jar" );
+ File ap = new File( _resourceBase, "maven-core-2.0.9.pom" );
+
+ File aJar1 = new File( _base1,
"org/apache/maven/maven-core/2.0.9-SNAPSHOT/maven-core-2.0.9-20090204.232323-23.jar");
+ File aJar2 = new File( _base2,
"org/apache/maven/maven-core/2.0.9-SNAPSHOT/maven-core-2.0.9-20090204.232323-23.jar");
+
+ assertFalse( aJar1.exists() );
+ assertFalse( aJar2.exists() );
+
+ writeArtifact( name, af, ap, _rr2 );
+
+ assertFalse( aJar1.exists() );
+ assertTrue( aJar2.exists() );
+
+ List<Artifact> al = readArtifact( name, _rrs );
+
+ System.out.println(al);
+
+ File localRepo1Jar = new File( _lbase1,
"org/apache/maven/maven-core/2.0.9-SNAPSHOT/maven-core-2.0.9-20090204.232323-23.jar"
);
+ File localRepo2Jar = new File( _lbase2,
"org/apache/maven/maven-core/2.0.9-SNAPSHOT/maven-core-2.0.9-20090204.232323-23.jar"
);
+
+ assertFalse( localRepo1Jar.exists() );
+ assertFalse( localRepo2Jar.exists() );
+
+ al = readArtifact( name, _repos );
+
+ assertTrue( localRepo1Jar.exists() );
+ assertFalse( localRepo2Jar.exists() );
+ }
+
+ public void testWriteReadLocalTimeStamp()
+ throws Exception
+ {
+ String name = "org.apache.maven:maven-core:2.0.9-20090204.232323-23";
+// ArtifactBasicMetadata bmd = new ArtifactBasicMetadata( name );
+
+ File af = new File( _resourceBase, "maven-core-2.0.9.jar" );
+ File ap = new File( _resourceBase, "maven-core-2.0.9.pom" );
+
+ File aJar1 = new File( _lbase1,
"org/apache/maven/maven-core/2.0.9-SNAPSHOT/maven-core-2.0.9-20090204.232323-23.jar");
+ File aJar2 = new File( _lbase2,
"org/apache/maven/maven-core/2.0.9-SNAPSHOT/maven-core-2.0.9-20090204.232323-23.jar");
+
+ assertFalse( aJar1.exists() );
+ assertFalse( aJar2.exists() );
+
+ writeArtifact( name, af, ap, _lr2 );
+
+ assertFalse( aJar1.exists() );
+ assertTrue( aJar2.exists() );
+
+ List<Artifact> al = readArtifact( name, _repos );
+
+ System.out.println(al);
+
+ File localRepo1Jar = new File( _lbase1,
"org/apache/maven/maven-core/2.0.9-SNAPSHOT/maven-core-2.0.9-20090204.232323-23.jar"
);
+ File localRepo2Jar = new File( _lbase2,
"org/apache/maven/maven-core/2.0.9-SNAPSHOT/maven-core-2.0.9-20090204.232323-23.jar"
);
+
+ assertTrue( localRepo1Jar.exists() );
+ assertTrue( localRepo2Jar.exists() );
+ }
+
+ public void testWriteReadSnapshot()
+ throws Exception
+ {
+ String name = "org.apache.maven:maven-core:2.0.9-SNAPSHOT";
+
+ File af = new File( _resourceBase, "maven-core-2.0.9.jar" );
+ File ap = new File( _resourceBase, "maven-core-2.0.9.pom" );
+
+ File aJar1 = new File( _base1,
"org/apache/maven/maven-core/2.0.9-SNAPSHOT/maven-core-2.0.9-SNAPSHOT.jar");
+ File aJar2 = new File( _base2,
"org/apache/maven/maven-core/2.0.9-SNAPSHOT/maven-core-2.0.9-SNAPSHOT.jar");
+
+ assertFalse( aJar1.exists() );
+ assertFalse( aJar2.exists() );
+
+ writeArtifact( name, af, ap, _rr2 );
+
+ assertFalse( aJar1.exists() );
+ assertTrue( aJar2.exists() );
+
+ List<Artifact> al = readArtifact( name, _rrs );
+
+ System.out.println(al);
+
+ File localRepo1Jar = new File( _lbase1,
"org/apache/maven/maven-core/2.0.9-SNAPSHOT/maven-core-2.0.9-SNAPSHOT.jar" );
+ File localRepo2Jar = new File( _lbase2,
"org/apache/maven/maven-core/2.0.9-SNAPSHOT/maven-core-2.0.9-SNAPSHOT.jar" );
+
+ assertFalse( localRepo1Jar.exists() );
+ assertFalse( localRepo2Jar.exists() );
+
+ al = readArtifact( name, _repos );
+
+ assertTrue( localRepo1Jar.exists() );
+ assertFalse( localRepo2Jar.exists() );
+ }
+
+ public void testWriteReadSnapshotLocal()
+ throws Exception
+ {
+ String name = "org.apache.maven:maven-core:2.0.9-SNAPSHOT";
+
+ File af = new File( _resourceBase, "maven-core-2.0.9.jar" );
+ File ap = new File( _resourceBase, "maven-core-2.0.9.pom" );
+
+ File aJar1 = new File( _lbase1,
"org/apache/maven/maven-core/2.0.9-SNAPSHOT/maven-core-2.0.9-SNAPSHOT.jar");
+ File aJar2 = new File( _lbase2,
"org/apache/maven/maven-core/2.0.9-SNAPSHOT/maven-core-2.0.9-SNAPSHOT.jar");
+
+ assertFalse( aJar1.exists() );
+ assertFalse( aJar2.exists() );
+
+ writeArtifact( name, af, ap, _lr2 );
+
+ assertFalse( aJar1.exists() );
+ assertTrue( aJar2.exists() );
+
+ List<Artifact> al = readArtifact( name, _lrs );
+
+ assertTrue( aJar1.exists() );
+ assertTrue( aJar2.exists() );
+ }
+
+ public void testWriteTimestampReadSnapshotSingleRepo()
+ throws Exception
+ {
+ String nameTS1 =
"org.apache.maven:maven-core:2.0.9-20090204.232323-23";
+ String nameTS2 =
"org.apache.maven:maven-core:2.0.9-20090204.232324-24";
+ String nameSN = "org.apache.maven:maven-core:2.0.9-SNAPSHOT";
+
+ File af = new File( _resourceBase, "maven-core-2.0.9.jar" );
+ File ap = new File( _resourceBase, "maven-core-2.0.9.pom" );
+
+ writeArtifact( nameTS1, af, ap, _rr2 );
+ writeArtifact( nameTS2, af, ap, _rr2 );
+
+ List<Artifact> al = readArtifact( nameSN, _rrs );
+
+ System.out.println(al);
+
+ assertNotNull( al );
+
+ assertEquals( 1, al.size() );
+
+ Artifact aSN = al.get( 0 );
+
+ assertNotNull( aSN.getFile() );
+
+ assertTrue( aSN.getFile().exists() );
+
+ assertEquals( "2.0.9-20090204.232324-24", aSN.getVersion() );
+ }
+
+ public void testWriteTimestampReadSnapshotSingleRepoSN()
+ throws Exception
+ {
+ String nameTS1 =
"org.apache.maven:maven-core:2.0.9-20090204.232323-23";
+ String nameTS2 =
"org.apache.maven:maven-core:2.0.9-20090204.232324-24";
+ String nameSN = "org.apache.maven:maven-core:2.0.9-SNAPSHOT";
+
+ File af = new File( _resourceBase, "maven-core-2.0.9.jar" );
+ File ap = new File( _resourceBase, "maven-core-2.0.9.pom" );
+
+ writeArtifact( nameTS1, af, ap, _rr2 );
+ writeArtifact( nameTS2, af, ap, _rr2 );
+ writeArtifact( nameSN, af, ap, _rr2 );
+
+ List<ArtifactBasicMetadata> vl = readVersions( nameSN, _rrs );
+
+ System.out.println(vl);
+
+ assertNotNull( vl );
+
+ assertEquals( 1, vl.size() );
+
+ List<Artifact> al = readArtifact( nameSN, _rrs );
+
+ System.out.println(al);
+
+ assertNotNull( al );
+
+ assertEquals( 1, al.size() );
+
+ Artifact aSN = al.get( 0 );
+
+ assertNotNull( aSN.getFile() );
+
+ assertTrue( aSN.getFile().exists() );
+
+ assertEquals( "2.0.9-SNAPSHOT", aSN.getVersion() );
+ }
+
+ public void testWriteTimestampReadSnapshot2Repos()
+ throws Exception
+ {
+ String nameTS1 =
"org.apache.maven:maven-core:2.0.9-20090204.232323-23";
+ String nameTS2 =
"org.apache.maven:maven-core:2.0.9-20090204.232324-24";
+ String nameSN = "org.apache.maven:maven-core:2.0.9-SNAPSHOT";
+
+ File af = new File( _resourceBase, "maven-core-2.0.9.jar" );
+ File ap = new File( _resourceBase, "maven-core-2.0.9.pom" );
+
+ writeArtifact( nameTS1, af, ap, _rr2 );
+ writeArtifact( nameTS2, af, ap, _rr1 );
+
+ List<ArtifactBasicMetadata> vl = readVersions( nameSN, _rrs );
+
+ System.out.println(vl);
+
+ assertNotNull( vl );
+
+ assertEquals( 1, vl.size() );
+
+ List<Artifact> al = readArtifact( nameSN, _rrs );
+
+ System.out.println(al);
+
+ assertNotNull( al );
+
+ assertEquals( 1, al.size() );
+
+ Artifact aSN = al.get( 0 );
+
+ assertNotNull( aSN.getFile() );
+
+ assertTrue( aSN.getFile().exists() );
+
+ assertEquals( "2.0.9-20090204.232324-24", aSN.getVersion() );
+ }
+
+ public void testWriteTimestampReadSnapshot2ReposReversed()
+ throws Exception
+ {
+ String nameTS1 =
"org.apache.maven:maven-core:2.0.9-20090204.232323-23";
+ String nameTS2 =
"org.apache.maven:maven-core:2.0.9-20090204.232324-24";
+ String nameSN = "org.apache.maven:maven-core:2.0.9-SNAPSHOT";
+
+ File af = new File( _resourceBase, "maven-core-2.0.9.jar" );
+ File ap = new File( _resourceBase, "maven-core-2.0.9.pom" );
+
+ writeArtifact( nameTS1, af, ap, _rr1 );
+ writeArtifact( nameTS2, af, ap, _rr2 );
+
+ List<ArtifactBasicMetadata> vl = readVersions( nameSN, _rrs );
+
+ System.out.println(vl);
+
+ assertNotNull( vl );
+
+ assertEquals( 1, vl.size() );
+
+ List<Artifact> al = readArtifact( nameSN, _rrs );
+
+ System.out.println(al);
+
+ assertNotNull( al );
+
+ assertEquals( 1, al.size() );
+
+ Artifact aSN = al.get( 0 );
+
+ assertNotNull( aSN.getFile() );
+
+ assertTrue( aSN.getFile().exists() );
+
+ assertEquals( "2.0.9-20090204.232324-24", aSN.getVersion() );
+ }
+
+ public void testLatest()
+ throws Exception
+ {
+ String nameTS1 =
"org.apache.maven:maven-core:2.0.9-20090204.232323-23";
+ String nameTS2 =
"org.apache.maven:maven-core:2.0.9-20090204.232324-24";
+ String nameRL = "org.apache.maven:maven-core:2.0.8";
+ String nameLT = "org.apache.maven:maven-core:LATEST";
+
+ File af = new File( _resourceBase, "maven-core-2.0.9.jar" );
+ File ap = new File( _resourceBase, "maven-core-2.0.9.pom" );
+
+ writeArtifact( nameTS1, af, ap, _rr2 );
+ writeArtifact( nameTS2, af, ap, _rr1 );
+ writeArtifact( nameRL, af, ap, _rr2 );
+
+ List<Artifact> al = readArtifact( nameLT, _rrs );
+
+ System.out.println(al);
+
+ assertNotNull( al );
+
+ assertEquals( 1, al.size() );
+
+ Artifact aSN = al.get( 0 );
+
+ assertNotNull( aSN.getFile() );
+
+ assertTrue( aSN.getFile().exists() );
+
+ assertEquals( "2.0.9-20090204.232324-24", aSN.getVersion() );
+ }
+
+ public void testLatestLocal()
+ throws Exception
+ {
+ String nameTS1 =
"org.apache.maven:maven-core:2.0.9-20090204.232323-23";
+ String nameTS2 =
"org.apache.maven:maven-core:2.0.9-20090204.232324-24";
+ String nameRL = "org.apache.maven:maven-core:2.0.8";
+ String nameLT = "org.apache.maven:maven-core:LATEST";
+
+ File af = new File( _resourceBase, "maven-core-2.0.9.jar" );
+ File ap = new File( _resourceBase, "maven-core-2.0.9.pom" );
+
+ writeArtifact( nameTS1, af, ap, _lr2 );
+ writeArtifact( nameTS2, af, ap, _lr1 );
+ writeArtifact( nameRL, af, ap, _lr2 );
+
+ List<Artifact> al = readArtifact( nameLT, _lrs );
+
+ System.out.println(al);
+
+ assertNotNull( al );
+
+ assertEquals( 1, al.size() );
+
+ Artifact aSN = al.get( 0 );
+
+ assertNotNull( aSN.getFile() );
+
+ assertTrue( aSN.getFile().exists() );
+
+ assertEquals( "2.0.9-20090204.232324-24", aSN.getVersion() );
+ }
+
+ public void testRelease()
+ throws Exception
+ {
+ String nameTS1 =
"org.apache.maven:maven-core:2.0.9-20090204.232323-23";
+ String nameTS2 =
"org.apache.maven:maven-core:2.0.9-20090204.232324-24";
+ String nameRL = "org.apache.maven:maven-core:2.0.8";
+ String name = "org.apache.maven:maven-core:RELEASE";
+
+ File af = new File( _resourceBase, "maven-core-2.0.9.jar" );
+ File ap = new File( _resourceBase, "maven-core-2.0.9.pom" );
+
+ writeArtifact( nameTS1, af, ap, _rr2 );
+ writeArtifact( nameTS2, af, ap, _rr1 );
+ writeArtifact( nameRL, af, ap, _rr2 );
+
+ List<Artifact> al = readArtifact( name, _rrs );
+
+ System.out.println(al);
+
+ assertNotNull( al );
+
+ assertEquals( 1, al.size() );
+
+ Artifact aSN = al.get( 0 );
+
+ assertNotNull( aSN.getFile() );
+
+ assertTrue( aSN.getFile().exists() );
+
+ assertEquals( "2.0.8", aSN.getVersion() );
+ }
+
+ public void testReleaseLocal()
+ throws Exception
+ {
+ String nameTS1 =
"org.apache.maven:maven-core:2.0.9-20090204.232323-23";
+ String nameTS2 =
"org.apache.maven:maven-core:2.0.9-20090204.232324-24";
+ String nameRL = "org.apache.maven:maven-core:2.0.8";
+ String name = "org.apache.maven:maven-core:RELEASE";
+
+ File af = new File( _resourceBase, "maven-core-2.0.9.jar" );
+ File ap = new File( _resourceBase, "maven-core-2.0.9.pom" );
+
+ writeArtifact( nameTS1, af, ap, _lr2 );
+ writeArtifact( nameTS2, af, ap, _lr1 );
+ writeArtifact( nameRL, af, ap, _lr2 );
+
+ List<Artifact> al = readArtifact( name, _lrs );
+
+ System.out.println(al);
+
+ assertNotNull( al );
+
+ assertEquals( 1, al.size() );
+
+ Artifact aSN = al.get( 0 );
+
+ assertNotNull( aSN.getFile() );
+
+ assertTrue( aSN.getFile().exists() );
+
+ assertEquals( "2.0.8", aSN.getVersion() );
+ }
+}
Propchange:
maven/mercury/trunk/mercury-it/src/test/java/org/apache/maven/mercury/repository/tests/AbstractRepositoryTest.java
------------------------------------------------------------------------------
svn:eol-style = native
Propchange:
maven/mercury/trunk/mercury-it/src/test/java/org/apache/maven/mercury/repository/tests/AbstractRepositoryTest.java
------------------------------------------------------------------------------
svn:keywords = Author Date Id Revision
Modified: maven/mercury/trunk/pom.xml
URL:
http://svn.apache.org/viewvc/maven/mercury/trunk/pom.xml?rev=741799&r1=741798&r2=741799&view=diff
==============================================================================
--- maven/mercury/trunk/pom.xml (original)
+++ maven/mercury/trunk/pom.xml Sat Feb 7 00:29:09 2009
@@ -76,6 +76,8 @@
<plexus.lang.version>1.1</plexus.lang.version>
<plexus.component.metadata.version>1.0-beta-3.0.1</plexus.component.metadata.version>
+ <emma4it.plugin.version>1.0</emma4it.plugin.version>
+
<commons.digester.version>1.8</commons.digester.version>
<commons.cli.version>1.1</commons.cli.version>