mirror of https://github.com/apache/archiva.git
[MRM-1046]
o added test cases for SearchActionTest git-svn-id: https://svn.apache.org/repos/asf/archiva/trunk@741051 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
c9cdca72bb
commit
8cbe207627
|
@ -297,13 +297,18 @@ public class SearchAction
|
||||||
|
|
||||||
//Lets get the versions for the artifact we just found and display them
|
//Lets get the versions for the artifact we just found and display them
|
||||||
//Yes, this is in the lucene index but its more challenging to get them out when we are searching by project
|
//Yes, this is in the lucene index but its more challenging to get them out when we are searching by project
|
||||||
for (SearchResultHit resultHit : results.getHits())
|
|
||||||
|
// TODO: do we still need to do this? all hits are already filtered in the NexusRepositorySearch
|
||||||
|
// before being returned as search results
|
||||||
|
for ( SearchResultHit resultHit : results.getHits() )
|
||||||
{
|
{
|
||||||
final List<String> versions = dao.query(new UniqueVersionConstraint(getObservableRepos(), resultHit.getGroupId(), resultHit.getArtifactId()));
|
final List<String> versions =
|
||||||
if (versions != null && !versions.isEmpty())
|
dao.query( new UniqueVersionConstraint( getObservableRepos(), resultHit.getGroupId(),
|
||||||
|
resultHit.getArtifactId() ) );
|
||||||
|
if ( versions != null && !versions.isEmpty() )
|
||||||
{
|
{
|
||||||
resultHit.setVersion(null);
|
resultHit.setVersion( null );
|
||||||
resultHit.setVersions(filterTimestampedSnapshots(versions));
|
resultHit.setVersions( filterTimestampedSnapshots( versions ) );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -602,4 +607,34 @@ public class SearchAction
|
||||||
{
|
{
|
||||||
this.nexusSearch = nexusSearch;
|
this.nexusSearch = nexusSearch;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public ArchivaDAO getDao()
|
||||||
|
{
|
||||||
|
return dao;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setDao( ArchivaDAO dao )
|
||||||
|
{
|
||||||
|
this.dao = dao;
|
||||||
|
}
|
||||||
|
|
||||||
|
public UserRepositories getUserRepositories()
|
||||||
|
{
|
||||||
|
return userRepositories;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setUserRepositories( UserRepositories userRepositories )
|
||||||
|
{
|
||||||
|
this.userRepositories = userRepositories;
|
||||||
|
}
|
||||||
|
|
||||||
|
public ArchivaXworkUser getArchivaXworkUser()
|
||||||
|
{
|
||||||
|
return archivaXworkUser;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setArchivaXworkUser( ArchivaXworkUser archivaXworkUser )
|
||||||
|
{
|
||||||
|
this.archivaXworkUser = archivaXworkUser;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,219 @@
|
||||||
|
package org.apache.maven.archiva.web.action;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* 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 java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.apache.archiva.indexer.search.RepositorySearch;
|
||||||
|
import org.apache.archiva.indexer.util.SearchUtil;
|
||||||
|
import org.apache.maven.archiva.configuration.ArchivaConfiguration;
|
||||||
|
import org.apache.maven.archiva.database.ArchivaDAO;
|
||||||
|
import org.apache.maven.archiva.database.constraints.UniqueVersionConstraint;
|
||||||
|
import org.apache.maven.archiva.indexer.search.SearchResultHit;
|
||||||
|
import org.apache.maven.archiva.indexer.search.SearchResultLimits;
|
||||||
|
import org.apache.maven.archiva.indexer.search.SearchResults;
|
||||||
|
import org.apache.maven.archiva.security.ArchivaXworkUser;
|
||||||
|
import org.apache.maven.archiva.security.UserRepositories;
|
||||||
|
import org.codehaus.plexus.spring.PlexusInSpringTestCase;
|
||||||
|
import org.easymock.MockControl;
|
||||||
|
import org.easymock.classextension.MockClassControl;
|
||||||
|
|
||||||
|
import com.opensymphony.xwork2.Action;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public class SearchActionTest
|
||||||
|
extends PlexusInSpringTestCase
|
||||||
|
{
|
||||||
|
private SearchAction action;
|
||||||
|
|
||||||
|
private MockControl archivaConfigControl;
|
||||||
|
|
||||||
|
private ArchivaConfiguration archivaConfig;
|
||||||
|
|
||||||
|
private MockControl daoControl;
|
||||||
|
|
||||||
|
private ArchivaDAO dao;
|
||||||
|
|
||||||
|
private MockControl userReposControl;
|
||||||
|
|
||||||
|
private UserRepositories userRepos;
|
||||||
|
|
||||||
|
private MockControl archivaXworkUserControl;
|
||||||
|
|
||||||
|
private ArchivaXworkUser archivaXworkUser;
|
||||||
|
|
||||||
|
private MockControl searchControl;
|
||||||
|
|
||||||
|
private RepositorySearch search;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void setUp()
|
||||||
|
throws Exception
|
||||||
|
{
|
||||||
|
super.setUp();
|
||||||
|
|
||||||
|
action = new SearchAction();
|
||||||
|
|
||||||
|
archivaConfigControl = MockControl.createControl( ArchivaConfiguration.class );
|
||||||
|
|
||||||
|
archivaConfig = ( ArchivaConfiguration ) archivaConfigControl.getMock();
|
||||||
|
|
||||||
|
daoControl = MockControl.createControl( ArchivaDAO.class );
|
||||||
|
daoControl.setDefaultMatcher( MockControl.ALWAYS_MATCHER );
|
||||||
|
|
||||||
|
dao = ( ArchivaDAO ) daoControl.getMock();
|
||||||
|
|
||||||
|
userReposControl = MockControl.createControl( UserRepositories.class );
|
||||||
|
|
||||||
|
userRepos = ( UserRepositories ) userReposControl.getMock();
|
||||||
|
|
||||||
|
archivaXworkUserControl = MockClassControl.createControl( ArchivaXworkUser.class );
|
||||||
|
archivaXworkUserControl.setDefaultMatcher( MockControl.ALWAYS_MATCHER );
|
||||||
|
|
||||||
|
archivaXworkUser = ( ArchivaXworkUser ) archivaXworkUserControl.getMock();
|
||||||
|
|
||||||
|
searchControl = MockControl.createControl( RepositorySearch.class );
|
||||||
|
searchControl.setDefaultMatcher( MockControl.ALWAYS_MATCHER );
|
||||||
|
|
||||||
|
search = ( RepositorySearch ) searchControl.getMock();
|
||||||
|
|
||||||
|
action.setArchivaConfiguration( archivaConfig );
|
||||||
|
action.setArchivaXworkUser( archivaXworkUser );
|
||||||
|
action.setUserRepositories( userRepos );
|
||||||
|
action.setDao( dao );
|
||||||
|
action.setNexusSearch( search );
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void tearDown()
|
||||||
|
throws Exception
|
||||||
|
{
|
||||||
|
super.tearDown();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testQuickSearch()
|
||||||
|
throws Exception
|
||||||
|
{
|
||||||
|
action.setQ( "archiva" );
|
||||||
|
action.setCurrentPage( 0 );
|
||||||
|
action.setSearchResultsOnly( false );
|
||||||
|
action.setCompleteQueryString( "" );
|
||||||
|
|
||||||
|
List<String> selectedRepos = new ArrayList<String>();
|
||||||
|
selectedRepos.add( "internal" );
|
||||||
|
selectedRepos.add( "snapshots" );
|
||||||
|
|
||||||
|
SearchResultLimits limits = new SearchResultLimits( action.getCurrentPage() );
|
||||||
|
limits.setPageSize( 30 );
|
||||||
|
|
||||||
|
SearchResultHit hit = new SearchResultHit();
|
||||||
|
hit.setGroupId( "org.apache.archiva" );
|
||||||
|
hit.setArtifactId( "archiva-configuration" );
|
||||||
|
hit.setUrl( "url" );
|
||||||
|
hit.addVersion( "1.0" );
|
||||||
|
hit.addVersion( "1.1" );
|
||||||
|
|
||||||
|
SearchResults results = new SearchResults();
|
||||||
|
results.setLimits( limits );
|
||||||
|
results.setTotalHits( 1 );
|
||||||
|
results.addHit( SearchUtil.getHitId( "org.apache.archiva", "archiva-configuration" ), hit );
|
||||||
|
|
||||||
|
List<String> versions = new ArrayList<String>();
|
||||||
|
versions.add( "1.0" );
|
||||||
|
versions.add( "1.1" );
|
||||||
|
|
||||||
|
archivaXworkUserControl.expectAndReturn( archivaXworkUser.getActivePrincipal( new HashMap() ), "user", 3 );
|
||||||
|
|
||||||
|
userReposControl.expectAndReturn( userRepos.getObservableRepositoryIds( "user" ), selectedRepos, 2 );
|
||||||
|
|
||||||
|
searchControl.expectAndReturn( search.search( "user", selectedRepos, "archiva", limits, null ), results );
|
||||||
|
|
||||||
|
daoControl.expectAndReturn( dao.query( new UniqueVersionConstraint( selectedRepos, hit.getGroupId(), hit.getArtifactId() ) ), versions );
|
||||||
|
|
||||||
|
archivaXworkUserControl.replay();
|
||||||
|
userReposControl.replay();
|
||||||
|
searchControl.replay();
|
||||||
|
daoControl.replay();
|
||||||
|
|
||||||
|
String result = action.quickSearch();
|
||||||
|
|
||||||
|
assertEquals( Action.SUCCESS, result );
|
||||||
|
|
||||||
|
archivaXworkUserControl.verify();
|
||||||
|
userReposControl.verify();
|
||||||
|
searchControl.verify();
|
||||||
|
daoControl.verify();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testSearchWithinSearchResults()
|
||||||
|
throws Exception
|
||||||
|
{
|
||||||
|
// test filter of completeQueryString?
|
||||||
|
// test no need to filter completeQueryString?
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testAdvancedSearch()
|
||||||
|
throws Exception
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testSearchUserHasNoAccessToAnyRepository()
|
||||||
|
throws Exception
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testNoSearchHits()
|
||||||
|
throws Exception
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// test pagination or just totalPages?
|
||||||
|
public void testPagination()
|
||||||
|
throws Exception
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testFindArtifactWithOneHit()
|
||||||
|
throws Exception
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testFindArtifactWithMultipleHits()
|
||||||
|
throws Exception
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testFindArtifactNoChecksumSpecified()
|
||||||
|
throws Exception
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue