123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283 |
- package org.apache.archiva.admin.repository.group;
- /*
- * 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.archiva.admin.model.RepositoryAdminException;
- import org.apache.archiva.admin.model.beans.ManagedRepository;
- import org.apache.archiva.admin.model.beans.RepositoryGroup;
- import org.apache.archiva.admin.model.group.RepositoryGroupAdmin;
- import org.apache.archiva.admin.repository.AbstractRepositoryAdminTest;
- import org.apache.archiva.metadata.model.facets.AuditEvent;
- import org.junit.Test;
-
- import javax.inject.Inject;
- import java.io.File;
- import java.util.Arrays;
-
- /**
- * @author Olivier Lamy
- */
- public class RepositoryGroupAdminTest
- extends AbstractRepositoryAdminTest
- {
- @Inject
- RepositoryGroupAdmin repositoryGroupAdmin;
-
- @Test
- public void addAndDeleteGroup()
- throws Exception
- {
- try
- {
- ManagedRepository managedRepositoryOne =
- getTestManagedRepository( "test-new-one", APPSERVER_BASE_PATH + File.separator + "test-new-one" );
-
- ManagedRepository managedRepositoryTwo =
- getTestManagedRepository( "test-new-two", APPSERVER_BASE_PATH + File.separator + "test-new-two" );
-
- managedRepositoryAdmin.addManagedRepository( managedRepositoryOne, false, getFakeAuditInformation() );
-
- managedRepositoryAdmin.addManagedRepository( managedRepositoryTwo, false, getFakeAuditInformation() );
-
- RepositoryGroup repositoryGroup =
- new RepositoryGroup( "repo-group-one", Arrays.asList( "test-new-one", "test-new-two" ) );
-
- mockAuditListener.clearEvents();
-
- repositoryGroupAdmin.addRepositoryGroup( repositoryGroup, getFakeAuditInformation() );
-
- assertEquals( 1, repositoryGroupAdmin.getRepositoriesGroups().size() );
- assertEquals( "repo-group-one", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getId() );
- assertEquals( 2, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories().size() );
- assertEquals( Arrays.asList( "test-new-one", "test-new-two" ),
- repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories() );
-
- // verify if default values were saved
- assertEquals(30, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getMergedIndexTtl() );
- assertEquals("/.indexer", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getMergedIndexPath() );
-
- repositoryGroupAdmin.deleteRepositoryGroup( "repo-group-one", getFakeAuditInformation() );
-
- assertEquals( 0, repositoryGroupAdmin.getRepositoriesGroups().size() );
-
- assertEquals( 2, mockAuditListener.getAuditEvents().size() );
-
- assertEquals( AuditEvent.ADD_REPO_GROUP, mockAuditListener.getAuditEvents().get( 0 ).getAction() );
- assertEquals( AuditEvent.DELETE_REPO_GROUP, mockAuditListener.getAuditEvents().get( 1 ).getAction() );
- }
- finally
- {
- mockAuditListener.clearEvents();
- managedRepositoryAdmin.deleteManagedRepository( "test-new-one", getFakeAuditInformation(), true );
- managedRepositoryAdmin.deleteManagedRepository( "test-new-two", getFakeAuditInformation(), true );
- }
- }
-
- @Test
- public void addAndUpdateAndDeleteGroup()
- throws Exception
- {
- try
- {
- ManagedRepository managedRepositoryOne =
- getTestManagedRepository( "test-new-one", APPSERVER_BASE_PATH + File.separator + "test-new-one" );
-
- ManagedRepository managedRepositoryTwo =
- getTestManagedRepository( "test-new-two", APPSERVER_BASE_PATH + File.separator + "test-new-two" );
-
- managedRepositoryAdmin.addManagedRepository( managedRepositoryOne, false, getFakeAuditInformation() );
-
- managedRepositoryAdmin.addManagedRepository( managedRepositoryTwo, false, getFakeAuditInformation() );
-
- RepositoryGroup repositoryGroup = new RepositoryGroup( "repo-group-one", Arrays.asList( "test-new-one" ) )
- .mergedIndexTtl( 20 ).mergedIndexPath( "/.nonDefaultPath" );
-
- mockAuditListener.clearEvents();
-
- repositoryGroupAdmin.addRepositoryGroup( repositoryGroup, getFakeAuditInformation() );
-
- assertEquals( 1, repositoryGroupAdmin.getRepositoriesGroups().size() );
- assertEquals( "repo-group-one", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getId() );
- assertEquals( 1, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories().size() );
- assertEquals( Arrays.asList( "test-new-one" ),
- repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories() );
- assertEquals( 20, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getMergedIndexTtl() );
- assertEquals( "/.nonDefaultPath", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getMergedIndexPath() );
-
- repositoryGroup = repositoryGroupAdmin.getRepositoryGroup( "repo-group-one" );
- assertNotNull( repositoryGroup );
-
- repositoryGroup.addRepository( managedRepositoryTwo.getId() );
-
- repositoryGroupAdmin.updateRepositoryGroup( repositoryGroup, getFakeAuditInformation() );
-
- assertEquals( 1, repositoryGroupAdmin.getRepositoriesGroups().size() );
- assertEquals( "repo-group-one", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getId() );
- assertEquals( 2, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories().size() );
- assertEquals( Arrays.asList( "test-new-one", "test-new-two" ),
- repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories() );
-
- repositoryGroupAdmin.deleteRepositoryGroup( "repo-group-one", getFakeAuditInformation() );
-
- assertEquals( 0, repositoryGroupAdmin.getRepositoriesGroups().size() );
-
- assertEquals( 3, mockAuditListener.getAuditEvents().size() );
-
- assertEquals( AuditEvent.ADD_REPO_GROUP, mockAuditListener.getAuditEvents().get( 0 ).getAction() );
- assertEquals( AuditEvent.MODIFY_REPO_GROUP, mockAuditListener.getAuditEvents().get( 1 ).getAction() );
- assertEquals( AuditEvent.DELETE_REPO_GROUP, mockAuditListener.getAuditEvents().get( 2 ).getAction() );
- }
- finally
- {
- mockAuditListener.clearEvents();
- managedRepositoryAdmin.deleteManagedRepository( "test-new-one", getFakeAuditInformation(), true );
- managedRepositoryAdmin.deleteManagedRepository( "test-new-two", getFakeAuditInformation(), true );
- }
- }
-
- @Test
- public void addAndDeleteGroupWithRemovedManagedRepo()
- throws Exception
- {
- try
- {
- ManagedRepository managedRepositoryOne =
- getTestManagedRepository( "test-new-one", APPSERVER_BASE_PATH + File.separator + "test-new-one" );
-
- ManagedRepository managedRepositoryTwo =
- getTestManagedRepository( "test-new-two", APPSERVER_BASE_PATH + File.separator + "test-new-two" );
-
- managedRepositoryAdmin.addManagedRepository( managedRepositoryOne, false, getFakeAuditInformation() );
-
- managedRepositoryAdmin.addManagedRepository( managedRepositoryTwo, false, getFakeAuditInformation() );
-
- RepositoryGroup repositoryGroup =
- new RepositoryGroup( "repo-group-one", Arrays.asList( "test-new-one", "test-new-two" ) );
-
- mockAuditListener.clearEvents();
-
- repositoryGroupAdmin.addRepositoryGroup( repositoryGroup, getFakeAuditInformation() );
-
- assertEquals( 1, repositoryGroupAdmin.getRepositoriesGroups().size() );
- assertEquals( "repo-group-one", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getId() );
- assertEquals( 2, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories().size() );
- assertEquals( Arrays.asList( "test-new-one", "test-new-two" ),
- repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories() );
-
- // deleting a managed repo to validate repogroup correctly updated !
- managedRepositoryAdmin.deleteManagedRepository( "test-new-one", getFakeAuditInformation(), true );
-
- assertEquals( 1, repositoryGroupAdmin.getRepositoriesGroups().size() );
- assertEquals( "repo-group-one", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getId() );
- assertEquals( 1, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories().size() );
- assertEquals( Arrays.asList( "test-new-two" ),
- repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories() );
-
- repositoryGroupAdmin.deleteRepositoryGroup( "repo-group-one", getFakeAuditInformation() );
-
- assertEquals( 0, repositoryGroupAdmin.getRepositoriesGroups().size() );
-
- assertEquals( 3, mockAuditListener.getAuditEvents().size() );
-
- assertEquals( AuditEvent.ADD_REPO_GROUP, mockAuditListener.getAuditEvents().get( 0 ).getAction() );
- assertEquals( AuditEvent.DELETE_MANAGED_REPO, mockAuditListener.getAuditEvents().get( 1 ).getAction() );
- assertEquals( AuditEvent.DELETE_REPO_GROUP, mockAuditListener.getAuditEvents().get( 2 ).getAction() );
- }
- finally
- {
- mockAuditListener.clearEvents();
-
- managedRepositoryAdmin.deleteManagedRepository( "test-new-two", getFakeAuditInformation(), true );
- }
- }
-
- @Test( expected = RepositoryAdminException.class )
- public void testAddGroupWithInvalidMergedIndexTtl() throws Exception {
- try {
- ManagedRepository managedRepositoryOne =
- getTestManagedRepository( "test-new-one", APPSERVER_BASE_PATH + File.separator + "test-new-one" );
-
- ManagedRepository managedRepositoryTwo =
- getTestManagedRepository( "test-new-two", APPSERVER_BASE_PATH + File.separator + "test-new-two" );
-
- managedRepositoryAdmin.addManagedRepository( managedRepositoryOne, false, getFakeAuditInformation() );
-
- managedRepositoryAdmin.addManagedRepository( managedRepositoryTwo, false, getFakeAuditInformation() );
-
- RepositoryGroup repositoryGroup =
- new RepositoryGroup( "repo-group-one", Arrays.asList( "test-new-one", "test-new-two" ) )
- .mergedIndexTtl( -1 );
-
- mockAuditListener.clearEvents();
-
- repositoryGroupAdmin.addRepositoryGroup( repositoryGroup, getFakeAuditInformation() );
- }
- finally
- {
- mockAuditListener.clearEvents();
- managedRepositoryAdmin.deleteManagedRepository( "test-new-one", getFakeAuditInformation(), true );
- managedRepositoryAdmin.deleteManagedRepository( "test-new-two", getFakeAuditInformation(), true );
- }
- }
-
- @Test( expected = RepositoryAdminException.class )
- public void testAddAndUpdateGroupWithInvalidMergedIndexTtl() throws Exception {
- try {
- ManagedRepository managedRepositoryOne =
- getTestManagedRepository( "test-new-one", APPSERVER_BASE_PATH + File.separator + "test-new-one" );
-
- ManagedRepository managedRepositoryTwo =
- getTestManagedRepository( "test-new-two", APPSERVER_BASE_PATH + File.separator + "test-new-two" );
-
- managedRepositoryAdmin.addManagedRepository( managedRepositoryOne, false, getFakeAuditInformation() );
-
- managedRepositoryAdmin.addManagedRepository( managedRepositoryTwo, false, getFakeAuditInformation() );
-
- RepositoryGroup repositoryGroup =
- new RepositoryGroup( "repo-group-one", Arrays.asList( "test-new-one", "test-new-two" ) );
-
- mockAuditListener.clearEvents();
-
- repositoryGroupAdmin.addRepositoryGroup( repositoryGroup, getFakeAuditInformation() );
-
- assertEquals( 1, repositoryGroupAdmin.getRepositoriesGroups().size() );
- assertEquals( "repo-group-one", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getId() );
- assertEquals( 2, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories().size() );
- assertEquals( Arrays.asList( "test-new-one", "test-new-two" ),
- repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories() );
-
- // verify if default values were saved
- assertEquals(30, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getMergedIndexTtl() );
- assertEquals("/.indexer", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getMergedIndexPath() );
-
- repositoryGroup = repositoryGroupAdmin.getRepositoryGroup( "repo-group-one" );
- assertNotNull( repositoryGroup );
-
- repositoryGroup.mergedIndexTtl( -1 );
-
- repositoryGroupAdmin.updateRepositoryGroup( repositoryGroup, getFakeAuditInformation() );
- }
- finally
- {
- mockAuditListener.clearEvents();
- managedRepositoryAdmin.deleteManagedRepository( "test-new-one", getFakeAuditInformation(), true );
- managedRepositoryAdmin.deleteManagedRepository( "test-new-two", getFakeAuditInformation(), true );
- }
- }
- }
|