Nevar pievienot vairāk kā 25 tēmas Tēmai ir jāsākas ar burtu vai ciparu, tā var saturēt domu zīmes ('-') un var būt līdz 35 simboliem gara.

TestRepositoryStatisticsManager.java 3.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. package org.apache.archiva.scheduler.repository;
  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.metadata.repository.MetadataRepository;
  21. import org.apache.archiva.metadata.repository.MetadataRepositoryException;
  22. import org.apache.archiva.metadata.repository.stats.RepositoryStatistics;
  23. import org.apache.archiva.metadata.repository.stats.RepositoryStatisticsManager;
  24. import org.springframework.stereotype.Service;
  25. import java.util.ArrayList;
  26. import java.util.Date;
  27. import java.util.HashMap;
  28. import java.util.List;
  29. import java.util.Map;
  30. @Service( "repositoryStatisticsManager#test" )
  31. public class TestRepositoryStatisticsManager
  32. implements RepositoryStatisticsManager
  33. {
  34. private Map<String, List<RepositoryStatistics>> repoStats = new HashMap<String, List<RepositoryStatistics>>();
  35. public boolean hasStatistics( MetadataRepository metadataRepository, String repositoryId )
  36. throws MetadataRepositoryException
  37. {
  38. return !repoStats.isEmpty();
  39. }
  40. public RepositoryStatistics getLastStatistics( MetadataRepository metadataRepository, String repositoryId )
  41. {
  42. List<RepositoryStatistics> repositoryStatisticsList = getStatsList( repositoryId );
  43. return !repositoryStatisticsList.isEmpty()
  44. ? repositoryStatisticsList.get( repositoryStatisticsList.size() - 1 )
  45. : null;
  46. }
  47. public void addStatisticsAfterScan( MetadataRepository metadataRepository, String repositoryId, Date startTime,
  48. Date endTime, long totalFiles, long newFiles )
  49. {
  50. List<RepositoryStatistics> stats = getStatsList( repositoryId );
  51. RepositoryStatistics repositoryStatistics = new RepositoryStatistics();
  52. repositoryStatistics.setScanStartTime( startTime );
  53. repositoryStatistics.setScanEndTime( endTime );
  54. repositoryStatistics.setNewFileCount( newFiles );
  55. repositoryStatistics.setTotalFileCount( totalFiles );
  56. repositoryStatistics.setRepositoryId( repositoryId );
  57. stats.add( repositoryStatistics );
  58. }
  59. public void deleteStatistics( MetadataRepository metadataRepository, String repositoryId )
  60. {
  61. repoStats.remove( repositoryId );
  62. }
  63. public List<RepositoryStatistics> getStatisticsInRange( MetadataRepository metadataRepository, String repositoryId,
  64. Date startDate, Date endDate )
  65. {
  66. throw new UnsupportedOperationException();
  67. }
  68. private List<RepositoryStatistics> getStatsList( String repositoryId )
  69. {
  70. List<RepositoryStatistics> stats = repoStats.get( repositoryId );
  71. if ( stats == null )
  72. {
  73. stats = new ArrayList<>();
  74. repoStats.put( repositoryId, stats );
  75. }
  76. return stats;
  77. }
  78. }