You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

RepositoryGroupAdminTest.java 14KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283
  1. package org.apache.archiva.admin.repository.group;
  2. /*
  3. * Licensed to the Apache Software Foundation (ASF) under one
  4. * or more contributor license agreements. See the NOTICE file
  5. * distributed with this work for additional information
  6. * regarding copyright ownership. The ASF licenses this file
  7. * to you under the Apache License, Version 2.0 (the
  8. * "License"); you may not use this file except in compliance
  9. * with the License. You may obtain a copy of the License at
  10. *
  11. * http://www.apache.org/licenses/LICENSE-2.0
  12. *
  13. * Unless required by applicable law or agreed to in writing,
  14. * software distributed under the License is distributed on an
  15. * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
  16. * KIND, either express or implied. See the License for the
  17. * specific language governing permissions and limitations
  18. * under the License.
  19. */
  20. import org.apache.archiva.admin.model.RepositoryAdminException;
  21. import org.apache.archiva.admin.model.beans.ManagedRepository;
  22. import org.apache.archiva.admin.model.beans.RepositoryGroup;
  23. import org.apache.archiva.admin.model.group.RepositoryGroupAdmin;
  24. import org.apache.archiva.admin.repository.AbstractRepositoryAdminTest;
  25. import org.apache.archiva.metadata.model.facets.AuditEvent;
  26. import org.junit.Test;
  27. import javax.inject.Inject;
  28. import java.io.File;
  29. import java.util.Arrays;
  30. /**
  31. * @author Olivier Lamy
  32. */
  33. public class RepositoryGroupAdminTest
  34. extends AbstractRepositoryAdminTest
  35. {
  36. @Inject
  37. RepositoryGroupAdmin repositoryGroupAdmin;
  38. @Test
  39. public void addAndDeleteGroup()
  40. throws Exception
  41. {
  42. try
  43. {
  44. ManagedRepository managedRepositoryOne =
  45. getTestManagedRepository( "test-new-one", APPSERVER_BASE_PATH + File.separator + "test-new-one" );
  46. ManagedRepository managedRepositoryTwo =
  47. getTestManagedRepository( "test-new-two", APPSERVER_BASE_PATH + File.separator + "test-new-two" );
  48. managedRepositoryAdmin.addManagedRepository( managedRepositoryOne, false, getFakeAuditInformation() );
  49. managedRepositoryAdmin.addManagedRepository( managedRepositoryTwo, false, getFakeAuditInformation() );
  50. RepositoryGroup repositoryGroup =
  51. new RepositoryGroup( "repo-group-one", Arrays.asList( "test-new-one", "test-new-two" ) );
  52. mockAuditListener.clearEvents();
  53. repositoryGroupAdmin.addRepositoryGroup( repositoryGroup, getFakeAuditInformation() );
  54. assertEquals( 1, repositoryGroupAdmin.getRepositoriesGroups().size() );
  55. assertEquals( "repo-group-one", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getId() );
  56. assertEquals( 2, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories().size() );
  57. assertEquals( Arrays.asList( "test-new-one", "test-new-two" ),
  58. repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories() );
  59. // verify if default values were saved
  60. assertEquals(30, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getMergedIndexTtl() );
  61. assertEquals("/.indexer", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getMergedIndexPath() );
  62. repositoryGroupAdmin.deleteRepositoryGroup( "repo-group-one", getFakeAuditInformation() );
  63. assertEquals( 0, repositoryGroupAdmin.getRepositoriesGroups().size() );
  64. assertEquals( 2, mockAuditListener.getAuditEvents().size() );
  65. assertEquals( AuditEvent.ADD_REPO_GROUP, mockAuditListener.getAuditEvents().get( 0 ).getAction() );
  66. assertEquals( AuditEvent.DELETE_REPO_GROUP, mockAuditListener.getAuditEvents().get( 1 ).getAction() );
  67. }
  68. finally
  69. {
  70. mockAuditListener.clearEvents();
  71. managedRepositoryAdmin.deleteManagedRepository( "test-new-one", getFakeAuditInformation(), true );
  72. managedRepositoryAdmin.deleteManagedRepository( "test-new-two", getFakeAuditInformation(), true );
  73. }
  74. }
  75. @Test
  76. public void addAndUpdateAndDeleteGroup()
  77. throws Exception
  78. {
  79. try
  80. {
  81. ManagedRepository managedRepositoryOne =
  82. getTestManagedRepository( "test-new-one", APPSERVER_BASE_PATH + File.separator + "test-new-one" );
  83. ManagedRepository managedRepositoryTwo =
  84. getTestManagedRepository( "test-new-two", APPSERVER_BASE_PATH + File.separator + "test-new-two" );
  85. managedRepositoryAdmin.addManagedRepository( managedRepositoryOne, false, getFakeAuditInformation() );
  86. managedRepositoryAdmin.addManagedRepository( managedRepositoryTwo, false, getFakeAuditInformation() );
  87. RepositoryGroup repositoryGroup = new RepositoryGroup( "repo-group-one", Arrays.asList( "test-new-one" ) )
  88. .mergedIndexTtl( 20 ).mergedIndexPath( "/.nonDefaultPath" );
  89. mockAuditListener.clearEvents();
  90. repositoryGroupAdmin.addRepositoryGroup( repositoryGroup, getFakeAuditInformation() );
  91. assertEquals( 1, repositoryGroupAdmin.getRepositoriesGroups().size() );
  92. assertEquals( "repo-group-one", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getId() );
  93. assertEquals( 1, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories().size() );
  94. assertEquals( Arrays.asList( "test-new-one" ),
  95. repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories() );
  96. assertEquals( 20, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getMergedIndexTtl() );
  97. assertEquals( "/.nonDefaultPath", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getMergedIndexPath() );
  98. repositoryGroup = repositoryGroupAdmin.getRepositoryGroup( "repo-group-one" );
  99. assertNotNull( repositoryGroup );
  100. repositoryGroup.addRepository( managedRepositoryTwo.getId() );
  101. repositoryGroupAdmin.updateRepositoryGroup( repositoryGroup, getFakeAuditInformation() );
  102. assertEquals( 1, repositoryGroupAdmin.getRepositoriesGroups().size() );
  103. assertEquals( "repo-group-one", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getId() );
  104. assertEquals( 2, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories().size() );
  105. assertEquals( Arrays.asList( "test-new-one", "test-new-two" ),
  106. repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories() );
  107. repositoryGroupAdmin.deleteRepositoryGroup( "repo-group-one", getFakeAuditInformation() );
  108. assertEquals( 0, repositoryGroupAdmin.getRepositoriesGroups().size() );
  109. assertEquals( 3, mockAuditListener.getAuditEvents().size() );
  110. assertEquals( AuditEvent.ADD_REPO_GROUP, mockAuditListener.getAuditEvents().get( 0 ).getAction() );
  111. assertEquals( AuditEvent.MODIFY_REPO_GROUP, mockAuditListener.getAuditEvents().get( 1 ).getAction() );
  112. assertEquals( AuditEvent.DELETE_REPO_GROUP, mockAuditListener.getAuditEvents().get( 2 ).getAction() );
  113. }
  114. finally
  115. {
  116. mockAuditListener.clearEvents();
  117. managedRepositoryAdmin.deleteManagedRepository( "test-new-one", getFakeAuditInformation(), true );
  118. managedRepositoryAdmin.deleteManagedRepository( "test-new-two", getFakeAuditInformation(), true );
  119. }
  120. }
  121. @Test
  122. public void addAndDeleteGroupWithRemovedManagedRepo()
  123. throws Exception
  124. {
  125. try
  126. {
  127. ManagedRepository managedRepositoryOne =
  128. getTestManagedRepository( "test-new-one", APPSERVER_BASE_PATH + File.separator + "test-new-one" );
  129. ManagedRepository managedRepositoryTwo =
  130. getTestManagedRepository( "test-new-two", APPSERVER_BASE_PATH + File.separator + "test-new-two" );
  131. managedRepositoryAdmin.addManagedRepository( managedRepositoryOne, false, getFakeAuditInformation() );
  132. managedRepositoryAdmin.addManagedRepository( managedRepositoryTwo, false, getFakeAuditInformation() );
  133. RepositoryGroup repositoryGroup =
  134. new RepositoryGroup( "repo-group-one", Arrays.asList( "test-new-one", "test-new-two" ) );
  135. mockAuditListener.clearEvents();
  136. repositoryGroupAdmin.addRepositoryGroup( repositoryGroup, getFakeAuditInformation() );
  137. assertEquals( 1, repositoryGroupAdmin.getRepositoriesGroups().size() );
  138. assertEquals( "repo-group-one", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getId() );
  139. assertEquals( 2, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories().size() );
  140. assertEquals( Arrays.asList( "test-new-one", "test-new-two" ),
  141. repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories() );
  142. // deleting a managed repo to validate repogroup correctly updated !
  143. managedRepositoryAdmin.deleteManagedRepository( "test-new-one", getFakeAuditInformation(), true );
  144. assertEquals( 1, repositoryGroupAdmin.getRepositoriesGroups().size() );
  145. assertEquals( "repo-group-one", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getId() );
  146. assertEquals( 1, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories().size() );
  147. assertEquals( Arrays.asList( "test-new-two" ),
  148. repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories() );
  149. repositoryGroupAdmin.deleteRepositoryGroup( "repo-group-one", getFakeAuditInformation() );
  150. assertEquals( 0, repositoryGroupAdmin.getRepositoriesGroups().size() );
  151. assertEquals( 3, mockAuditListener.getAuditEvents().size() );
  152. assertEquals( AuditEvent.ADD_REPO_GROUP, mockAuditListener.getAuditEvents().get( 0 ).getAction() );
  153. assertEquals( AuditEvent.DELETE_MANAGED_REPO, mockAuditListener.getAuditEvents().get( 1 ).getAction() );
  154. assertEquals( AuditEvent.DELETE_REPO_GROUP, mockAuditListener.getAuditEvents().get( 2 ).getAction() );
  155. }
  156. finally
  157. {
  158. mockAuditListener.clearEvents();
  159. managedRepositoryAdmin.deleteManagedRepository( "test-new-two", getFakeAuditInformation(), true );
  160. }
  161. }
  162. @Test( expected = RepositoryAdminException.class )
  163. public void testAddGroupWithInvalidMergedIndexTtl() throws Exception {
  164. try {
  165. ManagedRepository managedRepositoryOne =
  166. getTestManagedRepository( "test-new-one", APPSERVER_BASE_PATH + File.separator + "test-new-one" );
  167. ManagedRepository managedRepositoryTwo =
  168. getTestManagedRepository( "test-new-two", APPSERVER_BASE_PATH + File.separator + "test-new-two" );
  169. managedRepositoryAdmin.addManagedRepository( managedRepositoryOne, false, getFakeAuditInformation() );
  170. managedRepositoryAdmin.addManagedRepository( managedRepositoryTwo, false, getFakeAuditInformation() );
  171. RepositoryGroup repositoryGroup =
  172. new RepositoryGroup( "repo-group-one", Arrays.asList( "test-new-one", "test-new-two" ) )
  173. .mergedIndexTtl( -1 );
  174. mockAuditListener.clearEvents();
  175. repositoryGroupAdmin.addRepositoryGroup( repositoryGroup, getFakeAuditInformation() );
  176. }
  177. finally
  178. {
  179. mockAuditListener.clearEvents();
  180. managedRepositoryAdmin.deleteManagedRepository( "test-new-one", getFakeAuditInformation(), true );
  181. managedRepositoryAdmin.deleteManagedRepository( "test-new-two", getFakeAuditInformation(), true );
  182. }
  183. }
  184. @Test( expected = RepositoryAdminException.class )
  185. public void testAddAndUpdateGroupWithInvalidMergedIndexTtl() throws Exception {
  186. try {
  187. ManagedRepository managedRepositoryOne =
  188. getTestManagedRepository( "test-new-one", APPSERVER_BASE_PATH + File.separator + "test-new-one" );
  189. ManagedRepository managedRepositoryTwo =
  190. getTestManagedRepository( "test-new-two", APPSERVER_BASE_PATH + File.separator + "test-new-two" );
  191. managedRepositoryAdmin.addManagedRepository( managedRepositoryOne, false, getFakeAuditInformation() );
  192. managedRepositoryAdmin.addManagedRepository( managedRepositoryTwo, false, getFakeAuditInformation() );
  193. RepositoryGroup repositoryGroup =
  194. new RepositoryGroup( "repo-group-one", Arrays.asList( "test-new-one", "test-new-two" ) );
  195. mockAuditListener.clearEvents();
  196. repositoryGroupAdmin.addRepositoryGroup( repositoryGroup, getFakeAuditInformation() );
  197. assertEquals( 1, repositoryGroupAdmin.getRepositoriesGroups().size() );
  198. assertEquals( "repo-group-one", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getId() );
  199. assertEquals( 2, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories().size() );
  200. assertEquals( Arrays.asList( "test-new-one", "test-new-two" ),
  201. repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories() );
  202. // verify if default values were saved
  203. assertEquals(30, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getMergedIndexTtl() );
  204. assertEquals("/.indexer", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getMergedIndexPath() );
  205. repositoryGroup = repositoryGroupAdmin.getRepositoryGroup( "repo-group-one" );
  206. assertNotNull( repositoryGroup );
  207. repositoryGroup.mergedIndexTtl( -1 );
  208. repositoryGroupAdmin.updateRepositoryGroup( repositoryGroup, getFakeAuditInformation() );
  209. }
  210. finally
  211. {
  212. mockAuditListener.clearEvents();
  213. managedRepositoryAdmin.deleteManagedRepository( "test-new-one", getFakeAuditInformation(), true );
  214. managedRepositoryAdmin.deleteManagedRepository( "test-new-two", getFakeAuditInformation(), true );
  215. }
  216. }
  217. }