Search in sources :

Example 36 with Period

use of com.axibase.tsd.api.model.Period 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));
    Set<CheckedFields> actualFields = createCheckFields(querySeriesAsList(query));
    CheckedFields series = new CheckedFields("*", Arrays.asList(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"))));
    Set<CheckedFields> expectedFields = collectCheckFields(series);
    assertEquals(actualFields, expectedFields, "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 37 with Period

use of com.axibase.tsd.api.model.Period in project atsd-api-test by axibase.

the class SeriesQueryAggregateGroupOrderRateTest method testRateSeriesLimit.

@Issue("4729")
@Test(description = "test query result with rate seriesLimit")
public void testRateSeriesLimit() {
    SeriesQuery query = new SeriesQuery("*", TEST_METRIC, "2017-01-01T00:00:00Z", "2017-01-01T00:00:20Z");
    query.setRate(new Rate(new Period(5, TimeUnit.SECOND)));
    query.setSeriesLimit(1);
    Set<CheckedFields> actualFields = createCheckFields(querySeriesAsList(query));
    CheckedFields series = new CheckedFields(TEST_ENTITY1, Arrays.asList(Sample.ofDateDecimal("2017-01-01T00:00:03.000Z", new BigDecimal("5.0")), Sample.ofDateDecimal("2017-01-01T00:00:05.000Z", new BigDecimal("5.0")), Sample.ofDateDecimal("2017-01-01T00:00:07.000Z", new BigDecimal("5.0")), Sample.ofDateDecimal("2017-01-01T00:00:09.000Z", new BigDecimal("5.0")), Sample.ofDateDecimal("2017-01-01T00:00:11.000Z", new BigDecimal("5.0")), Sample.ofDateDecimal("2017-01-01T00:00:13.000Z", new BigDecimal("5.0")), Sample.ofDateDecimal("2017-01-01T00:00:15.000Z", new BigDecimal("5.0")), Sample.ofDateDecimal("2017-01-01T00:00:17.000Z", new BigDecimal("5.0")), Sample.ofDateDecimal("2017-01-01T00:00:19.000Z", new BigDecimal("5.0"))));
    Set<CheckedFields> expectedFields = collectCheckFields(series);
    assertEquals(actualFields, expectedFields, "Incorrect query result with rate");
}
Also used : 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)

Example 38 with Period

use of com.axibase.tsd.api.model.Period in project atsd-api-test by axibase.

the class SeriesQueryAggregateGroupOrderRateTest method testRateOrder.

@Issue("4729")
@Test(dataProvider = "provideOrders", description = "test query result with rate")
public void testRateOrder(Integer order) {
    SeriesQuery query = new SeriesQuery("*", TEST_METRIC, "2017-01-01T00:00:00Z", "2017-01-01T00:00:20Z");
    Rate rate = new Rate(new Period(5, TimeUnit.SECOND));
    if (order != null) {
        rate.setOrder(order);
    }
    query.setRate(rate);
    Set<CheckedFields> actualFields = createCheckFields(querySeriesAsList(query));
    CheckedFields series1 = new CheckedFields(TEST_ENTITY1, Arrays.asList(Sample.ofDateDecimal("2017-01-01T00:00:03.000Z", new BigDecimal("5.0")), Sample.ofDateDecimal("2017-01-01T00:00:05.000Z", new BigDecimal("5.0")), Sample.ofDateDecimal("2017-01-01T00:00:07.000Z", new BigDecimal("5.0")), Sample.ofDateDecimal("2017-01-01T00:00:09.000Z", new BigDecimal("5.0")), Sample.ofDateDecimal("2017-01-01T00:00:11.000Z", new BigDecimal("5.0")), Sample.ofDateDecimal("2017-01-01T00:00:13.000Z", new BigDecimal("5.0")), Sample.ofDateDecimal("2017-01-01T00:00:15.000Z", new BigDecimal("5.0")), Sample.ofDateDecimal("2017-01-01T00:00:17.000Z", new BigDecimal("5.0")), Sample.ofDateDecimal("2017-01-01T00:00:19.000Z", new BigDecimal("5.0"))));
    CheckedFields series2 = new CheckedFields(TEST_ENTITY2, Arrays.asList(Sample.ofDateDecimal("2017-01-01T00:00:02.000Z", new BigDecimal("5.0")), Sample.ofDateDecimal("2017-01-01T00:00:04.000Z", new BigDecimal("5.0")), Sample.ofDateDecimal("2017-01-01T00:00:06.000Z", new BigDecimal("5.0")), Sample.ofDateDecimal("2017-01-01T00:00:08.000Z", new BigDecimal("5.0")), Sample.ofDateDecimal("2017-01-01T00:00:10.000Z", new BigDecimal("5.0")), Sample.ofDateDecimal("2017-01-01T00:00:12.000Z", new BigDecimal("5.0")), Sample.ofDateDecimal("2017-01-01T00:00:14.000Z", new BigDecimal("5.0")), Sample.ofDateDecimal("2017-01-01T00:00:16.000Z", new BigDecimal("5.0")), Sample.ofDateDecimal("2017-01-01T00:00:18.000Z", new BigDecimal("5.0"))));
    Set<CheckedFields> expectedFields = collectCheckFields(series1, series2);
    assertEquals(actualFields, expectedFields, "Incorrect query result with rate");
}
Also used : 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)

Example 39 with Period

use of com.axibase.tsd.api.model.Period 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));
    Set<CheckedFields> actualFields = createCheckFields(querySeriesAsList(query));
    CheckedFields series = new CheckedFields("*", Arrays.asList(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"))));
    Set<CheckedFields> expectedFields = collectCheckFields(series);
    assertEquals(actualFields, expectedFields, "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 40 with Period

use of com.axibase.tsd.api.model.Period in project atsd-api-test by axibase.

the class SeriesQueryAggregateGroupOrderRateTest method testExplicitEqualsOrderGroupRateAggregate.

@Issue("4729")
@Test(description = "test query result with explicit equals Group/Rate/Aggregate order")
public void testExplicitEqualsOrderGroupRateAggregate() {
    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), 0));
    query.setRate(new Rate(new Period(2, TimeUnit.SECOND), 0));
    query.setAggregate(new Aggregate(AggregationType.SUM, new Period(10, TimeUnit.SECOND), 0));
    Set<CheckedFields> actualFields = createCheckFields(querySeriesAsList(query));
    CheckedFields series = new CheckedFields("*", Arrays.asList(Sample.ofDateDecimal("2017-01-01T00:00:00.000Z", new BigDecimal("1.6")), Sample.ofDateDecimal("2017-01-01T00:00:10.000Z", new BigDecimal("4.0"))));
    Set<CheckedFields> expectedFields = collectCheckFields(series);
    assertEquals(actualFields, expectedFields, "Incorrect query result with explicit equals Group/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)

Aggregations

Period (com.axibase.tsd.api.model.Period)63 Test (org.testng.annotations.Test)48 Issue (io.qameta.allure.Issue)44 SeriesQuery (com.axibase.tsd.api.model.series.query.SeriesQuery)39 Aggregate (com.axibase.tsd.api.model.series.query.transformation.aggregate.Aggregate)30 BigDecimal (java.math.BigDecimal)24 Group (com.axibase.tsd.api.model.series.query.transformation.group.Group)16 Series (com.axibase.tsd.api.model.series.Series)14 Rate (com.axibase.tsd.api.model.series.query.transformation.rate.Rate)11 AggregationInterpolate (com.axibase.tsd.api.model.series.query.transformation.AggregationInterpolate)10 PropertyQuery (com.axibase.tsd.api.model.property.PropertyQuery)7 Property (com.axibase.tsd.api.model.property.Property)6 MessageQuery (com.axibase.tsd.api.model.message.MessageQuery)5 MessageQuerySizeCheck (com.axibase.tsd.api.method.checks.MessageQuerySizeCheck)4 Message (com.axibase.tsd.api.model.message.Message)4 AggregationType (com.axibase.tsd.api.model.series.query.transformation.aggregate.AggregationType)3 ArrayList (java.util.ArrayList)3 Response (javax.ws.rs.core.Response)3 DataProvider (org.testng.annotations.DataProvider)3 Metric (com.axibase.tsd.api.model.metric.Metric)2