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

99 lines
3.3 KiB
Java
Raw Normal View History

2021-03-16 15:33:34 +01:00
/**
*
*/
package org.gcube.accounting.analytics.persistence.postgresql;
import java.util.Calendar;
2021-03-17 17:55:56 +01:00
import java.util.HashSet;
import java.util.Random;
2021-03-17 17:55:56 +01:00
import java.util.Set;
2021-03-16 15:33:34 +01:00
import org.gcube.accounting.analytics.Filter;
import org.gcube.accounting.analytics.TemporalConstraint;
import org.gcube.accounting.analytics.TemporalConstraint.AggregationMode;
2021-03-19 15:55:06 +01:00
import org.gcube.accounting.analytics.persistence.AccountingPersistenceQuery;
2021-03-16 15:33:34 +01:00
import org.gcube.accounting.datamodel.UsageRecord;
import org.gcube.accounting.datamodel.aggregation.AggregatedServiceUsageRecord;
2021-03-19 15:55:06 +01:00
import org.gcube.accounting.datamodel.usagerecords.ServiceUsageRecord;
2021-03-16 15:33:34 +01:00
import org.junit.Test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* @author Luca Frosini (ISTI - CNR)
*/
public class QueryTest extends ContextTest {
private static final Logger logger = LoggerFactory.getLogger(QueryTest.class);
2021-03-31 10:06:20 +02:00
public static final String[] users = new String[]{"luca.frosini", "lucio.lelii", "francesco.mangiacrapa", "fabio.sinibaldi", "massimiliano.assante", "giancarlo.panichi", "gianpaolo.coro"};
private static final Random random;
static {
random = new Random();
}
public static String getRandomUser() {
int randomNumber = random.nextInt(users.length);
return users[randomNumber];
}
2021-03-16 15:33:34 +01:00
@Test
public void testGetNoContextTimeSeriesQuery() throws Exception {
2021-03-16 15:33:34 +01:00
Calendar startTimeCalendar = Calendar.getInstance();
startTimeCalendar.set(Calendar.YEAR, 2020);
2021-03-16 15:33:34 +01:00
startTimeCalendar.set(Calendar.MONTH, Calendar.MARCH);
startTimeCalendar.set(Calendar.DAY_OF_MONTH, 1);
startTimeCalendar.set(Calendar.HOUR_OF_DAY, 0);
startTimeCalendar.set(Calendar.MINUTE, 0);
2021-03-16 15:33:34 +01:00
Calendar entTimeCalendar = Calendar.getInstance();
entTimeCalendar.set(Calendar.MONTH, Calendar.MARCH);
entTimeCalendar.set(Calendar.DAY_OF_MONTH, 15);
entTimeCalendar.set(Calendar.HOUR_OF_DAY, 16);
entTimeCalendar.set(Calendar.MINUTE, 17);
Set<Filter> filters = new HashSet<>();
Filter filter = new Filter(UsageRecord.CONSUMER_ID, getRandomUser());
2021-03-16 15:33:34 +01:00
filters.add(filter);
2021-11-02 11:29:29 +01:00
filter = new Filter(UsageRecord.CONSUMER_ID, getRandomUser());
filters.add(filter);
2021-03-16 15:33:34 +01:00
2021-03-19 15:55:06 +01:00
TemporalConstraint temporalConstraint = new TemporalConstraint(startTimeCalendar.getTimeInMillis(), entTimeCalendar.getTimeInMillis(), AggregationMode.MONTHLY);
2021-03-16 15:33:34 +01:00
Query query = new Query(AggregatedServiceUsageRecord.class);
query.setTemporalConstraint(temporalConstraint);
query.setFilters(filters);
2021-03-17 17:55:56 +01:00
String ret = query.getTimeSeriesQuery();
logger.debug(ret);
2021-03-19 15:55:06 +01:00
2021-03-17 17:55:56 +01:00
Set<String> contexts = new HashSet<>();
2021-11-02 11:29:29 +01:00
contexts.add(DEFAULT_TEST_SCOPE);
contexts.add(ALTERNATIVE_TEST_SCOPE);
2021-03-17 17:55:56 +01:00
query.setContexts(contexts);
ret = query.getTimeSeriesQuery();
2021-03-16 15:33:34 +01:00
logger.debug(ret);
2021-03-19 15:55:06 +01:00
query = new Query(AggregatedServiceUsageRecord.class);
query.setTemporalConstraint(temporalConstraint);
query.setFilters(filters);
query.setContexts(contexts);
2021-03-22 19:08:31 +01:00
query.setTableFieldToRequest(ServiceUsageRecord.CALLED_METHOD);
2021-03-19 15:55:06 +01:00
query.setOrderByField(AccountingPersistenceQuery.getDefaultOrderingProperties(AggregatedServiceUsageRecord.class));
ret = query.getNextPossibleValueQuery();
logger.debug(ret);
2021-03-22 18:08:35 +01:00
}
@Test
public void testGetRecordQuery() throws Exception {
Query query = new Query(AggregatedServiceUsageRecord.class);
2021-11-02 11:29:29 +01:00
query.setRecordId("7c3fcb31-6909-451d-bae0-633b3bec0c21");
2021-03-22 18:08:35 +01:00
String ret = query.getRecordQuery();
logger.debug(ret);
2021-03-16 15:33:34 +01:00
}
2021-03-17 17:55:56 +01:00
2021-03-16 15:33:34 +01:00
}