ACS-1711 : [SPIKE] Update the S3 connector to support Storage Classes (#559)

- update the storage class representation
This commit is contained in:
Lucian Tuca
2021-06-29 11:30:03 +03:00
committed by GitHub
parent d4e76d9f0f
commit 6a25322fd4
19 changed files with 193 additions and 137 deletions

View File

@@ -92,6 +92,10 @@ public interface ContentStore
*/ */
public static final String PROTOCOL_DELIMITER = "://"; public static final String PROTOCOL_DELIMITER = "://";
public static final String STORAGE_CLASS_DEFAULT = "default";
public static final String STORAGE_CLASS_ARCHIVE = "archive";
public static final String STORAGE_CLASS_WORM = "worm";
/** /**
* The 'default' storage class * The 'default' storage class
* *
@@ -100,7 +104,9 @@ public interface ContentStore
* the value is an empty set * the value is an empty set
* the value is null * the value is null
*/ */
public static final String DEFAULT_SC = "default"; public static final StorageClassSet SCS_DEFAULT = new StorageClassSet(STORAGE_CLASS_DEFAULT);
public static final StorageClassSet SCS_ARCHIVE = new StorageClassSet(STORAGE_CLASS_ARCHIVE);
public static final StorageClassSet SCS_WORM = new StorageClassSet(STORAGE_CLASS_WORM);
/** /**
* Check if the content URL format is supported by the store. * Check if the content URL format is supported by the store.
@@ -280,14 +286,14 @@ public interface ContentStore
/** /**
* Checks whether or not the current {@link ContentStore} supports the provided {@link Set} storage classes * Checks whether or not the current {@link ContentStore} supports the provided {@link Set} storage classes
* *
* @param storageClasses The storage classes that will be checked whether or not are supported * @param storageClassSet The storage classes that will be checked whether or not are supported
* @return true if the storage classes are supported, false otherwise. * @return true if the storage classes are supported, false otherwise.
*/ */
default boolean isStorageClassesSupported(Set<String> storageClasses) default boolean isStorageClassesSupported(StorageClassSet storageClassSet)
{ {
return storageClasses == null || return storageClassSet == null ||
storageClasses.isEmpty() || storageClassSet.isEmpty() ||
(1 == storageClasses.size() && storageClasses.contains(DEFAULT_SC)); (1 == storageClassSet.size() && storageClassSet.equals(SCS_DEFAULT));
} }
/** /**
@@ -295,17 +301,18 @@ public interface ContentStore
*/ */
default Set<String> getSupportedStorageClasses() default Set<String> getSupportedStorageClasses()
{ {
return Set.of(DEFAULT_SC); return Set.of(ContentStore.STORAGE_CLASS_DEFAULT);
} }
/** /**
* Updates the storage class for content * Updates the storage class for content
* *
* @param contentUrl The URL of the content that will have its storage classes updated * @param contentUrl The URL of the content that will have its storage classes updated
* @param storageClasses The new storage classes * @param storageClassSet The new storage class
* @param parameters extra parameters * @param parameters extra parameters
*/ */
default void updateStorageClasses(String contentUrl, Set<String> storageClasses, Map<String, Object> parameters) default void updateStorageClasses(String contentUrl, StorageClassSet storageClassSet, Map<String, Object> parameters)
{ {
} }
@@ -314,16 +321,16 @@ public interface ContentStore
* @param contentUrl the URL of the content for which the storage classes are to be requested * @param contentUrl the URL of the content for which the storage classes are to be requested
* @return Returns the current storage classes for the content found at the contentUrl * @return Returns the current storage classes for the content found at the contentUrl
*/ */
default Set<String> findStorageClasses(String contentUrl) default StorageClassSet findStorageClasses(String contentUrl)
{ {
return Set.of(DEFAULT_SC); return SCS_DEFAULT;
} }
/** /**
* @return Returns the complete collection of allowed storage classes transitions. * @return Returns the complete collection of allowed storage classes transitions.
* The key represents the source storage classes while the value (as a {@link Set}) represents all the possible target storage classes. * The key represents the source storage classes while the value (as a {@link Set}) represents all the possible target storage classes.
*/ */
default Map<Set<String>, Set<Set<String>>> getStorageClassesTransitions() default Map<StorageClassSet, Set<StorageClassSet>> getStorageClassesTransitions()
{ {
return Collections.emptyMap(); return Collections.emptyMap();
} }
@@ -332,7 +339,7 @@ public interface ContentStore
* @param contentUrl the URL of the content for which the storage classes transitions are to be requested * @param contentUrl the URL of the content for which the storage classes transitions are to be requested
* @return Returns the complete collection of allowed storage classes transitions for the content found at content URL * @return Returns the complete collection of allowed storage classes transitions for the content found at content URL
*/ */
default Map<Set<String>, Set<Set<String>>> findStorageClassesTransitions(String contentUrl) default Map<StorageClassSet, Set<StorageClassSet>> findStorageClassesTransitions(String contentUrl)
{ {
return Collections.emptyMap(); return Collections.emptyMap();
} }

View File

@@ -0,0 +1,45 @@
/*
* #%L
* Alfresco Data model classes
* %%
* Copyright (C) 2005 - 2016 Alfresco Software Limited
* %%
* This file is part of the Alfresco software.
* If the software was purchased under a paid Alfresco license, the terms of
* the paid license agreement will prevail. Otherwise, the software is
* provided under the following open source license terms:
*
* Alfresco is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Alfresco is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
* #L%
*/
package org.alfresco.repo.content;
import java.util.Collections;
import java.util.HashSet;
/**
* Represents the state of the content and it is internally represented as a set.
* It can have none, one, or multiple storage classes to specify the state
* e.g. [default], [archive], [archive, encrypted]
*
* @author Lucian Tuca
*/
public class StorageClassSet extends HashSet<String>
{
public StorageClassSet(String... storageClasses)
{
super();
Collections.addAll(this, storageClasses);
}
}

View File

@@ -26,16 +26,15 @@
package org.alfresco.rest.api.impl; package org.alfresco.rest.api.impl;
import java.util.Set;
import java.util.stream.Collectors;
import org.alfresco.rest.api.ContentStorageClasses; import org.alfresco.rest.api.ContentStorageClasses;
import org.alfresco.rest.api.model.StorageClass; import org.alfresco.rest.api.model.StorageClass;
import org.alfresco.rest.framework.resource.parameters.CollectionWithPagingInfo; import org.alfresco.rest.framework.resource.parameters.CollectionWithPagingInfo;
import org.alfresco.rest.framework.resource.parameters.Paging; import org.alfresco.rest.framework.resource.parameters.Paging;
import org.alfresco.service.cmr.repository.ContentService; import org.alfresco.service.cmr.repository.ContentService;
import java.util.Collections;
import java.util.Set;
import java.util.stream.Collectors;
/** /**
* Centralises access to storage classes functionality * Centralises access to storage classes functionality
*/ */

View File

@@ -25,12 +25,12 @@
*/ */
package org.alfresco.rest.framework.resource.content; package org.alfresco.rest.framework.resource.content;
import static org.alfresco.repo.content.ContentStore.DEFAULT_SC; import static org.alfresco.repo.content.ContentStore.SCS_DEFAULT;
import java.io.Serializable; import java.io.Serializable;
import java.util.Locale; import java.util.Locale;
import java.util.Set;
import org.alfresco.repo.content.StorageClassSet;
import org.alfresco.service.cmr.repository.ContentReader; import org.alfresco.service.cmr.repository.ContentReader;
import com.fasterxml.jackson.annotation.JsonIgnore; import com.fasterxml.jackson.annotation.JsonIgnore;
@@ -51,7 +51,7 @@ public class BinaryProperty implements ContentInfo, Serializable
private final String encoding; private final String encoding;
private final long length; private final long length;
private final Locale locale; private final Locale locale;
private final Set<String> storageClasses; private final StorageClassSet storageClassSet;
/** /**
* Sets the content length to zero, Locale to null, no stream and no caching * Sets the content length to zero, Locale to null, no stream and no caching
@@ -74,7 +74,7 @@ public class BinaryProperty implements ContentInfo, Serializable
this.encoding = reader.getEncoding(); this.encoding = reader.getEncoding();
this.length = reader.getSize(); this.length = reader.getSize();
this.locale = reader.getLocale(); this.locale = reader.getLocale();
this.storageClasses = Set.of(DEFAULT_SC); this.storageClassSet = SCS_DEFAULT;
} }
/** /**
@@ -89,14 +89,14 @@ public class BinaryProperty implements ContentInfo, Serializable
this(mimeType, encoding, length, locale, null); this(mimeType, encoding, length, locale, null);
} }
public BinaryProperty(String mimeType, String encoding, long length, Locale locale, Set<String> storageClasses) public BinaryProperty(String mimeType, String encoding, long length, Locale locale, StorageClassSet storageClassSet)
{ {
super(); super();
this.mimeType = mimeType; this.mimeType = mimeType;
this.encoding = encoding; this.encoding = encoding;
this.length = length; this.length = length;
this.locale = locale; this.locale = locale;
this.storageClasses = storageClasses; this.storageClassSet = storageClassSet;
} }
public String getMimeType() public String getMimeType()
@@ -132,9 +132,9 @@ public class BinaryProperty implements ContentInfo, Serializable
return this.locale; return this.locale;
} }
@JsonIgnore @JsonIgnore
public Set<String> getStorageClasses() public StorageClassSet getStorageClasses()
{ {
return storageClasses; return storageClassSet;
} }
} }

View File

@@ -4807,7 +4807,7 @@ public class NodeApiTest extends AbstractSingleNetworkSiteTest
// Check that all storage classes are retrieved // Check that all storage classes are retrieved
assertNotNull(documentResp.getContent().getStorageClasses()); assertNotNull(documentResp.getContent().getStorageClasses());
assertEquals(Set.of(ContentStore.DEFAULT_SC), documentResp.getContent().getStorageClasses()); assertEquals(ContentStore.SCS_DEFAULT, documentResp.getContent().getStorageClasses());
} }
/** /**

View File

@@ -26,6 +26,14 @@
package org.alfresco.rest.api.tests; package org.alfresco.rest.api.tests;
import static org.alfresco.rest.api.tests.util.RestApiUtil.parseRestApiEntries;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
import static org.mockito.Mockito.when;
import java.util.List;
import java.util.Set;
import org.alfresco.repo.content.ContentStore; import org.alfresco.repo.content.ContentStore;
import org.alfresco.repo.security.authentication.AuthenticationUtil; import org.alfresco.repo.security.authentication.AuthenticationUtil;
import org.alfresco.rest.AbstractSingleNetworkSiteTest; import org.alfresco.rest.AbstractSingleNetworkSiteTest;
@@ -39,14 +47,6 @@ import org.junit.Test;
import org.mockito.Mock; import org.mockito.Mock;
import org.springframework.test.util.ReflectionTestUtils; import org.springframework.test.util.ReflectionTestUtils;
import java.util.List;
import java.util.Set;
import static org.alfresco.rest.api.tests.util.RestApiUtil.parseRestApiEntries;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
import static org.mockito.Mockito.when;
/** /**
* V1 REST API tests for Storage Classes * V1 REST API tests for Storage Classes
* *
@@ -99,14 +99,15 @@ public class StorageClassesTest extends AbstractSingleNetworkSiteTest
{ {
ReflectionTestUtils.setField(contentService, "store", mockStore); ReflectionTestUtils.setField(contentService, "store", mockStore);
Set<String> expectedStorageClasses = Set.of("default", "archive", "worm"); Set<String> expectedStorageClass =
when(mockStore.getSupportedStorageClasses()).thenReturn(expectedStorageClasses); Set.of(ContentStore.STORAGE_CLASS_DEFAULT, ContentStore.STORAGE_CLASS_ARCHIVE);
when(mockStore.getSupportedStorageClasses()).thenReturn(expectedStorageClass);
PublicApiClient.Paging paging = getPaging(0, 100); PublicApiClient.Paging paging = getPaging(0, 100);
HttpResponse response = getAll(STORAGE_CLASSES, paging, 200); HttpResponse response = getAll(STORAGE_CLASSES, paging, 200);
List<StorageClass> nodes = parseRestApiEntries(response.getJsonResponse(), StorageClass.class); List<StorageClass> nodes = parseRestApiEntries(response.getJsonResponse(), StorageClass.class);
assertNotNull(nodes); assertNotNull(nodes);
assertEquals(3, nodes.size()); assertEquals(2, nodes.size());
} }
} }

View File

@@ -422,12 +422,12 @@ public abstract class AbstractRoutingContentStore implements ContentStore
} }
@Override @Override
public boolean isStorageClassesSupported(Set<String> storageClasses) public boolean isStorageClassesSupported(StorageClassSet storageClassSet)
{ {
boolean supported = false; boolean supported = false;
for (ContentStore store : getAllStores()) for (ContentStore store : getAllStores())
{ {
if (store.isStorageClassesSupported(storageClasses)) if (store.isStorageClassesSupported(storageClassSet))
{ {
supported = true; supported = true;
break; break;
@@ -436,7 +436,7 @@ public abstract class AbstractRoutingContentStore implements ContentStore
// Done // Done
if (logger.isDebugEnabled()) if (logger.isDebugEnabled())
{ {
logger.debug("The storage classes " + storageClasses + (supported ? "are" : "are not") + " supported by at least one store."); logger.debug("The storage classes " + storageClassSet + (supported ? "are" : "are not") + " supported by at least one store.");
} }
return supported; return supported;
} }
@@ -444,16 +444,16 @@ public abstract class AbstractRoutingContentStore implements ContentStore
@Override @Override
public Set<String> getSupportedStorageClasses() public Set<String> getSupportedStorageClasses()
{ {
Set<String> supportedStorageClasses = new HashSet<>(); Set<String> supportedStorageClassSets = new HashSet<>();
for (ContentStore store : getAllStores()) for (ContentStore store : getAllStores())
{ {
supportedStorageClasses.addAll(store.getSupportedStorageClasses()); supportedStorageClassSets.addAll(store.getSupportedStorageClasses());
} }
return supportedStorageClasses; return supportedStorageClassSets;
} }
@Override @Override
public void updateStorageClasses(String contentUrl, Set<String> storageClasses, public void updateStorageClasses(String contentUrl, StorageClassSet storageClassSet,
Map<String, Object> parameters) Map<String, Object> parameters)
{ {
ContentStore store; ContentStore store;
@@ -490,7 +490,7 @@ public abstract class AbstractRoutingContentStore implements ContentStore
} }
} }
if (!store.exists(contentUrl) || !store.isStorageClassesSupported(storageClasses)) if (!store.exists(contentUrl) || !store.isStorageClassesSupported(storageClassSet))
{ {
store = null; store = null;
@@ -498,7 +498,7 @@ public abstract class AbstractRoutingContentStore implements ContentStore
{ {
if (storeInList.isWriteSupported() && if (storeInList.isWriteSupported() &&
storeInList.exists(contentUrl) && storeInList.exists(contentUrl) &&
storeInList.isStorageClassesSupported(storageClasses)) storeInList.isStorageClassesSupported(storageClassSet))
{ {
store = storeInList; store = storeInList;
break; break;
@@ -511,7 +511,7 @@ public abstract class AbstractRoutingContentStore implements ContentStore
throw new UnsupportedOperationException( throw new UnsupportedOperationException(
"Unable to find a write store to update the storage classes for content URL: \n" + "Unable to find a write store to update the storage classes for content URL: \n" +
" Content URL: " + contentUrl + "\n" + " Content URL: " + contentUrl + "\n" +
" StorageClasses: " + storageClasses); " StorageClasses: " + storageClassSet);
} }
if (logger.isDebugEnabled()) if (logger.isDebugEnabled())
@@ -520,11 +520,11 @@ public abstract class AbstractRoutingContentStore implements ContentStore
" Content URL: " + contentUrl + "\n" + " Content URL: " + contentUrl + "\n" +
" Store: " + store); " Store: " + store);
} }
store.updateStorageClasses(contentUrl, storageClasses, parameters); store.updateStorageClasses(contentUrl, storageClassSet, parameters);
} }
@Override @Override
public Set<String> findStorageClasses(String contentUrl) public StorageClassSet findStorageClasses(String contentUrl)
{ {
ContentStore contentStore = selectReadStore(contentUrl); ContentStore contentStore = selectReadStore(contentUrl);
@@ -534,7 +534,7 @@ public abstract class AbstractRoutingContentStore implements ContentStore
{ {
logger.debug("Storage classes not found for content URL: " + contentUrl); logger.debug("Storage classes not found for content URL: " + contentUrl);
} }
return new HashSet<>(); return new StorageClassSet();
} }
if (logger.isDebugEnabled()) if (logger.isDebugEnabled())
@@ -547,9 +547,9 @@ public abstract class AbstractRoutingContentStore implements ContentStore
} }
@Override @Override
public Map<Set<String>, Set<Set<String>>> getStorageClassesTransitions() public Map<StorageClassSet, Set<StorageClassSet>> getStorageClassesTransitions()
{ {
Map<Set<String>, Set<Set<String>>> supportedTransitions = new HashMap<>(); Map<StorageClassSet, Set<StorageClassSet>> supportedTransitions = new HashMap<>();
for (ContentStore store : getAllStores()) for (ContentStore store : getAllStores())
{ {
supportedTransitions.putAll(store.getStorageClassesTransitions()); supportedTransitions.putAll(store.getStorageClassesTransitions());
@@ -558,7 +558,7 @@ public abstract class AbstractRoutingContentStore implements ContentStore
} }
@Override @Override
public Map<Set<String>, Set<Set<String>>> findStorageClassesTransitions(String contentUrl) public Map<StorageClassSet, Set<StorageClassSet>> findStorageClassesTransitions(String contentUrl)
{ {
ContentStore contentStore = selectReadStore(contentUrl); ContentStore contentStore = selectReadStore(contentUrl);

View File

@@ -588,9 +588,9 @@ public class ContentServiceImpl implements ContentService, ApplicationContextAwa
} }
@Override @Override
public boolean isStorageClassesSupported(Set<String> storageClasses) public boolean isStorageClassesSupported(StorageClassSet storageClassSet)
{ {
return store.isStorageClassesSupported(storageClasses); return store.isStorageClassesSupported(storageClassSet);
} }
@Override @Override
@@ -600,7 +600,7 @@ public class ContentServiceImpl implements ContentService, ApplicationContextAwa
} }
@Override @Override
public void updateStorageClasses(NodeRef nodeRef, Set<String> storageClasses, Map<String, Object> parameters) public void updateStorageClasses(NodeRef nodeRef, StorageClassSet storageClassSet, Map<String, Object> parameters)
{ {
ContentData contentData = getContentData(nodeRef, ContentModel.PROP_CONTENT); ContentData contentData = getContentData(nodeRef, ContentModel.PROP_CONTENT);
@@ -610,16 +610,16 @@ public class ContentServiceImpl implements ContentService, ApplicationContextAwa
throw new IllegalArgumentException("The supplied nodeRef " + nodeRef + " has no content."); throw new IllegalArgumentException("The supplied nodeRef " + nodeRef + " has no content.");
} }
if (!isStorageClassesSupported(storageClasses)) if (!isStorageClassesSupported(storageClassSet))
{ {
throw new UnsupportedStorageClassException(store, storageClasses, "The supplied storage classes are not supported"); throw new UnsupportedStorageClassException(store, storageClassSet, "The supplied storage classes are not supported");
} }
store.updateStorageClasses(contentData.getContentUrl(), storageClasses, parameters); store.updateStorageClasses(contentData.getContentUrl(), storageClassSet, parameters);
} }
@Override @Override
public Set<String> findStorageClasses(NodeRef nodeRef) public StorageClassSet findStorageClasses(NodeRef nodeRef)
{ {
ContentData contentData = getContentData(nodeRef, ContentModel.PROP_CONTENT); ContentData contentData = getContentData(nodeRef, ContentModel.PROP_CONTENT);
@@ -633,13 +633,13 @@ public class ContentServiceImpl implements ContentService, ApplicationContextAwa
} }
@Override @Override
public Map<Set<String>, Set<Set<String>>> getStorageClassesTransitions() public Map<StorageClassSet, Set<StorageClassSet>> getStorageClassesTransitions()
{ {
return store.getStorageClassesTransitions(); return store.getStorageClassesTransitions();
} }
@Override @Override
public Map<Set<String>, Set<Set<String>>> findStorageClassesTransitions(NodeRef nodeRef) public Map<StorageClassSet, Set<StorageClassSet>> findStorageClassesTransitions(NodeRef nodeRef)
{ {
ContentData contentData = getContentData(nodeRef, ContentModel.PROP_CONTENT); ContentData contentData = getContentData(nodeRef, ContentModel.PROP_CONTENT);

View File

@@ -34,6 +34,7 @@ import java.util.concurrent.locks.ReentrantReadWriteLock.WriteLock;
import org.alfresco.repo.content.ContentContext; import org.alfresco.repo.content.ContentContext;
import org.alfresco.repo.content.ContentStore; import org.alfresco.repo.content.ContentStore;
import org.alfresco.repo.content.StorageClassSet;
import org.alfresco.repo.content.caching.quota.QuotaManagerStrategy; import org.alfresco.repo.content.caching.quota.QuotaManagerStrategy;
import org.alfresco.repo.content.caching.quota.UnlimitedQuotaStrategy; import org.alfresco.repo.content.caching.quota.UnlimitedQuotaStrategy;
import org.alfresco.repo.content.filestore.FileContentStore; import org.alfresco.repo.content.filestore.FileContentStore;
@@ -491,9 +492,9 @@ public class CachingContentStore implements ContentStore, ApplicationEventPublis
} }
@Override @Override
public boolean isStorageClassesSupported(Set<String> storageClasses) public boolean isStorageClassesSupported(StorageClassSet storageClassSet)
{ {
return backingStore.isStorageClassesSupported(storageClasses); return backingStore.isStorageClassesSupported(storageClassSet);
} }
@Override @Override
@@ -503,25 +504,25 @@ public class CachingContentStore implements ContentStore, ApplicationEventPublis
} }
@Override @Override
public void updateStorageClasses(String contentUrl, Set<String> storageClasses, Map<String, Object> parameters) public void updateStorageClasses(String contentUrl, StorageClassSet storageClassSet, Map<String, Object> parameters)
{ {
backingStore.updateStorageClasses(contentUrl, storageClasses, parameters); backingStore.updateStorageClasses(contentUrl, storageClassSet, parameters);
} }
@Override @Override
public Set<String> findStorageClasses(String contentUrl) public StorageClassSet findStorageClasses(String contentUrl)
{ {
return backingStore.findStorageClasses(contentUrl); return backingStore.findStorageClasses(contentUrl);
} }
@Override @Override
public Map<Set<String>, Set<Set<String>>> getStorageClassesTransitions() public Map<StorageClassSet, Set<StorageClassSet>> getStorageClassesTransitions()
{ {
return backingStore.getStorageClassesTransitions(); return backingStore.getStorageClassesTransitions();
} }
@Override @Override
public Map<Set<String>, Set<Set<String>>> findStorageClassesTransitions(String contentUrl) public Map<StorageClassSet, Set<StorageClassSet>> findStorageClassesTransitions(String contentUrl)
{ {
return backingStore.findStorageClassesTransitions(contentUrl); return backingStore.findStorageClassesTransitions(contentUrl);
} }

View File

@@ -37,6 +37,7 @@ import org.alfresco.error.AlfrescoRuntimeException;
import org.alfresco.repo.content.AbstractContentStore; import org.alfresco.repo.content.AbstractContentStore;
import org.alfresco.repo.content.ContentContext; import org.alfresco.repo.content.ContentContext;
import org.alfresco.repo.content.ContentStore; import org.alfresco.repo.content.ContentStore;
import org.alfresco.repo.content.StorageClassSet;
import org.alfresco.repo.content.UnsupportedContentUrlException; import org.alfresco.repo.content.UnsupportedContentUrlException;
import org.alfresco.repo.content.caching.CachingContentStore; import org.alfresco.repo.content.caching.CachingContentStore;
import org.alfresco.service.cmr.repository.ContentIOException; import org.alfresco.service.cmr.repository.ContentIOException;
@@ -385,11 +386,11 @@ public class AggregatingContentStore extends AbstractContentStore
} }
@Override @Override
public boolean isStorageClassesSupported(Set<String> storageClasses) public boolean isStorageClassesSupported(StorageClassSet storageClassesSet)
{ {
// We only need to provide info about the primary store, // We only need to provide info about the primary store,
// because the aggregating CS only allows to be written in the primary // because the aggregating CS only allows to be written in the primary
return primaryStore.isStorageClassesSupported(storageClasses); return primaryStore.isStorageClassesSupported(storageClassesSet);
} }
@Override @Override
@@ -401,13 +402,13 @@ public class AggregatingContentStore extends AbstractContentStore
} }
@Override @Override
public void updateStorageClasses(String contentUrl, Set<String> storageClasses, Map<String, Object> parameters) public void updateStorageClasses(String contentUrl, StorageClassSet storageClassSet, Map<String, Object> parameters)
{ {
primaryStore.updateStorageClasses(contentUrl, storageClasses, parameters); primaryStore.updateStorageClasses(contentUrl, storageClassSet, parameters);
} }
@Override @Override
public Set<String> findStorageClasses(String contentUrl) public StorageClassSet findStorageClasses(String contentUrl)
{ {
if (primaryStore == null) if (primaryStore == null)
{ {
@@ -420,12 +421,12 @@ public class AggregatingContentStore extends AbstractContentStore
{ {
// Keep track of the unsupported state of the content URL - it might be a rubbish URL // Keep track of the unsupported state of the content URL - it might be a rubbish URL
boolean contentUrlSupported = true; boolean contentUrlSupported = true;
Set<String> storageClasses = null; StorageClassSet storageClassesSet = null;
// Check the primary store // Check the primary store
try try
{ {
storageClasses = primaryStore.findStorageClasses(contentUrl); storageClassesSet = primaryStore.findStorageClasses(contentUrl);
} }
catch (UnsupportedContentUrlException e) catch (UnsupportedContentUrlException e)
{ {
@@ -433,9 +434,9 @@ public class AggregatingContentStore extends AbstractContentStore
contentUrlSupported = false; contentUrlSupported = false;
} }
if (storageClasses != null) if (storageClassesSet != null)
{ {
return storageClasses; return storageClassesSet;
} }
// the content is not in the primary store so we have to go looking for it // the content is not in the primary store so we have to go looking for it
@@ -443,7 +444,7 @@ public class AggregatingContentStore extends AbstractContentStore
{ {
try try
{ {
storageClasses = store.findStorageClasses(contentUrl); storageClassesSet = store.findStorageClasses(contentUrl);
} }
catch (UnsupportedContentUrlException e) catch (UnsupportedContentUrlException e)
{ {
@@ -451,19 +452,19 @@ public class AggregatingContentStore extends AbstractContentStore
contentUrlSupported = false; contentUrlSupported = false;
} }
if (storageClasses != null) if (storageClassesSet != null)
{ {
break; break;
} }
} }
if (storageClasses == null && !contentUrlSupported) if (storageClassesSet == null && !contentUrlSupported)
{ {
// The content URL was not supported // The content URL was not supported
throw new UnsupportedContentUrlException(this, contentUrl); throw new UnsupportedContentUrlException(this, contentUrl);
} }
return storageClasses; return storageClassesSet;
} }
finally finally
{ {
@@ -472,7 +473,7 @@ public class AggregatingContentStore extends AbstractContentStore
} }
@Override @Override
public Map<Set<String>, Set<Set<String>>> getStorageClassesTransitions() public Map<StorageClassSet, Set<StorageClassSet>> getStorageClassesTransitions()
{ {
// We only need to provide info about the primary store, // We only need to provide info about the primary store,
// because the aggregating CS only allows to be written in the primary // because the aggregating CS only allows to be written in the primary
@@ -480,7 +481,7 @@ public class AggregatingContentStore extends AbstractContentStore
} }
@Override @Override
public Map<Set<String>, Set<Set<String>>> findStorageClassesTransitions(String contentUrl) public Map<StorageClassSet, Set<StorageClassSet>> findStorageClassesTransitions(String contentUrl)
{ {
// We only need to provide info about the primary store, // We only need to provide info about the primary store,
// because the aggregating CS only allows to be written in the primary // because the aggregating CS only allows to be written in the primary

View File

@@ -38,6 +38,7 @@ import java.util.concurrent.locks.ReentrantReadWriteLock.WriteLock;
import org.alfresco.repo.content.AbstractRoutingContentStore; import org.alfresco.repo.content.AbstractRoutingContentStore;
import org.alfresco.repo.content.ContentContext; import org.alfresco.repo.content.ContentContext;
import org.alfresco.repo.content.ContentStore; import org.alfresco.repo.content.ContentStore;
import org.alfresco.repo.content.StorageClassSet;
import org.alfresco.repo.domain.tenant.TenantAdminDAO; import org.alfresco.repo.domain.tenant.TenantAdminDAO;
import org.alfresco.repo.domain.tenant.TenantEntity; import org.alfresco.repo.domain.tenant.TenantEntity;
import org.alfresco.repo.security.authentication.AuthenticationUtil; import org.alfresco.repo.security.authentication.AuthenticationUtil;
@@ -273,9 +274,9 @@ public abstract class AbstractTenantRoutingContentStore extends AbstractRoutingC
} }
@Override @Override
public boolean isStorageClassesSupported(Set<String> storageClasses) public boolean isStorageClassesSupported(StorageClassSet storageClassSet)
{ {
return getTenantContentStore().isStorageClassesSupported(storageClasses); return getTenantContentStore().isStorageClassesSupported(storageClassSet);
} }
@Override @Override
@@ -285,26 +286,26 @@ public abstract class AbstractTenantRoutingContentStore extends AbstractRoutingC
} }
@Override @Override
public void updateStorageClasses(String contentUrl, Set<String> storageClasses, public void updateStorageClasses(String contentUrl, StorageClassSet storageClassSet,
Map<String, Object> parameters) Map<String, Object> parameters)
{ {
getTenantContentStore().updateStorageClasses(contentUrl, storageClasses, parameters); getTenantContentStore().updateStorageClasses(contentUrl, storageClassSet, parameters);
} }
@Override @Override
public Set<String> findStorageClasses(String contentUrl) public StorageClassSet findStorageClasses(String contentUrl)
{ {
return getTenantContentStore().findStorageClasses(contentUrl); return getTenantContentStore().findStorageClasses(contentUrl);
} }
@Override @Override
public Map<Set<String>, Set<Set<String>>> getStorageClassesTransitions() public Map<StorageClassSet, Set<StorageClassSet>> getStorageClassesTransitions()
{ {
return getTenantContentStore().getStorageClassesTransitions(); return getTenantContentStore().getStorageClassesTransitions();
} }
@Override @Override
public Map<Set<String>, Set<Set<String>>> findStorageClassesTransitions(String contentUrl) public Map<StorageClassSet, Set<StorageClassSet>> findStorageClassesTransitions(String contentUrl)
{ {
return getTenantContentStore().findStorageClassesTransitions(contentUrl); return getTenantContentStore().findStorageClassesTransitions(contentUrl);
} }

View File

@@ -31,6 +31,8 @@ import java.util.Map;
import java.util.Set; import java.util.Set;
import org.alfresco.api.AlfrescoPublicApi; import org.alfresco.api.AlfrescoPublicApi;
import org.alfresco.repo.content.ContentStore;
import org.alfresco.repo.content.StorageClassSet;
import org.alfresco.service.Auditable; import org.alfresco.service.Auditable;
import org.alfresco.service.cmr.dictionary.InvalidTypeException; import org.alfresco.service.cmr.dictionary.InvalidTypeException;
import org.alfresco.service.namespace.QName; import org.alfresco.service.namespace.QName;
@@ -177,10 +179,10 @@ public interface ContentService
/** /**
* Checks whether or not the current {@link ContentService} supports the provided {@link Set} storage classes * Checks whether or not the current {@link ContentService} supports the provided {@link Set} storage classes
* *
* @param storageClasses The storage classes that will be checked whether or not are supported * @param storageClassSet The storage classes that will be checked whether or not are supported
* @return true if the storage classes are supported, false otherwise. * @return true if the storage classes are supported, false otherwise.
*/ */
default boolean isStorageClassesSupported(Set<String> storageClasses) default boolean isStorageClassesSupported(StorageClassSet storageClassSet)
{ {
return false; return false;
} }
@@ -197,10 +199,10 @@ public interface ContentService
* Updates the storage class for a {@link NodeRef} * Updates the storage class for a {@link NodeRef}
* *
* @param nodeRef The ref of the node that will have its storage classes updated * @param nodeRef The ref of the node that will have its storage classes updated
* @param storageClasses The new storage classes * @param storageClassSet The new storage classes
* @param parameters extra parameters * @param parameters extra parameters
*/ */
default void updateStorageClasses(NodeRef nodeRef, Set<String> storageClasses, Map<String, Object> parameters) default void updateStorageClasses(NodeRef nodeRef, StorageClassSet storageClassSet, Map<String, Object> parameters)
{ {
} }
@@ -209,16 +211,16 @@ public interface ContentService
* @param nodeRef the {@link NodeRef} for which the storage classes are to be requested * @param nodeRef the {@link NodeRef} for which the storage classes are to be requested
* @return Returns the current storage classes for the given {@link NodeRef} * @return Returns the current storage classes for the given {@link NodeRef}
*/ */
default Set<String> findStorageClasses(NodeRef nodeRef) default StorageClassSet findStorageClasses(NodeRef nodeRef)
{ {
return Collections.emptySet(); return ContentStore.SCS_DEFAULT;
} }
/** /**
* @return Returns the complete collection of allowed storage classes transitions. * @return Returns the complete collection of allowed storage classes transitions.
* The key represents the source storage classes while the value (as a {@link Set}) represents all the possible target storage classes. * The key represents the source storage classes while the value (as a {@link Set}) represents all the possible target storage classes.
*/ */
default Map<Set<String>, Set<Set<String>>> getStorageClassesTransitions() default Map<StorageClassSet, Set<StorageClassSet>> getStorageClassesTransitions()
{ {
return Collections.emptyMap(); return Collections.emptyMap();
} }
@@ -227,7 +229,7 @@ public interface ContentService
* @param nodeRef the {@link NodeRef} for which the storage classes transitions are to be requested * @param nodeRef the {@link NodeRef} for which the storage classes transitions are to be requested
* @return Returns the complete collection of allowed storage classes transitions for the content found at content URL * @return Returns the complete collection of allowed storage classes transitions for the content found at content URL
*/ */
default Map<Set<String>, Set<Set<String>>> findStorageClassesTransitions(NodeRef nodeRef) default Map<StorageClassSet, Set<StorageClassSet>> findStorageClassesTransitions(NodeRef nodeRef)
{ {
return Collections.emptyMap(); return Collections.emptyMap();
} }

View File

@@ -34,7 +34,6 @@ import static org.junit.Assert.fail;
import java.io.File; import java.io.File;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collections; import java.util.Collections;
import java.util.HashSet;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
@@ -182,15 +181,11 @@ public class RoutingContentStoreTest extends AbstractWritableContentStoreTest
writer.putContent(content); writer.putContent(content);
String contentUrl = writer.getContentUrl(); String contentUrl = writer.getContentUrl();
final Set<String> storageClasses = Set.of("a-storage-class");
// Empty storage classes before update
assertTrue(routingStore.findStorageClasses(contentUrl).isEmpty());
// Update storage classes // Update storage classes
routingStore.updateStorageClasses(contentUrl, storageClasses, null); routingStore.updateStorageClasses(contentUrl, ContentStore.SCS_DEFAULT, null);
assertEquals(storageClasses, routingStore.findStorageClasses(contentUrl)); assertEquals(ContentStore.SCS_DEFAULT, routingStore.findStorageClasses(contentUrl));
} }
/** /**
@@ -247,7 +242,7 @@ public class RoutingContentStoreTest extends AbstractWritableContentStoreTest
private static class AnyStorageClassesSupportedStore extends AbstractContentStore private static class AnyStorageClassesSupportedStore extends AbstractContentStore
{ {
FileContentStore fileStore; FileContentStore fileStore;
Set<String> storageClasses = new HashSet<>(); StorageClassSet storageClasses = new StorageClassSet();
public AnyStorageClassesSupportedStore(FileContentStore fileStore) public AnyStorageClassesSupportedStore(FileContentStore fileStore)
{ {
@@ -280,12 +275,12 @@ public class RoutingContentStoreTest extends AbstractWritableContentStoreTest
return true; return true;
} }
public void updateStorageClasses(String contentUrl, Set<String> storageClasses, Map<String, Object> parameters) public void updateStorageClasses(String contentUrl, StorageClassSet storageClasses, Map<String, Object> parameters)
{ {
this.storageClasses = storageClasses; this.storageClasses = storageClasses;
} }
public Set<String> findStorageClasses(String contentUrl) public StorageClassSet findStorageClasses(String contentUrl)
{ {
return this.storageClasses; return this.storageClasses;
} }

View File

@@ -35,7 +35,6 @@ import static org.junit.Assert.assertTrue;
import static org.junit.Assert.fail; import static org.junit.Assert.fail;
import static org.mockito.ArgumentMatchers.any; import static org.mockito.ArgumentMatchers.any;
import static org.mockito.ArgumentMatchers.anyLong; import static org.mockito.ArgumentMatchers.anyLong;
import static org.mockito.ArgumentMatchers.anySet;
import static org.mockito.ArgumentMatchers.anyString; import static org.mockito.ArgumentMatchers.anyString;
import static org.mockito.Mockito.atLeastOnce; import static org.mockito.Mockito.atLeastOnce;
import static org.mockito.Mockito.doThrow; import static org.mockito.Mockito.doThrow;
@@ -48,10 +47,10 @@ import static org.mockito.Mockito.when;
import java.io.IOException; import java.io.IOException;
import java.util.Locale; import java.util.Locale;
import java.util.Set;
import org.alfresco.repo.content.ContentContext; import org.alfresco.repo.content.ContentContext;
import org.alfresco.repo.content.ContentStore; import org.alfresco.repo.content.ContentStore;
import org.alfresco.repo.content.StorageClassSet;
import org.alfresco.repo.content.caching.quota.QuotaManagerStrategy; import org.alfresco.repo.content.caching.quota.QuotaManagerStrategy;
import org.alfresco.repo.content.caching.quota.UnlimitedQuotaStrategy; import org.alfresco.repo.content.caching.quota.UnlimitedQuotaStrategy;
import org.alfresco.repo.content.filestore.SpoofedTextContentReader; import org.alfresco.repo.content.filestore.SpoofedTextContentReader;
@@ -528,11 +527,11 @@ public class CachingContentStoreTest
@Test @Test
public void testBackingStoreIsCalledForSupportedStorageClasses() public void testBackingStoreIsCalledForSupportedStorageClasses()
{ {
when(backingStore.isStorageClassesSupported(anySet())).thenReturn(true); when(backingStore.isStorageClassesSupported(new StorageClassSet("a-certain-storage-class"))).thenReturn(true);
final Set<String> storageClasses = Set.of("a-certain-storage-class"); final StorageClassSet storageClassSet = new StorageClassSet("a-certain-storage-class");
assertTrue(cachingStore.isStorageClassesSupported(storageClasses)); assertTrue(cachingStore.isStorageClassesSupported(storageClassSet));
verify(backingStore, times(1)).isStorageClassesSupported(storageClasses); verify(backingStore, times(1)).isStorageClassesSupported(storageClassSet);
} }
@Test @Test
@@ -547,17 +546,18 @@ public class CachingContentStoreTest
public void testUpdateStorageClassesForGivenContentUrl() public void testUpdateStorageClassesForGivenContentUrl()
{ {
String contentUrl = "contentUrl"; String contentUrl = "contentUrl";
final Set<String> storageClasses = Set.of("a-certain-storage-class"); final StorageClassSet storageClassSet = new StorageClassSet("a-certain-storage-class");
cachingStore.updateStorageClasses(contentUrl, storageClasses, null); cachingStore.updateStorageClasses(contentUrl, storageClassSet, null);
verify(backingStore, times(1)).updateStorageClasses(contentUrl, storageClasses, null); verify(backingStore, times(1)).updateStorageClasses(contentUrl, storageClassSet, null);
} }
@Test @Test
public void testFindStorageClassesForGivenContentUrl() public void testFindStorageClassesForGivenContentUrl()
{ {
when(backingStore.findStorageClasses(anyString())).thenReturn(emptySet()); final StorageClassSet storageClassSet = new StorageClassSet();
when(backingStore.findStorageClasses(anyString())).thenReturn(storageClassSet);
assertTrue(cachingStore.findStorageClasses("a-contentUrl").isEmpty()); assertTrue(cachingStore.findStorageClasses("a-contentUrl").isEmpty());
verify(backingStore, times(1)).findStorageClasses("a-contentUrl"); verify(backingStore, times(1)).findStorageClasses("a-contentUrl");

View File

@@ -34,7 +34,6 @@ import static org.junit.Assert.fail;
import java.io.File; import java.io.File;
import java.nio.ByteBuffer; import java.nio.ByteBuffer;
import java.util.Locale; import java.util.Locale;
import java.util.Set;
import org.alfresco.repo.content.AbstractWritableContentStoreTest; import org.alfresco.repo.content.AbstractWritableContentStoreTest;
import org.alfresco.repo.content.ContentContext; import org.alfresco.repo.content.ContentContext;
@@ -43,6 +42,7 @@ import org.alfresco.repo.content.ContentLimitProvider;
import org.alfresco.repo.content.ContentLimitProvider.SimpleFixedLimitProvider; import org.alfresco.repo.content.ContentLimitProvider.SimpleFixedLimitProvider;
import org.alfresco.repo.content.ContentLimitViolationException; import org.alfresco.repo.content.ContentLimitViolationException;
import org.alfresco.repo.content.ContentStore; import org.alfresco.repo.content.ContentStore;
import org.alfresco.repo.content.StorageClassSet;
import org.alfresco.service.cmr.repository.ContentIOException; import org.alfresco.service.cmr.repository.ContentIOException;
import org.alfresco.service.cmr.repository.ContentReader; import org.alfresco.service.cmr.repository.ContentReader;
import org.alfresco.service.cmr.repository.ContentWriter; import org.alfresco.service.cmr.repository.ContentWriter;
@@ -352,13 +352,13 @@ public class FileContentStoreTest extends AbstractWritableContentStoreTest
@Test @Test
public void testSupportsDefaultStorageClass() public void testSupportsDefaultStorageClass()
{ {
assertTrue(store.isStorageClassesSupported(Set.of(ContentStore.DEFAULT_SC))); assertTrue(store.isStorageClassesSupported(ContentStore.SCS_DEFAULT));
} }
@Test @Test
public void testDoesNotSupportUnknownStorageClass() public void testDoesNotSupportUnknownStorageClass()
{ {
assertFalse(store.isStorageClassesSupported(Set.of("unknown"))); assertFalse(store.isStorageClassesSupported(new StorageClassSet("unknown")));
} }
private void assertDirExists(File root, String dir) private void assertDirExists(File root, String dir)

View File

@@ -44,11 +44,11 @@ import static org.mockito.Mockito.when;
import java.io.File; import java.io.File;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.Set;
import org.alfresco.repo.content.AbstractWritableContentStoreTest; import org.alfresco.repo.content.AbstractWritableContentStoreTest;
import org.alfresco.repo.content.ContentContext; import org.alfresco.repo.content.ContentContext;
import org.alfresco.repo.content.ContentStore; import org.alfresco.repo.content.ContentStore;
import org.alfresco.repo.content.StorageClassSet;
import org.alfresco.repo.content.UnsupportedContentUrlException; import org.alfresco.repo.content.UnsupportedContentUrlException;
import org.alfresco.repo.content.filestore.FileContentStore; import org.alfresco.repo.content.filestore.FileContentStore;
import org.alfresco.service.cmr.repository.ContentReader; import org.alfresco.service.cmr.repository.ContentReader;
@@ -319,7 +319,7 @@ public class AggregatingContentStoreTest extends AbstractWritableContentStoreTes
@Test @Test
public void testIsStorageClassesSupported() public void testIsStorageClassesSupported()
{ {
Set<String> sc = Set.of("a-certain-storage-class"); final StorageClassSet sc = new StorageClassSet("a-certain-storage-class");
when(primaryStoreMock.isStorageClassesSupported(sc)).thenReturn(true); when(primaryStoreMock.isStorageClassesSupported(sc)).thenReturn(true);
assertTrue(aggregatingContentStoreMock.isStorageClassesSupported(sc)); assertTrue(aggregatingContentStoreMock.isStorageClassesSupported(sc));
@@ -330,7 +330,7 @@ public class AggregatingContentStoreTest extends AbstractWritableContentStoreTes
@Test @Test
public void testStorageClassesIsNotSupported() public void testStorageClassesIsNotSupported()
{ {
Set<String> sc = Set.of("a-certain-storage-class"); final StorageClassSet sc = new StorageClassSet("a-certain-storage-class");
when(primaryStoreMock.isStorageClassesSupported(sc)).thenReturn(false); when(primaryStoreMock.isStorageClassesSupported(sc)).thenReturn(false);
assertFalse(aggregatingContentStoreMock.isStorageClassesSupported(sc)); assertFalse(aggregatingContentStoreMock.isStorageClassesSupported(sc));
@@ -352,18 +352,19 @@ public class AggregatingContentStoreTest extends AbstractWritableContentStoreTes
public void testUpdateStorageClassesForGivenContentUrl() public void testUpdateStorageClassesForGivenContentUrl()
{ {
String contentUrl = "contentUrl"; String contentUrl = "contentUrl";
final Set<String> storageClasses = Set.of("a-certain-storage-class"); final StorageClassSet sc = new StorageClassSet("a-certain-storage-class");
aggregatingContentStoreMock.updateStorageClasses(contentUrl, storageClasses, null); aggregatingContentStoreMock.updateStorageClasses(contentUrl, sc, null);
verify(primaryStoreMock, times(1)).updateStorageClasses(contentUrl, storageClasses, null); verify(primaryStoreMock, times(1)).updateStorageClasses(contentUrl, sc, null);
verifyNoInteractions(secondaryStoreMock); verifyNoInteractions(secondaryStoreMock);
} }
@Test @Test
public void testFindStorageClassesForGivenContentUrlInPrimaryStore() public void testFindStorageClassesForGivenContentUrlInPrimaryStore()
{ {
when(primaryStoreMock.findStorageClasses(anyString())).thenReturn(emptySet()); final StorageClassSet sc = new StorageClassSet();
when(primaryStoreMock.findStorageClasses(anyString())).thenReturn(sc);
assertTrue(aggregatingContentStoreMock.findStorageClasses("a-contentUrl").isEmpty()); assertTrue(aggregatingContentStoreMock.findStorageClasses("a-contentUrl").isEmpty());
verify(primaryStoreMock, times(1)).findStorageClasses("a-contentUrl"); verify(primaryStoreMock, times(1)).findStorageClasses("a-contentUrl");
@@ -373,11 +374,12 @@ public class AggregatingContentStoreTest extends AbstractWritableContentStoreTes
@Test @Test
public void testFindStorageClassesForGivenContentUrlInSecondaryStore() public void testFindStorageClassesForGivenContentUrlInSecondaryStore()
{ {
final StorageClassSet sc = new StorageClassSet();
UnsupportedContentUrlException unsupportedContentUrlExc = new UnsupportedContentUrlException( UnsupportedContentUrlException unsupportedContentUrlExc = new UnsupportedContentUrlException(
aggregatingContentStoreMock, ""); aggregatingContentStoreMock, "");
when(primaryStoreMock.findStorageClasses(anyString())).thenThrow(unsupportedContentUrlExc); when(primaryStoreMock.findStorageClasses(anyString())).thenThrow(unsupportedContentUrlExc);
when(secondaryStoreMock.findStorageClasses(anyString())).thenReturn(emptySet()); when(secondaryStoreMock.findStorageClasses(anyString())).thenReturn(sc);
assertTrue(aggregatingContentStoreMock.findStorageClasses("a-contentUrl").isEmpty()); assertTrue(aggregatingContentStoreMock.findStorageClasses("a-contentUrl").isEmpty());
verify(primaryStoreMock, times(1)).findStorageClasses("a-contentUrl"); verify(primaryStoreMock, times(1)).findStorageClasses("a-contentUrl");

View File

@@ -26,7 +26,6 @@
package org.alfresco.repo.tenant; package org.alfresco.repo.tenant;
import java.io.Serializable; import java.io.Serializable;
import java.util.Collections;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
@@ -35,6 +34,7 @@ import org.alfresco.error.AlfrescoRuntimeException;
import org.alfresco.model.ContentModel; import org.alfresco.model.ContentModel;
import org.alfresco.repo.content.ContentStore; import org.alfresco.repo.content.ContentStore;
import org.alfresco.repo.content.MimetypeMap; import org.alfresco.repo.content.MimetypeMap;
import org.alfresco.repo.content.StorageClassSet;
import org.alfresco.repo.security.authentication.AuthenticationUtil; import org.alfresco.repo.security.authentication.AuthenticationUtil;
import org.alfresco.repo.transaction.AlfrescoTransactionSupport; import org.alfresco.repo.transaction.AlfrescoTransactionSupport;
import org.alfresco.repo.transaction.RetryingTransactionHelper.RetryingTransactionCallback; import org.alfresco.repo.transaction.RetryingTransactionHelper.RetryingTransactionCallback;
@@ -120,7 +120,7 @@ public class AbstractTenantRoutingContentStoreTest extends TestCase
public void testIsStorageClassesSupported() public void testIsStorageClassesSupported()
{ {
assertTrue(fileContentStore.isStorageClassesSupported(Collections.emptySet())); assertTrue(fileContentStore.isStorageClassesSupported(new StorageClassSet()));
} }
public void testGetSupportedStorageClasses() public void testGetSupportedStorageClasses()

View File

@@ -180,7 +180,7 @@ public class ContentServiceImplTest extends BaseVersionStoreTest
final NodeRef newNode = createNewNode(); final NodeRef newNode = createNewNode();
final Set<String> storageClasses = contentService.findStorageClasses(newNode); final Set<String> storageClasses = contentService.findStorageClasses(newNode);
assertEquals(1, storageClasses.size()); assertEquals(1, storageClasses.size());
assertTrue(storageClasses.contains(ContentStore.DEFAULT_SC)); assertEquals(storageClasses, ContentStore.SCS_DEFAULT);
} }
@Test @Test

View File

@@ -34,6 +34,7 @@ import static org.mockito.Mockito.when;
import org.alfresco.repo.content.ContentServiceImpl; import org.alfresco.repo.content.ContentServiceImpl;
import org.alfresco.repo.content.ContentStore; import org.alfresco.repo.content.ContentStore;
import org.alfresco.repo.content.StorageClassSet;
import org.alfresco.service.cmr.repository.ContentService; import org.alfresco.service.cmr.repository.ContentService;
import org.junit.Before; import org.junit.Before;
import org.junit.Test; import org.junit.Test;
@@ -65,9 +66,10 @@ public class ContentServiceImplWithMockedContentStoreTest
@Test @Test
public void testStoreIsCalledForIsStorageClassesSupported() public void testStoreIsCalledForIsStorageClassesSupported()
{ {
when(store.isStorageClassesSupported(emptySet())).thenReturn(true); final StorageClassSet sc = new StorageClassSet();
assertTrue(contentService.isStorageClassesSupported(emptySet())); when(store.isStorageClassesSupported(sc)).thenReturn(true);
verify(store, times(1)).isStorageClassesSupported(emptySet()); assertTrue(contentService.isStorageClassesSupported(sc));
verify(store, times(1)).isStorageClassesSupported(sc);
} }
@Test @Test