use of com.axibase.tsd.api.model.Period in project atsd-api-test by axibase.
the class SeriesQueryTransformationWithDifferentForecastTest method generateGroupingSet.
private List<Group> generateGroupingSet() {
List<Group> groups = new ArrayList<>();
List<List<GroupType>> setsGroupType = Arrays.asList(Arrays.asList(GroupType.AVG, GroupType.SUM), Arrays.asList(GroupType.AVG, GroupType.SUM, GroupType.DETAIL));
Period period = new Period(GROUP_PERIOD_COUNT, TimeUnit.MINUTE, PeriodAlignment.START_TIME);
AggregationInterpolate interp = new AggregationInterpolate(AggregationInterpolateType.LINEAR, true);
for (List<GroupType> setGroupType : setsGroupType) {
groups.add(new Group().setPeriod(period).setInterpolate(interp).setTypes(setGroupType));
}
return groups;
}
use of com.axibase.tsd.api.model.Period in project atsd-api-test by axibase.
the class TokenMessageTest method testStatsMethod.
@Test(description = "Tests messages query stats endpoint with tokens.")
@Issue("6052")
public void testStatsMethod() throws Exception {
String url = "/messages/stats/query";
String token = TokenRepository.getToken(username, HttpMethod.POST, url);
MessageStatsQuery msq = new MessageStatsQuery().setEntity(entity).setType(message.getType()).setStartDate(ISO_TIME).setEndDate(Util.MAX_QUERYABLE_DATE).setAggregate(new Aggregate(AggregationType.COUNT, new Period(1, TimeUnit.DAY, PeriodAlignment.START_TIME)));
Response response = queryMessageStats(Collections.singletonList(msq), token);
String expected = String.format("[ {\n" + " \"entity\" : \"%s\",\n" + " \"metric\" : \"message-count\",\n" + " \"tags\" : {\n" + " \"type\" : \"logger\"\n" + " },\n" + " \"type\" : \"HISTORY\",\n" + " \"aggregate\" : {\n" + " \"type\" : \"COUNT\",\n" + " \"period\":{\"count\":1,\"unit\":\"DAY\"}" + " },\n" + " \"data\" : [{\"d\":\"%s\", \"v\":1} ]\n" + "} ]", entity, ISO_TIME);
assertTrue(compareJsonString(expected, response.readEntity(String.class)));
}
use of com.axibase.tsd.api.model.Period in project atsd-api-test by axibase.
the class SeriesQueryMultipleYearsGroupTest method testSeriesQueryMultipleYearGroupBothEntities.
@Issue("4101")
@Issue("4591")
@Test
public void testSeriesQueryMultipleYearGroupBothEntities() throws Exception {
SeriesQuery query = new SeriesQuery();
query.setEntities(Arrays.asList(ENTITY_NAME1, ENTITY_NAME2));
query.setMetric(METRIC_NAME);
query.setStartDate("1900-01-01T00:00:00.000Z");
query.setEndDate("2100-01-01T00:00:00.000Z");
query.setAggregate(new Aggregate(AggregationType.COUNT, new Period(12, TimeUnit.YEAR)));
List<Series> resultSeries = querySeriesAsList(query);
List<Sample> samples1 = new ArrayList<>();
/* See #4101#note-18 */
if (zeroTimeOffset <= 0) {
samples1.add(Sample.ofDateInteger("1970-01-01T00:00:00.000Z", 1));
}
samples1.add(Sample.ofDateInteger("2006-01-01T00:00:00.000Z", 2));
samples1.add(Sample.ofDateInteger("2018-01-01T00:00:00.000Z", 1));
List<Sample> samples2 = new ArrayList<>();
samples2.add(Sample.ofDateInteger("2006-01-01T00:00:00.000Z", 2));
assertSamples(samples1, resultSeries.get(0).getData());
assertSamples(samples2, resultSeries.get(1).getData());
}
use of com.axibase.tsd.api.model.Period in project atsd-api-test by axibase.
the class SeriesQueryMultipleYearsGroupTest method testSeriesQueryMultipleYearGroupSingleEntity.
@Issue("4101")
@Issue("4591")
@Test
public void testSeriesQueryMultipleYearGroupSingleEntity() throws Exception {
SeriesQuery query = new SeriesQuery();
query.setEntities(Collections.singletonList(ENTITY_NAME2));
query.setMetric(METRIC_NAME);
query.setStartDate("1900-01-01T00:00:00.000Z");
query.setEndDate("2100-01-01T00:00:00.000Z");
query.setAggregate(new Aggregate(AggregationType.COUNT, new Period(12, TimeUnit.YEAR)));
List<Series> resultSeries = querySeriesAsList(query);
List<Sample> samples = new ArrayList<>();
samples.add(Sample.ofDateInteger("2006-01-01T00:00:00.000Z", 2));
assertSamples(samples, resultSeries.get(0).getData());
}
use of com.axibase.tsd.api.model.Period in project atsd-api-test by axibase.
the class SeriesQueryTest method testDateIntervalFieldEnoughToAggregate.
@Issue("3030")
@Test
public void testDateIntervalFieldEnoughToAggregate() throws Exception {
final BigDecimal VALUE = new BigDecimal("1.0");
Series series = new Series("entity-query-26", "metric-query-26");
series.addSamples(Sample.ofDateDecimal("2014-01-01T00:00:00.000Z", VALUE));
insertSeriesCheck(Collections.singletonList(series));
SeriesQuery query = new SeriesQuery();
query.setEntity(series.getEntity());
query.setMetric(series.getMetric());
query.setInterval(new Interval(99999, TimeUnit.QUARTER));
Period period = new Period(99999, TimeUnit.QUARTER, PeriodAlignment.START_TIME);
query.setAggregate(new Aggregate(AggregationType.SUM, period));
List<Series> storedSeries = querySeriesAsList(query);
assertEquals("Response should contain only one series", 1, storedSeries.size());
List<Sample> data = storedSeries.get(0).getData();
assertEquals("Response should contain only one sample", 1, data.size());
assertEquals("Returned value does not match to expected SUM", VALUE, data.get(0).getValue());
}
Aggregations