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
+    {
+    
+    }
+    
+}


Reply via email to