2016-02-10 15:15:01 +01:00
|
|
|
/**
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
package org.gcube.documentstore.persistence;
|
|
|
|
|
|
|
|
import java.util.concurrent.TimeUnit;
|
|
|
|
|
|
|
|
import org.gcube.accounting.datamodel.UsageRecord;
|
2017-07-31 15:39:45 +02:00
|
|
|
import org.gcube.accounting.datamodel.usagerecords.TestUsageRecord;
|
2016-02-10 15:15:01 +01:00
|
|
|
import org.gcube.documentstore.exception.InvalidValueException;
|
2019-02-28 16:28:11 +01:00
|
|
|
import org.gcube.testutility.ContextTest;
|
2016-02-17 14:17:31 +01:00
|
|
|
import org.gcube.testutility.StressTestUtility;
|
|
|
|
import org.gcube.testutility.TestOperation;
|
2016-02-10 15:15:01 +01:00
|
|
|
import org.junit.Test;
|
|
|
|
import org.slf4j.Logger;
|
|
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
|
|
|
|
/**
|
2016-10-12 14:24:02 +02:00
|
|
|
* @author Luca Frosini (ISTI - CNR)
|
2016-02-10 15:15:01 +01:00
|
|
|
*
|
|
|
|
*/
|
2019-02-28 16:28:11 +01:00
|
|
|
public class PersistenceBackendMonitorTest extends ContextTest {
|
2016-02-10 15:15:01 +01:00
|
|
|
|
|
|
|
private static final Logger logger = LoggerFactory.getLogger(PersistenceBackendMonitorTest.class);
|
|
|
|
|
|
|
|
public static final long timeout = 5000;
|
|
|
|
public static final TimeUnit timeUnit = TimeUnit.MILLISECONDS;
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void parsingTest() throws Exception {
|
|
|
|
PersistenceBackendFactory.setFallbackLocation(null);
|
2019-02-28 16:28:11 +01:00
|
|
|
final PersistenceBackend persistence = PersistenceBackendFactory.getPersistenceBackend(ContextTest.getCurrentContext());
|
2016-02-10 15:15:01 +01:00
|
|
|
|
|
|
|
StressTestUtility.stressTest(new TestOperation() {
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void operate(int i) {
|
|
|
|
UsageRecord usageRecord = null;
|
|
|
|
switch (i%3) {
|
|
|
|
case 0:
|
2016-02-10 16:49:09 +01:00
|
|
|
usageRecord = TestUsageRecord.createTestServiceUsageRecord();
|
2016-02-10 15:15:01 +01:00
|
|
|
break;
|
|
|
|
case 1:
|
2016-02-10 16:49:09 +01:00
|
|
|
usageRecord = TestUsageRecord.createTestStorageUsageRecord();
|
2016-02-10 15:15:01 +01:00
|
|
|
break;
|
|
|
|
case 2:
|
2016-02-10 16:49:09 +01:00
|
|
|
usageRecord = TestUsageRecord.createTestJobUsageRecord();
|
2016-02-10 15:15:01 +01:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
try {
|
|
|
|
persistence.account(usageRecord);
|
|
|
|
} catch (InvalidValueException e) {
|
|
|
|
throw new RuntimeException(e);
|
|
|
|
}
|
|
|
|
}
|
2018-01-08 12:50:35 +01:00
|
|
|
}, 3);
|
2016-02-10 15:15:01 +01:00
|
|
|
|
|
|
|
logger.debug(" START -----------------------------------------------");
|
|
|
|
logger.debug("Flushing the buffered records");
|
2017-07-14 16:40:11 +02:00
|
|
|
persistence.flush();
|
2016-02-10 15:15:01 +01:00
|
|
|
logger.debug(" END -----------------------------------------------");
|
|
|
|
|
2019-02-28 16:28:11 +01:00
|
|
|
PersistenceBackend persistenceBackend = PersistenceBackendFactory.getPersistenceBackend(ContextTest.getCurrentContext());
|
2016-02-10 15:15:01 +01:00
|
|
|
|
2018-01-08 12:50:35 +01:00
|
|
|
if(persistenceBackend instanceof FallbackPersistenceBackend) {
|
|
|
|
/* This line has no sense in real scenario is only used to avoid null pointer exception in test because
|
|
|
|
* the test has no time to get the real persistence
|
|
|
|
*/
|
|
|
|
persistenceBackend.setFallback((FallbackPersistenceBackend) persistenceBackend);
|
|
|
|
}
|
2016-02-10 15:15:01 +01:00
|
|
|
|
2018-01-08 12:50:35 +01:00
|
|
|
FallbackMonitor fallbackMonitor = new FallbackMonitor(persistenceBackend, false);
|
|
|
|
fallbackMonitor.run();
|
|
|
|
|
|
|
|
logger.debug("{} finished", FallbackMonitor.class.getSimpleName());
|
2016-02-10 15:15:01 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void singleParsingTest() throws Exception {
|
|
|
|
PersistenceBackendFactory.setFallbackLocation(null);
|
2019-02-28 16:28:11 +01:00
|
|
|
PersistenceBackend persistenceBackend = PersistenceBackendFactory.getPersistenceBackend(ContextTest.getCurrentContext());
|
2018-01-08 12:50:35 +01:00
|
|
|
if(persistenceBackend instanceof FallbackPersistenceBackend) {
|
|
|
|
/* This line has no sense in real scenario is only used to avoid null pointer exception in test because
|
|
|
|
* the test has no time to get the real persistence
|
|
|
|
*/
|
|
|
|
persistenceBackend.setFallback((FallbackPersistenceBackend) persistenceBackend);
|
|
|
|
}
|
|
|
|
FallbackMonitor fallbackMonitor = new FallbackMonitor(persistenceBackend);
|
|
|
|
fallbackMonitor.run();
|
2016-02-10 15:15:01 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|