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 15KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301
  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.apache.archiva.repository.Repository;
  27. import org.apache.archiva.repository.RepositoryRegistry;
  28. import org.apache.archiva.repository.base.group.RepositoryGroupHandler;
  29. import org.junit.Test;
  30. import javax.inject.Inject;
  31. import java.nio.file.Paths;
  32. import java.util.Arrays;
  33. /**
  34. * @author Olivier Lamy
  35. */
  36. public class RepositoryGroupAdminTest
  37. extends AbstractRepositoryAdminTest
  38. {
  39. @Inject
  40. RepositoryGroupAdmin repositoryGroupAdmin;
  41. @Inject
  42. RepositoryRegistry repositoryRegistry;
  43. @Inject
  44. RepositoryGroupHandler repositoryGroupHandler;
  45. @Test
  46. public void addAndDeleteGroup()
  47. throws Exception
  48. {
  49. try
  50. {
  51. Repository repo = repositoryRegistry.getRepository("test-new-one");
  52. if (repo!=null) {
  53. repositoryRegistry.removeRepository(repo);
  54. }
  55. repo = repositoryRegistry.getRepository("test-new-two");
  56. if (repo!=null) {
  57. repositoryRegistry.removeRepository(repo);
  58. }
  59. ManagedRepository managedRepositoryOne =
  60. getTestManagedRepository( "test-new-one", Paths.get(APPSERVER_BASE_PATH,"test-new-one" ).toString());
  61. ManagedRepository managedRepositoryTwo =
  62. getTestManagedRepository( "test-new-two", Paths.get(APPSERVER_BASE_PATH, "test-new-two" ).toString());
  63. managedRepositoryAdmin.addManagedRepository( managedRepositoryOne, false, getFakeAuditInformation() );
  64. managedRepositoryAdmin.addManagedRepository( managedRepositoryTwo, false, getFakeAuditInformation() );
  65. RepositoryGroup repositoryGroup =
  66. new RepositoryGroup( "repo-group-one", Arrays.asList( "test-new-one", "test-new-two" ) );
  67. // repositoryGroupAdmin.deleteRepositoryGroup("repo-group-one", null);
  68. mockAuditListener.clearEvents();
  69. repositoryGroupAdmin.addRepositoryGroup( repositoryGroup, getFakeAuditInformation() );
  70. assertEquals( 1, repositoryGroupAdmin.getRepositoriesGroups().size() );
  71. assertEquals( "repo-group-one", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getId() );
  72. assertEquals( 2, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories().size() );
  73. assertEquals( Arrays.asList( "test-new-one", "test-new-two" ),
  74. repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories() );
  75. // verify if default values were saved
  76. assertEquals(30, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getMergedIndexTtl() );
  77. assertEquals(".indexer", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getMergedIndexPath() );
  78. repositoryGroupAdmin.deleteRepositoryGroup( "repo-group-one", getFakeAuditInformation() );
  79. assertEquals( 0, repositoryGroupAdmin.getRepositoriesGroups().size() );
  80. assertEquals( 2, mockAuditListener.getAuditEvents().size() );
  81. assertEquals( AuditEvent.ADD_REPO_GROUP, mockAuditListener.getAuditEvents().get( 0 ).getAction() );
  82. assertEquals( AuditEvent.DELETE_REPO_GROUP, mockAuditListener.getAuditEvents().get( 1 ).getAction() );
  83. }
  84. finally
  85. {
  86. mockAuditListener.clearEvents();
  87. repositoryRegistry.removeRepository(repositoryRegistry.getManagedRepository("test-new-one"));
  88. repositoryRegistry.removeRepository(repositoryRegistry.getManagedRepository("test-new-two"));
  89. }
  90. }
  91. @Test
  92. public void addAndUpdateAndDeleteGroup()
  93. throws Exception
  94. {
  95. try
  96. {
  97. ManagedRepository managedRepositoryOne =
  98. getTestManagedRepository( "test-new-one", Paths.get(APPSERVER_BASE_PATH,"test-new-one" ).toString());
  99. ManagedRepository managedRepositoryTwo =
  100. getTestManagedRepository( "test-new-two", Paths.get(APPSERVER_BASE_PATH, "test-new-two" ).toString());
  101. managedRepositoryAdmin.addManagedRepository( managedRepositoryOne, false, getFakeAuditInformation() );
  102. managedRepositoryAdmin.addManagedRepository( managedRepositoryTwo, false, getFakeAuditInformation() );
  103. RepositoryGroup repositoryGroup = new RepositoryGroup( "repo-group-one", Arrays.asList( "test-new-one" ) )
  104. .mergedIndexTtl( 20 ).mergedIndexPath( "/.nonDefaultPath" );
  105. mockAuditListener.clearEvents();
  106. repositoryGroupAdmin.addRepositoryGroup( repositoryGroup, getFakeAuditInformation() );
  107. assertEquals( 1, repositoryGroupAdmin.getRepositoriesGroups().size() );
  108. assertEquals( "repo-group-one", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getId() );
  109. assertEquals( 1, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories().size() );
  110. assertEquals( Arrays.asList( "test-new-one" ),
  111. repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories() );
  112. assertEquals( 20, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getMergedIndexTtl() );
  113. assertEquals( "/.nonDefaultPath", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getMergedIndexPath() );
  114. repositoryGroup = repositoryGroupAdmin.getRepositoryGroup( "repo-group-one" );
  115. assertNotNull( repositoryGroup );
  116. repositoryGroup.addRepository( managedRepositoryTwo.getId() );
  117. repositoryGroupAdmin.updateRepositoryGroup( repositoryGroup, getFakeAuditInformation() );
  118. assertEquals( 1, repositoryGroupAdmin.getRepositoriesGroups().size() );
  119. assertEquals( "repo-group-one", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getId() );
  120. assertEquals( 2, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories().size() );
  121. assertEquals( Arrays.asList( "test-new-one", "test-new-two" ),
  122. repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories() );
  123. repositoryGroupAdmin.deleteRepositoryGroup( "repo-group-one", getFakeAuditInformation() );
  124. assertEquals( 0, repositoryGroupAdmin.getRepositoriesGroups().size() );
  125. assertEquals( 3, mockAuditListener.getAuditEvents().size() );
  126. assertEquals( AuditEvent.ADD_REPO_GROUP, mockAuditListener.getAuditEvents().get( 0 ).getAction() );
  127. assertEquals( AuditEvent.MODIFY_REPO_GROUP, mockAuditListener.getAuditEvents().get( 1 ).getAction() );
  128. assertEquals( AuditEvent.DELETE_REPO_GROUP, mockAuditListener.getAuditEvents().get( 2 ).getAction() );
  129. }
  130. finally
  131. {
  132. mockAuditListener.clearEvents();
  133. managedRepositoryAdmin.deleteManagedRepository( "test-new-one", getFakeAuditInformation(), true );
  134. managedRepositoryAdmin.deleteManagedRepository( "test-new-two", getFakeAuditInformation(), true );
  135. }
  136. }
  137. @Test
  138. public void addAndDeleteGroupWithRemovedManagedRepo()
  139. throws Exception
  140. {
  141. try
  142. {
  143. ManagedRepository managedRepositoryOne =
  144. getTestManagedRepository( "test-new-one", Paths.get(APPSERVER_BASE_PATH , "test-new-one" ).toString());
  145. ManagedRepository managedRepositoryTwo =
  146. getTestManagedRepository( "test-new-two", Paths.get(APPSERVER_BASE_PATH ,"test-new-two" ).toString());
  147. managedRepositoryAdmin.addManagedRepository( managedRepositoryOne, false, getFakeAuditInformation() );
  148. managedRepositoryAdmin.addManagedRepository( managedRepositoryTwo, false, getFakeAuditInformation() );
  149. RepositoryGroup repositoryGroup =
  150. new RepositoryGroup( "repo-group-one", Arrays.asList( "test-new-one", "test-new-two" ) );
  151. mockAuditListener.clearEvents();
  152. repositoryGroupAdmin.addRepositoryGroup( repositoryGroup, getFakeAuditInformation() );
  153. assertEquals( 1, repositoryGroupAdmin.getRepositoriesGroups().size() );
  154. assertEquals( "repo-group-one", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getId() );
  155. assertEquals( 2, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories().size() );
  156. assertEquals( Arrays.asList( "test-new-one", "test-new-two" ),
  157. repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories() );
  158. // deleting a managed repo to validate repogroup correctly updated !
  159. managedRepositoryAdmin.deleteManagedRepository( "test-new-one", getFakeAuditInformation(), true );
  160. assertEquals( 1, repositoryGroupAdmin.getRepositoriesGroups().size() );
  161. assertEquals( "repo-group-one", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getId() );
  162. assertEquals( 1, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories().size() );
  163. assertEquals( Arrays.asList( "test-new-two" ),
  164. repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories() );
  165. repositoryGroupAdmin.deleteRepositoryGroup( "repo-group-one", getFakeAuditInformation() );
  166. assertEquals( 0, repositoryGroupAdmin.getRepositoriesGroups().size() );
  167. assertEquals( 3, mockAuditListener.getAuditEvents().size() );
  168. assertEquals( AuditEvent.ADD_REPO_GROUP, mockAuditListener.getAuditEvents().get( 0 ).getAction() );
  169. assertEquals( AuditEvent.DELETE_MANAGED_REPO, mockAuditListener.getAuditEvents().get( 1 ).getAction() );
  170. assertEquals( AuditEvent.DELETE_REPO_GROUP, mockAuditListener.getAuditEvents().get( 2 ).getAction() );
  171. }
  172. finally
  173. {
  174. mockAuditListener.clearEvents();
  175. repositoryRegistry.removeRepository(repositoryRegistry.getRepository("test-new-two"));
  176. }
  177. }
  178. @Test( expected = RepositoryAdminException.class )
  179. public void testAddGroupWithInvalidMergedIndexTtl() throws Exception {
  180. try {
  181. ManagedRepository managedRepositoryOne =
  182. getTestManagedRepository( "test-new-one", Paths.get(APPSERVER_BASE_PATH , "test-new-one" ).toString());
  183. ManagedRepository managedRepositoryTwo =
  184. getTestManagedRepository( "test-new-two", Paths.get(APPSERVER_BASE_PATH , "test-new-two" ).toString());
  185. managedRepositoryAdmin.addManagedRepository( managedRepositoryOne, false, getFakeAuditInformation() );
  186. managedRepositoryAdmin.addManagedRepository( managedRepositoryTwo, false, getFakeAuditInformation() );
  187. RepositoryGroup repositoryGroup =
  188. new RepositoryGroup( "repo-group-one", Arrays.asList( "test-new-one", "test-new-two" ) )
  189. .mergedIndexTtl( -1 );
  190. mockAuditListener.clearEvents();
  191. repositoryGroupAdmin.addRepositoryGroup( repositoryGroup, getFakeAuditInformation() );
  192. }
  193. finally
  194. {
  195. mockAuditListener.clearEvents();
  196. repositoryRegistry.removeRepository(repositoryRegistry.getRepository("test-new-one"));
  197. repositoryRegistry.removeRepository(repositoryRegistry.getRepository("test-new-two"));
  198. }
  199. }
  200. @Test( expected = RepositoryAdminException.class )
  201. public void testAddAndUpdateGroupWithInvalidMergedIndexTtl() throws Exception {
  202. try {
  203. ManagedRepository managedRepositoryOne =
  204. getTestManagedRepository( "test-new-one", Paths.get(APPSERVER_BASE_PATH , "test-new-one" ).toString());
  205. ManagedRepository managedRepositoryTwo =
  206. getTestManagedRepository( "test-new-two", Paths.get(APPSERVER_BASE_PATH , "test-new-two" ).toString());
  207. managedRepositoryAdmin.addManagedRepository( managedRepositoryOne, false, getFakeAuditInformation() );
  208. managedRepositoryAdmin.addManagedRepository( managedRepositoryTwo, false, getFakeAuditInformation() );
  209. RepositoryGroup repositoryGroup =
  210. new RepositoryGroup( "repo-group-one", Arrays.asList( "test-new-one", "test-new-two" ) );
  211. mockAuditListener.clearEvents();
  212. repositoryGroupAdmin.addRepositoryGroup( repositoryGroup, getFakeAuditInformation() );
  213. assertEquals( 1, repositoryGroupAdmin.getRepositoriesGroups().size() );
  214. assertEquals( "repo-group-one", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getId() );
  215. assertEquals( 2, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories().size() );
  216. assertEquals( Arrays.asList( "test-new-one", "test-new-two" ),
  217. repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getRepositories() );
  218. // verify if default values were saved
  219. assertEquals(30, repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getMergedIndexTtl() );
  220. assertEquals(".indexer", repositoryGroupAdmin.getRepositoriesGroups().get( 0 ).getMergedIndexPath() );
  221. repositoryGroup = repositoryGroupAdmin.getRepositoryGroup( "repo-group-one" );
  222. assertNotNull( repositoryGroup );
  223. repositoryGroup.mergedIndexTtl( -1 );
  224. repositoryGroupAdmin.updateRepositoryGroup( repositoryGroup, getFakeAuditInformation() );
  225. }
  226. finally
  227. {
  228. mockAuditListener.clearEvents();
  229. managedRepositoryAdmin.deleteManagedRepository( "test-new-one", getFakeAuditInformation(), true );
  230. managedRepositoryAdmin.deleteManagedRepository( "test-new-two", getFakeAuditInformation(), true );
  231. }
  232. }
  233. }