2016-02-10 15:34:17 +01:00
|
|
|
/**
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
package org.gcube.accounting.persistence;
|
|
|
|
|
|
|
|
import java.io.StringWriter;
|
|
|
|
import java.util.Calendar;
|
|
|
|
|
|
|
|
import org.gcube.accounting.datamodel.BasicUsageRecord;
|
|
|
|
import org.gcube.common.authorization.library.provider.SecurityTokenProvider;
|
|
|
|
import org.gcube.common.resources.gcore.Resource;
|
|
|
|
import org.gcube.common.resources.gcore.Resources;
|
|
|
|
import org.gcube.common.resources.gcore.ServiceEndpoint;
|
|
|
|
import org.gcube.documentstore.persistence.PersistenceBackend;
|
|
|
|
import org.gcube.documentstore.persistence.PersistenceBackendFactory;
|
|
|
|
import org.gcube.documentstore.persistence.PersistenceMongoDB;
|
|
|
|
import org.gcube.informationsystem.publisher.RegistryPublisher;
|
|
|
|
import org.gcube.informationsystem.publisher.RegistryPublisherFactory;
|
2016-02-10 16:49:09 +01:00
|
|
|
import org.gcube.utils.TestUtility;
|
2016-02-10 15:34:17 +01:00
|
|
|
import org.junit.After;
|
|
|
|
import org.junit.Assert;
|
|
|
|
import org.junit.Before;
|
|
|
|
import org.junit.Test;
|
|
|
|
import org.slf4j.Logger;
|
|
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @author Luca Frosini (ISTI - CNR) http://www.lucafrosini.com/
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public class PersistenceMongoDBTest {
|
|
|
|
|
|
|
|
private static final Logger logger = LoggerFactory.getLogger(PersistenceMongoDBTest.class);
|
|
|
|
|
|
|
|
@Before
|
|
|
|
public void before() throws Exception {
|
|
|
|
SecurityTokenProvider.instance.set(TestUtility.TOKEN);
|
|
|
|
}
|
|
|
|
|
|
|
|
@After
|
|
|
|
public void after(){
|
|
|
|
SecurityTokenProvider.instance.reset();
|
|
|
|
}
|
|
|
|
|
|
|
|
public static PersistenceBackend getPersistence(){
|
|
|
|
PersistenceBackendFactory.setFallbackLocation(null);
|
|
|
|
return PersistenceBackendFactory.getPersistenceBackend(BasicUsageRecord.getScopeFromToken());
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void persistenceIsMongoDB() {
|
|
|
|
PersistenceBackend accountingPersistence = getPersistence();
|
|
|
|
Assert.assertTrue(accountingPersistence instanceof PersistenceMongoDB);
|
|
|
|
}
|
|
|
|
|
|
|
|
private static void publishResource(Resource resource) throws Exception {
|
|
|
|
StringWriter stringWriter = new StringWriter();
|
|
|
|
Resources.marshal(resource, stringWriter);
|
|
|
|
|
|
|
|
RegistryPublisher registryPublisher = RegistryPublisherFactory.create();
|
|
|
|
|
|
|
|
try {
|
|
|
|
logger.debug("Trying to publish to {}:\n{}", BasicUsageRecord.getScopeFromToken(), stringWriter);
|
|
|
|
registryPublisher.create(resource);
|
|
|
|
} catch (Exception e) {
|
|
|
|
logger.error("The resource was not published", e);
|
|
|
|
throw e;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private static void unPublishResource(Resource resource) throws Exception {
|
|
|
|
//StringWriter stringWriter = new StringWriter();
|
|
|
|
//Resources.marshal(resource, stringWriter);
|
|
|
|
|
|
|
|
RegistryPublisher registryPublisher = RegistryPublisherFactory.create();
|
|
|
|
|
|
|
|
String id = resource.id();
|
|
|
|
logger.debug("Trying to remove {} with ID {} from {}",
|
|
|
|
resource.getClass().getSimpleName(), id,
|
|
|
|
BasicUsageRecord.getScopeFromToken());
|
|
|
|
|
|
|
|
registryPublisher.remove(resource);
|
|
|
|
|
|
|
|
logger.debug("{} with ID {} removed successfully", resource.getClass().getSimpleName(), id);
|
|
|
|
}
|
|
|
|
|
|
|
|
public void testScopeRecheck() throws Exception {
|
|
|
|
ServiceEndpoint serviceEndpoint = null;
|
|
|
|
try {
|
|
|
|
AccountingPersistenceConfiguration persitenceConfiguration = new AccountingPersistenceConfiguration(PersistenceMongoDB.class);
|
|
|
|
serviceEndpoint = persitenceConfiguration.getServiceEndpoint(
|
|
|
|
AccountingPersistenceConfiguration.SERVICE_ENDPOINT_CATEGORY, AccountingPersistenceConfiguration.SERVICE_ENDPOINT_NAME,
|
|
|
|
PersistenceMongoDB.class);
|
|
|
|
unPublishResource(serviceEndpoint);
|
|
|
|
} catch(IndexOutOfBoundsException e){
|
|
|
|
SecurityTokenProvider.instance.set(TestUtility.PARENT_TOKEN);
|
|
|
|
AccountingPersistenceConfiguration persitenceConfiguration = new AccountingPersistenceConfiguration(PersistenceMongoDB.class);
|
|
|
|
serviceEndpoint = persitenceConfiguration.getServiceEndpoint(
|
|
|
|
AccountingPersistenceConfiguration.SERVICE_ENDPOINT_CATEGORY,
|
|
|
|
AccountingPersistenceConfiguration.SERVICE_ENDPOINT_NAME,
|
|
|
|
PersistenceMongoDB.class);
|
|
|
|
SecurityTokenProvider.instance.set(TestUtility.TOKEN);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
long startTime = Calendar.getInstance().getTimeInMillis();
|
|
|
|
long endTime = startTime;
|
|
|
|
while(endTime <= (startTime + 10*1000)){ // 10 sec
|
|
|
|
endTime = Calendar.getInstance().getTimeInMillis();
|
|
|
|
}
|
|
|
|
|
|
|
|
logger.debug("Going to check First Time");
|
|
|
|
PersistenceBackend first = PersistenceBackendFactory.getPersistenceBackend(BasicUsageRecord.getScopeFromToken());
|
|
|
|
logger.debug("First {} : {}", PersistenceBackend.class.getSimpleName(), first);
|
|
|
|
|
|
|
|
publishResource(serviceEndpoint);
|
|
|
|
|
|
|
|
startTime = Calendar.getInstance().getTimeInMillis();
|
|
|
|
endTime = startTime;
|
|
|
|
while(endTime <= (startTime + (PersistenceBackendFactory.FALLBACK_RETRY_TIME + 100))){
|
|
|
|
endTime = Calendar.getInstance().getTimeInMillis();
|
|
|
|
}
|
|
|
|
|
|
|
|
logger.debug("Going to check Second Time");
|
|
|
|
PersistenceBackend second = PersistenceBackendFactory.getPersistenceBackend(BasicUsageRecord.getScopeFromToken());
|
|
|
|
logger.debug("Second {} : {}", PersistenceBackend.class.getSimpleName(), second);
|
|
|
|
|
|
|
|
Assert.assertNotEquals(first, second);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|