accounting-analytics-persis.../src/test/java/org/gcube/accounting/analytics/persistence/postgresql/AccountingPersistenceQueryP...

557 lines
23 KiB
Java
Raw Normal View History

2021-03-15 17:01:09 +01:00
/**
*
*/
package org.gcube.accounting.analytics.persistence.postgresql;
2021-03-16 15:33:34 +01:00
import java.util.ArrayList;
2021-03-16 10:37:52 +01:00
import java.util.Calendar;
2021-11-22 14:19:12 +01:00
import java.util.Collection;
2021-03-31 10:06:20 +02:00
import java.util.HashMap;
import java.util.HashSet;
2021-03-16 15:33:34 +01:00
import java.util.List;
2021-03-31 10:06:20 +02:00
import java.util.Map;
import java.util.Set;
2021-03-17 14:56:27 +01:00
import java.util.SortedMap;
2021-03-19 15:55:06 +01:00
import java.util.SortedSet;
2021-03-16 10:37:52 +01:00
2021-03-16 15:33:34 +01:00
import org.gcube.accounting.analytics.Filter;
2021-03-17 14:56:27 +01:00
import org.gcube.accounting.analytics.Info;
2021-03-19 15:55:06 +01:00
import org.gcube.accounting.analytics.NumberedFilter;
2021-03-16 10:37:52 +01:00
import org.gcube.accounting.analytics.TemporalConstraint;
import org.gcube.accounting.analytics.TemporalConstraint.AggregationMode;
import org.gcube.accounting.analytics.exception.DuplicatedKeyFilterException;
import org.gcube.accounting.analytics.exception.KeyException;
import org.gcube.accounting.analytics.exception.ValueException;
2021-03-17 14:56:27 +01:00
import org.gcube.accounting.analytics.persistence.AccountingPersistenceBackendQueryConfiguration;
2021-03-22 11:53:12 +01:00
import org.gcube.accounting.analytics.persistence.AccountingPersistenceQuery;
2021-11-22 18:23:12 +01:00
import org.gcube.accounting.analytics.persistence.AccountingPersistenceQueryFactory;
2021-03-16 15:33:34 +01:00
import org.gcube.accounting.datamodel.UsageRecord;
2021-03-30 22:35:51 +02:00
import org.gcube.accounting.datamodel.aggregation.AggregatedJobUsageRecord;
2021-03-16 10:37:52 +01:00
import org.gcube.accounting.datamodel.aggregation.AggregatedServiceUsageRecord;
2021-11-22 14:19:12 +01:00
import org.gcube.accounting.datamodel.aggregation.AggregatedStorageStatusRecord;
2021-03-29 11:45:48 +02:00
import org.gcube.accounting.datamodel.aggregation.AggregatedStorageUsageRecord;
import org.gcube.accounting.datamodel.basetypes.AbstractStorageUsageRecord.DataType;
2021-03-22 18:08:35 +01:00
import org.gcube.accounting.utility.postgresql.RecordToDBMapping;
2021-03-30 22:35:51 +02:00
import org.gcube.documentstore.records.AggregatedRecord;
2021-03-22 18:08:35 +01:00
import org.gcube.documentstore.records.Record;
2021-03-17 14:56:27 +01:00
import org.junit.Before;
2021-03-15 17:01:09 +01:00
import org.junit.Test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* @author Luca Frosini (ISTI - CNR)
*/
public class AccountingPersistenceQueryPostgreSQLTest extends ContextTest {
private static final Logger logger = LoggerFactory.getLogger(AccountingPersistenceQueryPostgreSQLTest.class);
2021-03-17 14:56:27 +01:00
protected AccountingPersistenceQueryPostgreSQL accountingPersistenceQueryPostgreSQL;
@Before
public void before() throws Exception {
AccountingPersistenceBackendQueryConfiguration configuration = new AccountingPersistenceBackendQueryConfiguration(
AccountingPersistenceQueryPostgreSQL.class);
accountingPersistenceQueryPostgreSQL = new AccountingPersistenceQueryPostgreSQL();
accountingPersistenceQueryPostgreSQL.prepareConnection(configuration);
}
2021-11-22 12:48:34 +01:00
protected List<Filter> getFilters(){
List<Filter> filters = new ArrayList<>();
2021-03-31 10:06:20 +02:00
String user = QueryTest.getRandomUser();
logger.debug("Going to query filtering with user {}", user);
Filter filter = new Filter(UsageRecord.CONSUMER_ID, user);
filters.add(filter);
return filters;
}
2021-03-30 22:35:51 +02:00
protected TemporalConstraint getTemporalConstraint() {
2021-03-16 10:37:52 +01:00
Calendar startTimeCalendar = Calendar.getInstance();
2021-11-26 17:24:33 +01:00
startTimeCalendar.setTimeZone(TemporalConstraint.DEFAULT_TIME_ZONE);
2021-03-30 22:35:51 +02:00
startTimeCalendar.set(Calendar.YEAR, 2015);
2021-03-31 17:49:49 +02:00
startTimeCalendar.set(Calendar.MONTH, Calendar.JANUARY);
startTimeCalendar.set(Calendar.DAY_OF_MONTH, 1);
startTimeCalendar.set(Calendar.HOUR_OF_DAY, 0);
startTimeCalendar.set(Calendar.MINUTE, 0);
2021-03-16 10:37:52 +01:00
Calendar entTimeCalendar = Calendar.getInstance();
2021-11-26 17:24:33 +01:00
entTimeCalendar.setTimeZone(TemporalConstraint.DEFAULT_TIME_ZONE);
2021-03-30 22:35:51 +02:00
entTimeCalendar.set(Calendar.YEAR, 2021);
2021-03-16 10:37:52 +01:00
entTimeCalendar.set(Calendar.MONTH, Calendar.MARCH);
2021-03-30 22:35:51 +02:00
entTimeCalendar.set(Calendar.DAY_OF_MONTH, 1);
entTimeCalendar.set(Calendar.HOUR_OF_DAY, 0);
entTimeCalendar.set(Calendar.MINUTE, 0);
2021-03-31 17:49:49 +02:00
TemporalConstraint temporalConstraint = new TemporalConstraint(startTimeCalendar.getTimeInMillis(), entTimeCalendar.getTimeInMillis(), AggregationMode.MONTHLY);
2021-03-30 22:35:51 +02:00
return temporalConstraint;
}
2021-03-31 10:06:20 +02:00
protected List<Class<? extends AggregatedRecord<?, ?>>> getClassesToTest(){
List<Class<? extends AggregatedRecord<?, ?>>> classes = new ArrayList<Class<? extends AggregatedRecord<?, ?>>>();
classes.add(AggregatedServiceUsageRecord.class);
classes.add(AggregatedStorageUsageRecord.class);
classes.add(AggregatedJobUsageRecord.class);
return classes;
}
2021-11-26 17:24:33 +01:00
@Test
public void testGetNoContextTimeSeriesYearly() throws Exception {
List<Filter> filters = getFilters();
AggregationMode aggregationMode = AggregationMode.YEARLY;
Calendar startTimeCalendar = Calendar.getInstance();
startTimeCalendar.setTimeZone(TemporalConstraint.DEFAULT_TIME_ZONE);
startTimeCalendar.set(Calendar.YEAR, 2015);
startTimeCalendar.set(Calendar.MONTH, Calendar.JANUARY);
startTimeCalendar.set(Calendar.DAY_OF_MONTH, 1);
startTimeCalendar.set(Calendar.HOUR_OF_DAY, 0);
startTimeCalendar.set(Calendar.MINUTE, 0);
Calendar entTimeCalendar = Calendar.getInstance();
entTimeCalendar.setTimeZone(TemporalConstraint.DEFAULT_TIME_ZONE);
entTimeCalendar.set(Calendar.YEAR, 2021);
entTimeCalendar.set(Calendar.MONTH, Calendar.DECEMBER);
entTimeCalendar.set(Calendar.DAY_OF_MONTH, 31);
entTimeCalendar.set(Calendar.HOUR_OF_DAY, 0);
entTimeCalendar.set(Calendar.MINUTE, 0);
TemporalConstraint temporalConstraint = new TemporalConstraint(startTimeCalendar.getTimeInMillis(), entTimeCalendar.getTimeInMillis(), aggregationMode);
Class<? extends AggregatedRecord<?, ?>> clz = AggregatedServiceUsageRecord.class;
logger.debug("----------------------------------------------------------------------");
logger.debug("Going to query {} - Aggregation Mode {}\n", RecordToDBMapping.getRecordTypeByClass(clz), aggregationMode.name());
temporalConstraint.setAggregationMode(aggregationMode);
accountingPersistenceQueryPostgreSQL.setRequestedRecords(clz);
accountingPersistenceQueryPostgreSQL.setTemporalConstraint(temporalConstraint);
accountingPersistenceQueryPostgreSQL.setFilters(filters);
SortedMap<Calendar, Info> timeseries = accountingPersistenceQueryPostgreSQL.getTimeSeries();
for(Calendar c : timeseries.keySet()) {
Info info = timeseries.get(c);
logger.debug("{}", info);
}
}
@Test
public void testGetNoContextTimeSeriesMonthly() throws Exception {
List<Filter> filters = getFilters();
AggregationMode aggregationMode = AggregationMode.MONTHLY;
Calendar startTimeCalendar = Calendar.getInstance();
startTimeCalendar.setTimeZone(TemporalConstraint.DEFAULT_TIME_ZONE);
startTimeCalendar.set(Calendar.YEAR, 2015);
startTimeCalendar.set(Calendar.MONTH, Calendar.JANUARY);
startTimeCalendar.set(Calendar.DAY_OF_MONTH, 1);
startTimeCalendar.set(Calendar.HOUR_OF_DAY, 0);
startTimeCalendar.set(Calendar.MINUTE, 0);
Calendar entTimeCalendar = Calendar.getInstance();
entTimeCalendar.setTimeZone(TemporalConstraint.DEFAULT_TIME_ZONE);
entTimeCalendar.set(Calendar.YEAR, 2021);
entTimeCalendar.set(Calendar.MONTH, Calendar.NOVEMBER);
entTimeCalendar.set(Calendar.DAY_OF_MONTH, 1);
entTimeCalendar.set(Calendar.HOUR_OF_DAY, 0);
entTimeCalendar.set(Calendar.MINUTE, 0);
TemporalConstraint temporalConstraint = new TemporalConstraint(startTimeCalendar.getTimeInMillis(), entTimeCalendar.getTimeInMillis(), aggregationMode);
Class<? extends AggregatedRecord<?, ?>> clz = AggregatedServiceUsageRecord.class;
logger.debug("----------------------------------------------------------------------");
logger.debug("Going to query {} - Aggregation Mode {}\n", RecordToDBMapping.getRecordTypeByClass(clz), aggregationMode.name());
temporalConstraint.setAggregationMode(aggregationMode);
accountingPersistenceQueryPostgreSQL.setRequestedRecords(clz);
accountingPersistenceQueryPostgreSQL.setTemporalConstraint(temporalConstraint);
accountingPersistenceQueryPostgreSQL.setFilters(filters);
SortedMap<Calendar, Info> timeseries = accountingPersistenceQueryPostgreSQL.getTimeSeries();
for(Calendar c : timeseries.keySet()) {
Info info = timeseries.get(c);
logger.debug("{}", info);
}
}
@Test
public void testGetNoContextTimeSeriesDaily() throws Exception {
List<Filter> filters = getFilters();
AggregationMode aggregationMode = AggregationMode.DAILY;
Calendar startTimeCalendar = Calendar.getInstance();
startTimeCalendar.setTimeZone(TemporalConstraint.DEFAULT_TIME_ZONE);
startTimeCalendar.set(Calendar.YEAR, 2021);
startTimeCalendar.set(Calendar.MONTH, Calendar.OCTOBER);
startTimeCalendar.set(Calendar.DAY_OF_MONTH, 26);
startTimeCalendar.set(Calendar.HOUR_OF_DAY, 0);
startTimeCalendar.set(Calendar.MINUTE, 0);
Calendar entTimeCalendar = Calendar.getInstance();
entTimeCalendar.setTimeZone(TemporalConstraint.DEFAULT_TIME_ZONE);
entTimeCalendar.set(Calendar.YEAR, 2021);
entTimeCalendar.set(Calendar.MONTH, Calendar.NOVEMBER);
entTimeCalendar.set(Calendar.DAY_OF_MONTH, 26);
entTimeCalendar.set(Calendar.HOUR_OF_DAY, 0);
entTimeCalendar.set(Calendar.MINUTE, 0);
TemporalConstraint temporalConstraint = new TemporalConstraint(startTimeCalendar.getTimeInMillis(), entTimeCalendar.getTimeInMillis(), aggregationMode);
Class<? extends AggregatedRecord<?, ?>> clz = AggregatedServiceUsageRecord.class;
logger.debug("----------------------------------------------------------------------");
logger.debug("Going to query {} - Aggregation Mode {}\n", RecordToDBMapping.getRecordTypeByClass(clz), aggregationMode.name());
temporalConstraint.setAggregationMode(aggregationMode);
accountingPersistenceQueryPostgreSQL.setRequestedRecords(clz);
accountingPersistenceQueryPostgreSQL.setTemporalConstraint(temporalConstraint);
accountingPersistenceQueryPostgreSQL.setFilters(filters);
SortedMap<Calendar, Info> timeseries = accountingPersistenceQueryPostgreSQL.getTimeSeries();
for(Calendar c : timeseries.keySet()) {
Info info = timeseries.get(c);
logger.debug("{}", info);
}
}
@Test
public void testGetNoContextTimeSeriesHourly() throws Exception {
List<Filter> filters = getFilters();
AggregationMode aggregationMode = AggregationMode.HOURLY;
Calendar startTimeCalendar = Calendar.getInstance();
startTimeCalendar.setTimeZone(TemporalConstraint.DEFAULT_TIME_ZONE);
startTimeCalendar.set(Calendar.YEAR, 2021);
startTimeCalendar.set(Calendar.MONTH, Calendar.NOVEMBER);
startTimeCalendar.set(Calendar.DAY_OF_MONTH, 26);
startTimeCalendar.set(Calendar.HOUR_OF_DAY, 00);
startTimeCalendar.set(Calendar.MINUTE, 0);
Calendar entTimeCalendar = Calendar.getInstance();
entTimeCalendar.setTimeZone(TemporalConstraint.DEFAULT_TIME_ZONE);
entTimeCalendar.set(Calendar.YEAR, 2021);
entTimeCalendar.set(Calendar.MONTH, Calendar.NOVEMBER);
entTimeCalendar.set(Calendar.DAY_OF_MONTH, 26);
entTimeCalendar.set(Calendar.HOUR_OF_DAY, 23);
entTimeCalendar.set(Calendar.MINUTE, 0);
TemporalConstraint temporalConstraint = new TemporalConstraint(startTimeCalendar.getTimeInMillis(), entTimeCalendar.getTimeInMillis(), aggregationMode);
Class<? extends AggregatedRecord<?, ?>> clz = AggregatedServiceUsageRecord.class;
logger.debug("----------------------------------------------------------------------");
logger.debug("Going to query {} - Aggregation Mode {}\n", RecordToDBMapping.getRecordTypeByClass(clz), aggregationMode.name());
temporalConstraint.setAggregationMode(aggregationMode);
accountingPersistenceQueryPostgreSQL.setRequestedRecords(clz);
accountingPersistenceQueryPostgreSQL.setTemporalConstraint(temporalConstraint);
accountingPersistenceQueryPostgreSQL.setFilters(filters);
SortedMap<Calendar, Info> timeseries = accountingPersistenceQueryPostgreSQL.getTimeSeries();
for(Calendar c : timeseries.keySet()) {
Info info = timeseries.get(c);
logger.debug("{}", info);
}
}
@Test
public void testGetNoContextTimeSeriesMinutely() throws Exception {
List<Filter> filters = getFilters();
AggregationMode aggregationMode = AggregationMode.MINUTELY;
Calendar startTimeCalendar = Calendar.getInstance();
startTimeCalendar.setTimeZone(TemporalConstraint.DEFAULT_TIME_ZONE);
startTimeCalendar.set(Calendar.YEAR, 2021);
startTimeCalendar.set(Calendar.MONTH, Calendar.NOVEMBER);
startTimeCalendar.set(Calendar.DAY_OF_MONTH, 26);
startTimeCalendar.set(Calendar.HOUR_OF_DAY, 17);
startTimeCalendar.set(Calendar.MINUTE, 15);
Calendar entTimeCalendar = Calendar.getInstance();
entTimeCalendar.setTimeZone(TemporalConstraint.DEFAULT_TIME_ZONE);
entTimeCalendar.set(Calendar.YEAR, 2021);
entTimeCalendar.set(Calendar.MONTH, Calendar.NOVEMBER);
entTimeCalendar.set(Calendar.DAY_OF_MONTH, 26);
entTimeCalendar.set(Calendar.HOUR_OF_DAY, 17);
entTimeCalendar.set(Calendar.MINUTE, 15);
TemporalConstraint temporalConstraint = new TemporalConstraint(startTimeCalendar.getTimeInMillis(), entTimeCalendar.getTimeInMillis(), aggregationMode);
Class<? extends AggregatedRecord<?, ?>> clz = AggregatedServiceUsageRecord.class;
logger.debug("----------------------------------------------------------------------");
logger.debug("Going to query {} - Aggregation Mode {}\n", RecordToDBMapping.getRecordTypeByClass(clz), aggregationMode.name());
temporalConstraint.setAggregationMode(aggregationMode);
accountingPersistenceQueryPostgreSQL.setRequestedRecords(clz);
accountingPersistenceQueryPostgreSQL.setTemporalConstraint(temporalConstraint);
accountingPersistenceQueryPostgreSQL.setFilters(filters);
SortedMap<Calendar, Info> timeseries = accountingPersistenceQueryPostgreSQL.getTimeSeries();
for(Calendar c : timeseries.keySet()) {
Info info = timeseries.get(c);
logger.debug("{}", info);
}
}
2021-03-30 22:35:51 +02:00
@Test
2021-03-31 10:06:20 +02:00
public void testGetNoContextTimeSeries() throws Exception {
2021-03-16 10:37:52 +01:00
2021-11-22 12:48:34 +01:00
List<Filter> filters = getFilters();
2021-03-16 15:33:34 +01:00
2021-03-30 22:35:51 +02:00
TemporalConstraint temporalConstraint = getTemporalConstraint();
2021-03-31 10:06:20 +02:00
List<Class<? extends AggregatedRecord<?, ?>>> classes = getClassesToTest();
2021-03-30 22:35:51 +02:00
for(Class<? extends AggregatedRecord<?, ?>> clz : classes) {
logger.debug("----------------------------------------------------------------------");
logger.debug("Going to query {}\n", RecordToDBMapping.getRecordTypeByClass(clz));
2021-03-31 10:06:20 +02:00
accountingPersistenceQueryPostgreSQL.setRequestedRecords(clz);
accountingPersistenceQueryPostgreSQL.setTemporalConstraint(temporalConstraint);
accountingPersistenceQueryPostgreSQL.setFilters(filters);
SortedMap<Calendar, Info> timeseries = accountingPersistenceQueryPostgreSQL.getTimeSeries();
2021-03-30 22:35:51 +02:00
for(Calendar c : timeseries.keySet()) {
Info info = timeseries.get(c);
logger.debug("{}", info);
}
}
2021-03-15 17:01:09 +01:00
}
2021-03-17 17:55:56 +01:00
@Test
public void testTimeSeries() throws DuplicatedKeyFilterException, KeyException, ValueException, Exception {
2021-11-22 12:48:34 +01:00
List<Filter> filters = getFilters();
2021-03-17 17:55:56 +01:00
2021-03-30 22:35:51 +02:00
TemporalConstraint temporalConstraint = getTemporalConstraint();
2021-03-29 11:45:48 +02:00
2021-03-31 10:06:20 +02:00
List<Class<? extends AggregatedRecord<?, ?>>> classes = getClassesToTest();
2021-03-29 11:45:48 +02:00
2021-03-30 22:35:51 +02:00
for(Class<? extends AggregatedRecord<?, ?>> clz : classes) {
logger.debug("----------------------------------------------------------------------");
logger.debug("Going to query {}\n", RecordToDBMapping.getRecordTypeByClass(clz));
accountingPersistenceQueryPostgreSQL.setRequestedRecords(clz);
accountingPersistenceQueryPostgreSQL.setTemporalConstraint(temporalConstraint);
accountingPersistenceQueryPostgreSQL.setFilters(filters);
SortedMap<Calendar, Info> timeseries = accountingPersistenceQueryPostgreSQL.getTimeSeries();
2021-03-30 22:35:51 +02:00
for(Calendar c : timeseries.keySet()) {
Info info = timeseries.get(c);
logger.debug("{}", info);
}
2021-03-29 11:45:48 +02:00
}
2021-03-30 22:35:51 +02:00
2021-03-17 17:55:56 +01:00
}
2021-03-22 11:53:12 +01:00
@Test
public void testContextTimeSeries() throws DuplicatedKeyFilterException, KeyException, ValueException, Exception {
2021-11-22 12:48:34 +01:00
List<Filter> filters = getFilters();
2021-03-22 11:53:12 +01:00
2021-03-30 22:35:51 +02:00
TemporalConstraint temporalConstraint = getTemporalConstraint();
2021-03-22 11:53:12 +01:00
2021-03-31 10:06:20 +02:00
List<Class<? extends AggregatedRecord<?, ?>>> classes = getClassesToTest();
Set<String> contexts = new HashSet<>();
2021-03-22 11:53:12 +01:00
contexts.add("/gcube/devsec/devVRE");
contexts.add("/gcube/devNext/NextNext");
2021-03-30 22:35:51 +02:00
for(Class<? extends AggregatedRecord<?, ?>> clz : classes) {
logger.debug("----------------------------------------------------------------------");
logger.debug("Going to query {}\n", RecordToDBMapping.getRecordTypeByClass(clz));
accountingPersistenceQueryPostgreSQL.setRequestedRecords(clz);
accountingPersistenceQueryPostgreSQL.setTemporalConstraint(temporalConstraint);
accountingPersistenceQueryPostgreSQL.setContexts(contexts);
accountingPersistenceQueryPostgreSQL.setFilters(filters);
SortedMap<Filter, SortedMap<Calendar, Info>> contextTimeseries = accountingPersistenceQueryPostgreSQL.getContextTimeSeries();
2021-03-30 22:35:51 +02:00
for(Filter f : contextTimeseries.keySet()) {
logger.debug("{}", f);
SortedMap<Calendar, Info> timeseries = contextTimeseries.get(f);
for(Calendar c : timeseries.keySet()) {
Info info = timeseries.get(c);
logger.debug("{}", info);
}
2021-03-22 11:53:12 +01:00
}
}
2021-03-30 22:35:51 +02:00
2021-03-22 11:53:12 +01:00
}
2021-03-19 15:55:06 +01:00
@Test
public void testGetFilterValues() throws DuplicatedKeyFilterException, KeyException, ValueException, Exception {
2021-11-22 12:48:34 +01:00
List<Filter> filters = getFilters();
2021-03-19 15:55:06 +01:00
2021-03-30 22:35:51 +02:00
TemporalConstraint temporalConstraint = getTemporalConstraint();
2021-03-31 10:06:20 +02:00
List<Class<? extends AggregatedRecord<?, ?>>> classes = getClassesToTest();
2021-03-19 15:55:06 +01:00
2021-03-31 10:06:20 +02:00
Map<Class<? extends AggregatedRecord<?, ?>>, String> keysToRequest = new HashMap<>();
keysToRequest.put(AggregatedServiceUsageRecord.class, AggregatedServiceUsageRecord.CALLED_METHOD);
2021-04-14 16:32:48 +02:00
keysToRequest.put(AggregatedStorageUsageRecord.class, AggregatedStorageUsageRecord.CONSUMER_ID);
2021-03-31 10:06:20 +02:00
keysToRequest.put(AggregatedJobUsageRecord.class, AggregatedJobUsageRecord.JOB_NAME);
2021-03-19 15:55:06 +01:00
2021-03-31 10:06:20 +02:00
for(Class<? extends AggregatedRecord<?, ?>> clz : classes) {
logger.debug("----------------------------------------------------------------------");
logger.debug("Going to query {}\n", RecordToDBMapping.getRecordTypeByClass(clz));
String key = keysToRequest.get(clz);
2021-03-19 15:55:06 +01:00
accountingPersistenceQueryPostgreSQL.setRequestedRecords(clz);
accountingPersistenceQueryPostgreSQL.setTemporalConstraint(temporalConstraint);
SortedSet<NumberedFilter> numberedFilters = accountingPersistenceQueryPostgreSQL.getFilterValues(key);
2021-03-31 10:06:20 +02:00
for(NumberedFilter numberedFilter : numberedFilters) {
logger.debug("{}", numberedFilter);
}
2021-11-23 10:41:27 +01:00
accountingPersistenceQueryPostgreSQL.setFilters(filters);
numberedFilters = accountingPersistenceQueryPostgreSQL.getFilterValues(key);
for(NumberedFilter numberedFilter : numberedFilters) {
logger.debug("{}", numberedFilter);
}
accountingPersistenceQueryPostgreSQL.setFilters(null);
logger.debug("----Only first 3 results");
numberedFilters = accountingPersistenceQueryPostgreSQL.getFilterValues(key, 3);
for(NumberedFilter numberedFilter : numberedFilters) {
logger.debug("{}", numberedFilter);
}
accountingPersistenceQueryPostgreSQL.setFilters(filters);
2021-04-01 09:40:59 +02:00
logger.debug("----Only first 3 results");
numberedFilters = accountingPersistenceQueryPostgreSQL.getFilterValues(key, 3);
2021-03-31 10:06:20 +02:00
for(NumberedFilter numberedFilter : numberedFilters) {
logger.debug("{}", numberedFilter);
}
2021-03-19 15:55:06 +01:00
}
}
2021-03-22 11:53:12 +01:00
@Test
public void testTopValues() throws DuplicatedKeyFilterException, KeyException, ValueException, Exception {
String orderingProperty = AccountingPersistenceQuery.getDefaultOrderingProperties(AggregatedServiceUsageRecord.class);
2021-11-22 12:48:34 +01:00
List<Filter> filters = new ArrayList<>();
2021-03-22 11:53:12 +01:00
Filter filter = new Filter(UsageRecord.CONSUMER_ID, QueryTest.getRandomUser());
filters.add(filter);
2021-03-30 22:35:51 +02:00
TemporalConstraint temporalConstraint = getTemporalConstraint();
2021-03-22 11:53:12 +01:00
accountingPersistenceQueryPostgreSQL.setRequestedRecords(AggregatedServiceUsageRecord.class);
accountingPersistenceQueryPostgreSQL.setTemporalConstraint(temporalConstraint);
accountingPersistenceQueryPostgreSQL.setFilters(filters);
2021-11-25 12:27:52 +01:00
SortedMap<NumberedFilter, SortedMap<Calendar, Info>> topTimeSeries = accountingPersistenceQueryPostgreSQL.getTopValues(AggregatedServiceUsageRecord.CALLED_METHOD, orderingProperty, null);
2021-03-22 11:53:12 +01:00
for(NumberedFilter numberedFilter : topTimeSeries.keySet()) {
logger.debug("{}", numberedFilter);
SortedMap<Calendar, Info> timeseries = topTimeSeries.get(numberedFilter);
for(Calendar c : timeseries.keySet()) {
Info info = timeseries.get(c);
logger.debug("{}", info);
}
2021-03-22 18:08:35 +01:00
}
}
@Test
public void testGetRecord() throws Exception {
String type = RecordToDBMapping.getRecordTypeByClass(AggregatedServiceUsageRecord.class);
2021-03-30 22:13:28 +02:00
Record record = accountingPersistenceQueryPostgreSQL.getRecord("7c3fcb31-6909-451d-bae0-633b3bec0c21", type);
2021-03-22 18:08:35 +01:00
logger.debug("{}", record);
2021-03-22 11:53:12 +01:00
}
2021-03-29 10:43:21 +02:00
2021-11-22 15:55:20 +01:00
@Test
public void storageStatusTest() throws Exception {
accountingPersistenceQueryPostgreSQL.setRequestedRecords(AggregatedStorageStatusRecord.class);
Collection<NumberedFilter> myFilters = accountingPersistenceQueryPostgreSQL.getFilterValues(AggregatedStorageStatusRecord.DATA_TYPE);
accountingPersistenceQueryPostgreSQL.setFilters(myFilters);
accountingPersistenceQueryPostgreSQL.setTemporalConstraint(getTemporalConstraint());
accountingPersistenceQueryPostgreSQL.getTimeSeries();
}
2021-03-29 10:43:21 +02:00
@Test
public void testGetSpaceTimeSeries() throws DuplicatedKeyFilterException, KeyException, ValueException, Exception {
TemporalConstraint temporalConstraint = getTemporalConstraint();
accountingPersistenceQueryPostgreSQL.setTemporalConstraint(temporalConstraint);
Set<String> dataTypes = new HashSet<>();
dataTypes.add(DataType.STORAGE.name());
SortedMap<Filter, SortedMap<Calendar, Info>> getSpaceTimeSeries = accountingPersistenceQueryPostgreSQL.getSpaceTimeSeries(dataTypes);
for(Filter filter : getSpaceTimeSeries.keySet()) {
logger.debug("{}", filter);
SortedMap<Calendar, Info> timeseries = getSpaceTimeSeries.get(filter);
for(Calendar c : timeseries.keySet()) {
Info info = timeseries.get(c);
logger.debug("{}", info);
}
}
2021-03-29 10:43:21 +02:00
}
2021-11-22 18:23:12 +01:00
@Test
public void testStorageTimeSeries() throws DuplicatedKeyFilterException, KeyException, ValueException, Exception {
AccountingPersistenceQuery apq = AccountingPersistenceQueryFactory.getInstance();
Calendar startTimeCalendar = Calendar.getInstance();
startTimeCalendar.set(Calendar.YEAR, 2017);
startTimeCalendar.set(Calendar.MONTH, Calendar.JANUARY);
startTimeCalendar.set(Calendar.DAY_OF_MONTH, 1);
startTimeCalendar.set(Calendar.HOUR_OF_DAY, 0);
startTimeCalendar.set(Calendar.MINUTE, 0);
Calendar entTimeCalendar = Calendar.getInstance();
entTimeCalendar.set(Calendar.YEAR, 2021);
entTimeCalendar.set(Calendar.MONTH, Calendar.MARCH);
entTimeCalendar.set(Calendar.DAY_OF_MONTH, 22);
entTimeCalendar.set(Calendar.HOUR_OF_DAY, 0);
entTimeCalendar.set(Calendar.MINUTE, 0);
TemporalConstraint temporalConstraint = new TemporalConstraint(startTimeCalendar.getTimeInMillis(), entTimeCalendar.getTimeInMillis(), AggregationMode.DAILY);
apq.setRequestedRecords(AggregatedStorageStatusRecord.class);
apq.setTemporalConstraint(temporalConstraint);
SortedMap<Calendar, Info> timeseries = apq.getTimeSeries();
for(Calendar c : timeseries.keySet()) {
Info info = timeseries.get(c);
logger.debug("{}", info);
}
}
2021-03-17 17:55:56 +01:00
}