Class OakRepositoryFixture

    • Constructor Detail

      • OakRepositoryFixture

        protected OakRepositoryFixture​(OakFixture oakFixture)
    • Method Detail

      • getMongo

        public static RepositoryFixture getMongo​(String host,
                                                 int port,
                                                 String database,
                                                 boolean dropDBAfterTest,
                                                 long cacheSize,
                                                 boolean throttlingEnabled)
      • getMongo

        public static RepositoryFixture getMongo​(String uri,
                                                 boolean dropDBAfterTest,
                                                 long cacheSize,
                                                 boolean throttlingEnabled)
      • getMongoWithDS

        public static RepositoryFixture getMongoWithDS​(String host,
                                                       int port,
                                                       String database,
                                                       boolean dropDBAfterTest,
                                                       long cacheSize,
                                                       File base,
                                                       int fdsCacheInMB,
                                                       boolean throttlingEnabled)
      • getMongoWithDS

        public static RepositoryFixture getMongoWithDS​(String uri,
                                                       boolean dropDBAfterTest,
                                                       long cacheSize,
                                                       File base,
                                                       int fdsCacheInMB,
                                                       boolean throttlingEnabled)
      • getMongoNS

        public static RepositoryFixture getMongoNS​(String host,
                                                   int port,
                                                   String database,
                                                   boolean dropDBAfterTest,
                                                   long cacheSize,
                                                   boolean throttlingEnabled)
      • getMongoNS

        public static RepositoryFixture getMongoNS​(String uri,
                                                   boolean dropDBAfterTest,
                                                   long cacheSize,
                                                   boolean throttlingEnabled)
      • getRDBWithDS

        public static RepositoryFixture getRDBWithDS​(String jdbcuri,
                                                     String jdbcuser,
                                                     String jdbcpasswd,
                                                     String jdbctableprefix,
                                                     boolean dropDBAfterTest,
                                                     long cacheSize,
                                                     File base,
                                                     int fdsCacheInMB,
                                                     int vgcMaxAge)
      • getSegmentTar

        public static RepositoryFixture getSegmentTar​(File base,
                                                      int maxFileSizeMB,
                                                      int cacheSizeMB,
                                                      boolean memoryMapping,
                                                      int binariesInlineThreshold)
      • getSegmentTarWithDataStore

        public static RepositoryFixture getSegmentTarWithDataStore​(File base,
                                                                   int maxFileSizeMB,
                                                                   int cacheSizeMB,
                                                                   boolean memoryMapping,
                                                                   int binariesInlineThreshold,
                                                                   int dsCacheInMB)
      • getSegmentTarWithColdStandby

        public static RepositoryFixture getSegmentTarWithColdStandby​(File base,
                                                                     int maxFileSizeMB,
                                                                     int cacheSizeMB,
                                                                     boolean memoryMapping,
                                                                     int binariesInlineThreshold,
                                                                     boolean useBlobStore,
                                                                     int dsCacheInMB,
                                                                     int syncInterval,
                                                                     boolean shareBlobStore,
                                                                     boolean secure,
                                                                     boolean oneShotRun)
      • getSegmentTarWithAwsSegmentStore

        public static RepositoryFixture getSegmentTarWithAwsSegmentStore​(File base,
                                                                         String awsBucketName,
                                                                         String awsRootPath,
                                                                         String awsJournalTableName,
                                                                         String awsLockTableName,
                                                                         int maxFileSizeMB,
                                                                         int cacheSizeMB,
                                                                         int binariesInlineThreshold,
                                                                         boolean useBlobStore,
                                                                         int dsCacheInMB)
      • getSegmentTarWithAzureSegmentStore

        public static RepositoryFixture getSegmentTarWithAzureSegmentStore​(File base,
                                                                           String azureConnectionString,
                                                                           String azureContainerName,
                                                                           String azureRootPath,
                                                                           int maxFileSizeMB,
                                                                           int cacheSizeMB,
                                                                           int binariesInlineThreshold,
                                                                           boolean useBlobStore,
                                                                           int dsCacheInMB)
      • getCompositeStore

        public static RepositoryFixture getCompositeStore​(File base,
                                                          int maxFileSizeMB,
                                                          int cacheSizeMB,
                                                          boolean memoryMapping,
                                                          int binariesInlineThreshold)
      • getCompositeMemoryStore

        public static RepositoryFixture getCompositeMemoryStore()
      • getCompositeMongoStore

        public static RepositoryFixture getCompositeMongoStore​(String uri,
                                                               long cacheSize,
                                                               boolean dropDBAfterTest,
                                                               boolean throttlingEnabled)
      • isAvailable

        public boolean isAvailable​(int n)
        Description copied from interface: RepositoryFixture
        Checks whether this fixture is currently available. For example a database-based fixture would only be available when the underlying database service is running.
        Specified by:
        isAvailable in interface RepositoryFixture
        Parameters:
        n - size of the requested cluster
        Returns:
        true iff the fixture is available
      • setUpCluster

        public final Repository[] setUpCluster​(int n)
                                        throws Exception
        Description copied from interface: RepositoryFixture
        Creates a new repository cluster with the given number of nodes. The initial state of the cluster consists of just the default repository content included by the implementation. The caller of this method should have exclusive access to the created cluster. The caller is also responsible for calling RepositoryFixture.tearDownCluster() when the test cluster is no longer needed.
        Specified by:
        setUpCluster in interface RepositoryFixture
        Parameters:
        n - size of the requested cluster
        Returns:
        nodes of the created cluster
        Throws:
        Exception - if the cluster could not be set up
      • syncRepositoryCluster

        public void syncRepositoryCluster​(Repository... nodes)
        Description copied from interface: RepositoryFixture
        Ensures that all content changes seen by one of the given cluster nodes are seen also by all the other given nodes. Used to help testing features like eventual consistency where the normal APIs don't make strong enough guarantees to enable writing a test case without a potentially unbounded wait for changes to propagate across the cluster.
        Specified by:
        syncRepositoryCluster in interface RepositoryFixture
        Parameters:
        nodes - cluster nodes to be synchronized
      • getOakFixture

        public OakFixture getOakFixture()
      • setStatisticsProvider

        public void setStatisticsProvider​(StatisticsProvider statisticsProvider)