Author: oching
Date: Thu Feb 5 09:00:31 2009
New Revision: 741051
URL: http://svn.apache.org/viewvc?rev=741051&view=rev
Log:
[MRM-1046]
o added test cases for SearchActionTest
Added:
archiva/trunk/archiva-modules/archiva-web/archiva-webapp/src/test/java/org/apache/maven/archiva/web/action/SearchActionTest.java
Modified:
archiva/trunk/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/SearchAction.java
Modified:
archiva/trunk/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/SearchAction.java
URL:
http://svn.apache.org/viewvc/archiva/trunk/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/SearchAction.java?rev=741051&r1=741050&r2=741051&view=diff
==============================================================================
---
archiva/trunk/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/SearchAction.java
(original)
+++
archiva/trunk/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/SearchAction.java
Thu Feb 5 09:00:31 2009
@@ -297,13 +297,18 @@
//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
- for (SearchResultHit resultHit : results.getHits())
- {
- final List<String> versions = dao.query(new
UniqueVersionConstraint(getObservableRepos(), resultHit.getGroupId(),
resultHit.getArtifactId()));
- if (versions != null && !versions.isEmpty())
+
+ // 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() ) );
+ if ( versions != null && !versions.isEmpty() )
{
- resultHit.setVersion(null);
- resultHit.setVersions(filterTimestampedSnapshots(versions));
+ resultHit.setVersion( null );
+ resultHit.setVersions( filterTimestampedSnapshots( versions )
);
}
}
@@ -602,4 +607,34 @@
{
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;
+ }
}
Added:
archiva/trunk/archiva-modules/archiva-web/archiva-webapp/src/test/java/org/apache/maven/archiva/web/action/SearchActionTest.java
URL:
http://svn.apache.org/viewvc/archiva/trunk/archiva-modules/archiva-web/archiva-webapp/src/test/java/org/apache/maven/archiva/web/action/SearchActionTest.java?rev=741051&view=auto
==============================================================================
---
archiva/trunk/archiva-modules/archiva-web/archiva-webapp/src/test/java/org/apache/maven/archiva/web/action/SearchActionTest.java
(added)
+++
archiva/trunk/archiva-modules/archiva-web/archiva-webapp/src/test/java/org/apache/maven/archiva/web/action/SearchActionTest.java
Thu Feb 5 09:00:31 2009
@@ -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
+ {
+
+ }
+
+}