[MRM-1025] remove constraint that is no longer used

git-svn-id: https://svn.apache.org/repos/asf/archiva/branches/MRM-1025@889205 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Brett Porter 2009-12-10 11:41:18 +00:00
parent 9b2c646f75
commit 5e5764c8a0
3 changed files with 1 additions and 328 deletions

View File

@ -1,120 +0,0 @@
package org.apache.maven.archiva.database.constraints;
/*
* 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 org.apache.commons.lang.StringUtils;
import org.apache.maven.archiva.database.Constraint;
import org.apache.maven.archiva.model.ArchivaArtifactModel;
import java.util.List;
/**
* Obtain the list of version's for specific GroupId and ArtifactId.
*
* @version $Id$
*/
public class UniqueVersionConstraint
extends AbstractSimpleConstraint
implements Constraint
{
private StringBuffer sql = new StringBuffer();
/**
* Obtain the list of version's for specific GroupId and ArtifactId.
*
* @param selectedRepositoryIds the selected repository ids.
* @param groupId the selected groupId.
* @param artifactId the selected artifactId.
*/
public UniqueVersionConstraint( List<String> selectedRepositoryIds, String groupId, String artifactId )
{
if ( StringUtils.isBlank( groupId ) )
{
throw new IllegalArgumentException( "A blank groupId is not allowed." );
}
if ( StringUtils.isBlank( artifactId ) )
{
throw new IllegalArgumentException( "A blank artifactId is not allowed." );
}
appendSelect( sql );
sql.append( " WHERE " );
SqlBuilder.appendWhereSelectedRepositories( sql, "repositoryId", selectedRepositoryIds );
sql.append( " && " );
appendWhereSelectedGroupIdArtifactId( sql );
appendGroupBy( sql );
super.params = new Object[] { groupId, artifactId };
}
/**
* Obtain the list of version's for specific GroupId and ArtifactId.
*
* @param groupId the selected groupId.
* @param artifactId the selected artifactId.
*/
public UniqueVersionConstraint( String groupId, String artifactId )
{
if ( StringUtils.isBlank( groupId ) )
{
throw new IllegalArgumentException( "A blank groupId is not allowed." );
}
if ( StringUtils.isBlank( artifactId ) )
{
throw new IllegalArgumentException( "A blank artifactId is not allowed." );
}
appendSelect( sql );
sql.append( " WHERE " );
appendWhereSelectedGroupIdArtifactId( sql );
appendGroupBy( sql );
super.params = new Object[] { groupId, artifactId };
}
@SuppressWarnings("unchecked")
public Class getResultClass()
{
return String.class;
}
public String getSelectSql()
{
return sql.toString();
}
private void appendGroupBy( StringBuffer buf )
{
buf.append( " GROUP BY version ORDER BY version ASCENDING" );
}
private void appendSelect( StringBuffer buf )
{
buf.append( "SELECT version FROM " ).append( ArchivaArtifactModel.class.getName() );
}
private void appendWhereSelectedGroupIdArtifactId( StringBuffer buf )
{
buf.append( " groupId == selectedGroupId && artifactId == selectedArtifactId" );
buf.append( " PARAMETERS String selectedGroupId, String selectedArtifactId" );
}
}

View File

@ -1,193 +0,0 @@
package org.apache.maven.archiva.database.constraints;
/*
* 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 org.apache.commons.lang.StringUtils;
import org.apache.maven.archiva.database.AbstractArchivaDatabaseTestCase;
import org.apache.maven.archiva.database.ArchivaDAO;
import org.apache.maven.archiva.database.ArtifactDAO;
import org.apache.maven.archiva.database.SimpleConstraint;
import org.apache.maven.archiva.model.ArchivaArtifact;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Date;
import java.util.List;
/**
* UniqueVersionConstraintTest
*
* @version $Id$
*/
public class UniqueVersionConstraintTest
extends AbstractArchivaDatabaseTestCase
{
private ArtifactDAO artifactDao;
public void testConstraintGroupIdArtifactIdCommonsLang()
throws Exception
{
setupArtifacts();
assertConstraint( new String[] { "2.0", "2.1" }, new UniqueVersionConstraint( "commons-lang", "commons-lang" ) );
}
public void testConstraintGroupIdArtifactIdInvalid()
throws Exception
{
setupArtifacts();
assertConstraint( new String[] {}, new UniqueVersionConstraint( "org.apache", "invalid" ) );
assertConstraint( new String[] {}, new UniqueVersionConstraint( "org.apache.test", "invalid" ) );
assertConstraint( new String[] {}, new UniqueVersionConstraint( "invalid", "test-two" ) );
}
public void testConstraintGroupIdArtifactIdMavenSharedTestTwo()
throws Exception
{
setupArtifacts();
assertConstraint( new String[] { "2.0", "2.1-SNAPSHOT", "2.1.1", "2.1-alpha-1" },
new UniqueVersionConstraint( "org.apache.maven.shared", "test-two" ) );
}
public void testConstraintGroupIdArtifactIdMavenSharedTestTwoCentralOnly()
throws Exception
{
setupArtifacts();
List<String> observableRepositories = new ArrayList<String>();
observableRepositories.add( "central" );
assertConstraint( new String[] { "2.0", "2.1.1", "2.1-alpha-1" },
new UniqueVersionConstraint( observableRepositories, "org.apache.maven.shared", "test-two" ) );
}
public void testConstraintGroupIdArtifactIdMavenSharedTestTwoSnapshotsOnly()
throws Exception
{
setupArtifacts();
List<String> observableRepositories = new ArrayList<String>();
observableRepositories.add( "snapshots" );
assertConstraint( new String[] { "2.1-SNAPSHOT" },
new UniqueVersionConstraint( observableRepositories, "org.apache.maven.shared", "test-two" ) );
}
public void testConstraintGroupIdArtifactIdMavenTestOne()
throws Exception
{
setupArtifacts();
assertConstraint( new String[] { "1.2" }, new UniqueVersionConstraint( "org.apache.maven.test", "test-one" ) );
}
public void testConstraintGroupIdArtifactIdModelloLong()
throws Exception
{
setupArtifacts();
assertConstraint( new String[] { "3.0" }, new UniqueVersionConstraint( "org.codehaus.modello", "modellong" ) );
}
@SuppressWarnings("unchecked")
private void assertConstraint( String[] versions, SimpleConstraint constraint )
{
String prefix = "Unique Versions: ";
List<String> results = (List<String>) dao.query( constraint );
assertNotNull( prefix + "Not Null", results );
assertEquals( prefix + "Results.size", versions.length, results.size() );
List<String> expectedVersions = Arrays.asList( versions );
for ( String actualVersion : results )
{
assertTrue( prefix + "version result should not be blank.", StringUtils.isNotBlank( actualVersion ) );
assertTrue( prefix + "version result <" + actualVersion + "> exists in expected versions.",
expectedVersions.contains( actualVersion ) );
}
}
private ArchivaArtifact createArtifact( String repoId, String groupId, String artifactId, String version )
{
ArchivaArtifact artifact = artifactDao.createArtifact( groupId, artifactId, version, "", "jar", "testrepo" );
artifact.getModel().setLastModified( new Date() ); // mandatory field.
artifact.getModel().setRepositoryId( repoId );
return artifact;
}
private void setupArtifacts()
throws Exception
{
ArchivaArtifact artifact;
// Setup artifacts in fresh DB.
artifact = createArtifact( "central", "commons-lang", "commons-lang", "2.0" );
artifactDao.saveArtifact( artifact );
artifact = createArtifact( "central", "commons-lang", "commons-lang", "2.1" );
artifactDao.saveArtifact( artifact );
artifact = createArtifact( "central", "org.apache.maven.test", "test-one", "1.2" );
artifactDao.saveArtifact( artifact );
artifact = createArtifact( "central", "org.apache.maven.test.foo", "test-two", "1.0" );
artifactDao.saveArtifact( artifact );
artifact = createArtifact( "central", "org.apache.maven.shared", "test-two", "2.0" );
artifactDao.saveArtifact( artifact );
artifact = createArtifact( "central", "org.apache.maven.shared", "test-two", "2.1.1" );
artifactDao.saveArtifact( artifact );
artifact = createArtifact( "central", "org.apache.maven.shared", "test-two", "2.1-alpha-1" );
artifactDao.saveArtifact( artifact );
artifact = createArtifact( "central", "org.apache.maven.shared", "test-bar", "2.1" );
artifactDao.saveArtifact( artifact );
artifact = createArtifact( "central", "org.codehaus.modello", "modellong", "3.0" );
artifactDao.saveArtifact( artifact );
// Snapshots repository artifacts
artifact = createArtifact( "snapshots", "org.apache.maven.shared", "test-two", "2.1-SNAPSHOT" );
artifactDao.saveArtifact( artifact );
artifact = createArtifact( "snapshots", "org.codehaus.modello", "test-three", "1.0-SNAPSHOT" );
artifactDao.saveArtifact( artifact );
artifact = createArtifact( "snapshots", "org.codehaus.mojo", "testable-maven-plugin", "2.1-SNAPSHOT" );
artifactDao.saveArtifact( artifact );
artifact = createArtifact( "snapshots", "org.apache.archiva", "testable", "1.1-alpha-1-20070822.033400-43" );
artifactDao.saveArtifact( artifact );
}
protected void setUp()
throws Exception
{
super.setUp();
ArchivaDAO dao = (ArchivaDAO) lookup( ArchivaDAO.ROLE, "jdo" );
artifactDao = dao.getArtifactDAO();
}
}

View File

@ -21,13 +21,11 @@ package org.apache.maven.archiva.web.action.admin.repositories;
import java.util.List; import java.util.List;
import org.apache.maven.archiva.configuration.ArchivaConfiguration;
import org.apache.maven.archiva.database.ArchivaDAO; import org.apache.maven.archiva.database.ArchivaDAO;
import org.apache.maven.archiva.database.ArtifactDAO; import org.apache.maven.archiva.database.ArtifactDAO;
import org.apache.maven.archiva.database.RepositoryProblemDAO; import org.apache.maven.archiva.database.RepositoryProblemDAO;
import org.apache.maven.archiva.database.SimpleConstraint; import org.apache.maven.archiva.database.SimpleConstraint;
import org.apache.maven.archiva.database.constraints.UniqueFieldConstraint; import org.apache.maven.archiva.database.constraints.UniqueFieldConstraint;
import org.apache.maven.archiva.database.constraints.UniqueVersionConstraint;
/** /**
* Stub class for Archiva DAO to avoid having to set up a database for tests. * Stub class for Archiva DAO to avoid having to set up a database for tests.
@ -37,23 +35,16 @@ import org.apache.maven.archiva.database.constraints.UniqueVersionConstraint;
public class ArchivaDAOStub public class ArchivaDAOStub
implements ArchivaDAO implements ArchivaDAO
{ {
private ArchivaConfiguration configuration;
private ArtifactDAO artifactDao; private ArtifactDAO artifactDao;
private List<String> versions;
private List<String> repositoryIds; private List<String> repositoryIds;
private RepositoryProblemDAO repositoryProblemDAO; private RepositoryProblemDAO repositoryProblemDAO;
public List<?> query( SimpleConstraint constraint ) public List<?> query( SimpleConstraint constraint )
{ {
if ( constraint instanceof UniqueVersionConstraint ) if ( constraint instanceof UniqueFieldConstraint )
{
return versions;
}
else if ( constraint instanceof UniqueFieldConstraint )
{ {
return repositoryIds; return repositoryIds;
} }
@ -75,11 +66,6 @@ public class ArchivaDAOStub
this.artifactDao = artifactDao; this.artifactDao = artifactDao;
} }
public void setVersions( List<String> versions )
{
this.versions = versions;
}
public void setRepositoryIds( List<String> repositoryIds ) public void setRepositoryIds( List<String> repositoryIds )
{ {
this.repositoryIds = repositoryIds; this.repositoryIds = repositoryIds;