Search in sources :

Example 6 with Group

use of com.axibase.tsd.api.model.series.query.transformation.group.Group in project atsd-api-test by axibase.

the class SeriesQueryAggregateGroupOrderRateTest method testGroupSeriesLimit.

@Issue("4729")
@Test(description = "test query result with group seriesLimit")
public void testGroupSeriesLimit() {
    SeriesQuery query = new SeriesQuery("*", TEST_METRIC, "2017-01-01T00:00:00Z", "2017-01-01T00:00:20Z");
    query.setGroup(new Group(GroupType.COUNT, new Period(5, TimeUnit.SECOND)));
    query.setSeriesLimit(1);
    List<Series> result = querySeriesAsList(query);
    Series expectedSeries = createSeries("*", Sample.ofDateInteger("2017-01-01T00:00:00.000Z", 5), Sample.ofDateInteger("2017-01-01T00:00:05.000Z", 5), Sample.ofDateInteger("2017-01-01T00:00:10.000Z", 5), Sample.ofDateInteger("2017-01-01T00:00:15.000Z", 5));
    assertEquals(result, Collections.singletonList(expectedSeries), "Incorrect query result with group seriesLimit");
}
Also used : Group(com.axibase.tsd.api.model.series.query.transformation.group.Group) SeriesQuery(com.axibase.tsd.api.model.series.query.SeriesQuery) Period(com.axibase.tsd.api.model.Period) Issue(io.qameta.allure.Issue) Test(org.testng.annotations.Test)

Example 7 with Group

use of com.axibase.tsd.api.model.series.query.transformation.group.Group in project atsd-api-test by axibase.

the class SeriesQueryTest method testDateIntervalFieldEnoughToGroup.

@Issue("3030")
@Test
public void testDateIntervalFieldEnoughToGroup() throws Exception {
    Series series = new Series("entity-query-25", "metric-query-25");
    series.addSamples(Sample.ofDateInteger(MIN_STORABLE_DATE, 1));
    insertSeriesCheck(Collections.singletonList(series));
    SeriesQuery query = new SeriesQuery();
    query.setEntity(series.getEntity());
    query.setMetric(series.getMetric());
    query.setInterval(new Period(99999, TimeUnit.QUARTER));
    query.setGroup(new Group(GroupType.SUM));
    List<Series> storedSeries = querySeriesAsList(query);
    final String expected = jacksonMapper.writeValueAsString(Collections.singletonList(series));
    final String given = jacksonMapper.writeValueAsString(storedSeries);
    assertTrue("Stored series does not match to inserted", compareJsonString(expected, given));
}
Also used : Group(com.axibase.tsd.api.model.series.query.transformation.group.Group) SeriesQuery(com.axibase.tsd.api.model.series.query.SeriesQuery) Period(com.axibase.tsd.api.model.Period) Issue(io.qameta.allure.Issue) Test(org.testng.annotations.Test)

Example 8 with Group

use of com.axibase.tsd.api.model.series.query.transformation.group.Group in project atsd-api-test by axibase.

the class SeriesQueryAggregateGroupOrderRateTest method testExplicitOrderGroupRateAggregate.

@Issue("4729")
@Test(description = "test query result with explicit non-equals Group/Aggregate order")
public void testExplicitOrderGroupRateAggregate() {
    SeriesQuery query = new SeriesQuery("*", TEST_METRIC, "2017-01-01T00:00:00Z", "2017-01-01T00:00:20Z");
    query.setAggregate(new Aggregate(AggregationType.SUM, new Period(4, TimeUnit.SECOND), 3));
    query.setGroup(new Group(GroupType.MIN, new Period(5, TimeUnit.SECOND), 4));
    query.setRate(new Rate(new Period(10, TimeUnit.SECOND), 5));
    List<Series> result = querySeriesAsList(query);
    Series expectedSeries = createSeries("*", Sample.ofDateDecimal("2017-01-01T00:00:05.000Z", new BigDecimal("32.0")), Sample.ofDateDecimal("2017-01-01T00:00:10.000Z", new BigDecimal("16.0")), Sample.ofDateDecimal("2017-01-01T00:00:15.000Z", new BigDecimal("16.0")));
    assertEquals(result, Collections.singletonList(expectedSeries), "Incorrect query result with explicit non-equals Group/Rate/Aggregate order");
}
Also used : Group(com.axibase.tsd.api.model.series.query.transformation.group.Group) SeriesQuery(com.axibase.tsd.api.model.series.query.SeriesQuery) Rate(com.axibase.tsd.api.model.series.query.transformation.rate.Rate) Period(com.axibase.tsd.api.model.Period) Aggregate(com.axibase.tsd.api.model.series.query.transformation.aggregate.Aggregate) BigDecimal(java.math.BigDecimal) Issue(io.qameta.allure.Issue) Test(org.testng.annotations.Test)

Example 9 with Group

use of com.axibase.tsd.api.model.series.query.transformation.group.Group in project atsd-api-test by axibase.

the class SeriesQueryAggregateGroupOrderRateTest method testExplicitNegativeOrderGroupRateAggregate.

@Issue("4729")
@Test(description = "test query result with explicit negative Group/Aggregate order")
public void testExplicitNegativeOrderGroupRateAggregate() {
    SeriesQuery query = new SeriesQuery("*", TEST_METRIC, "2017-01-01T00:00:00Z", "2017-01-01T00:00:20Z");
    query.setAggregate(new Aggregate(AggregationType.SUM, new Period(4, TimeUnit.SECOND), -5));
    query.setGroup(new Group(GroupType.MIN, new Period(5, TimeUnit.SECOND), -4));
    query.setRate(new Rate(new Period(10, TimeUnit.SECOND), -3));
    List<Series> result = querySeriesAsList(query);
    Series expectedSeries = createSeries("*", Sample.ofDateDecimal("2017-01-01T00:00:05.000Z", new BigDecimal("32.0")), Sample.ofDateDecimal("2017-01-01T00:00:10.000Z", new BigDecimal("16.0")), Sample.ofDateDecimal("2017-01-01T00:00:15.000Z", new BigDecimal("16.0")));
    assertEquals(result, Collections.singletonList(expectedSeries), "Incorrect query result with explicit non-equals Group/Rate/Aggregate order");
}
Also used : Group(com.axibase.tsd.api.model.series.query.transformation.group.Group) SeriesQuery(com.axibase.tsd.api.model.series.query.SeriesQuery) Rate(com.axibase.tsd.api.model.series.query.transformation.rate.Rate) Period(com.axibase.tsd.api.model.Period) Aggregate(com.axibase.tsd.api.model.series.query.transformation.aggregate.Aggregate) BigDecimal(java.math.BigDecimal) Issue(io.qameta.allure.Issue) Test(org.testng.annotations.Test)

Example 10 with Group

use of com.axibase.tsd.api.model.series.query.transformation.group.Group in project atsd-api-test by axibase.

the class SeriesQueryAggregateGroupOrderRateTest method testDefaultOrderGroupRate.

@Issue("4729")
@Test(description = "test query result with default Group/Rate order")
public void testDefaultOrderGroupRate() {
    SeriesQuery query = new SeriesQuery("*", TEST_METRIC, "2017-01-01T00:00:00Z", "2017-01-01T00:00:20Z");
    query.setGroup(new Group(GroupType.MAX, new Period(5, TimeUnit.SECOND)));
    query.setRate(new Rate(new Period(10, TimeUnit.SECOND)));
    List<Series> result = querySeriesAsList(query);
    Series expectedSeries = createSeries("*", Sample.ofDateDecimal("2017-01-01T00:00:05.000Z", new BigDecimal("8.0")), Sample.ofDateDecimal("2017-01-01T00:00:10.000Z", new BigDecimal("12.0")), Sample.ofDateDecimal("2017-01-01T00:00:15.000Z", new BigDecimal("8.0")));
    assertEquals(result, Collections.singletonList(expectedSeries), "Incorrect query result with default Group/Rate order");
}
Also used : Group(com.axibase.tsd.api.model.series.query.transformation.group.Group) SeriesQuery(com.axibase.tsd.api.model.series.query.SeriesQuery) Rate(com.axibase.tsd.api.model.series.query.transformation.rate.Rate) Period(com.axibase.tsd.api.model.Period) BigDecimal(java.math.BigDecimal) Issue(io.qameta.allure.Issue) Test(org.testng.annotations.Test)

Aggregations

SeriesQuery (com.axibase.tsd.api.model.series.query.SeriesQuery)20 Group (com.axibase.tsd.api.model.series.query.transformation.group.Group)20 Issue (io.qameta.allure.Issue)20 Test (org.testng.annotations.Test)19 Period (com.axibase.tsd.api.model.Period)14 Aggregate (com.axibase.tsd.api.model.series.query.transformation.aggregate.Aggregate)7 BigDecimal (java.math.BigDecimal)6 AggregationInterpolate (com.axibase.tsd.api.model.series.query.transformation.AggregationInterpolate)5 Rate (com.axibase.tsd.api.model.series.query.transformation.rate.Rate)4 Response (javax.ws.rs.core.Response)1