Search in sources :

Example 46 with Period

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

the class PropertyQueryTest method testStartPastIntervalGiveFuture.

/**
 * #NoTicket
 */
@Test
public void testStartPastIntervalGiveFuture() throws Exception {
    final Property property = new Property("query-type5", "query-entity5");
    property.addTag("t1", "tv1");
    property.addKey("k1", "kv1");
    property.setDate(getCurrentDate());
    insertPropertyCheck(property);
    PropertyQuery query = new PropertyQuery(property.getType(), property.getEntity());
    query.setKey(property.getKey());
    query.setStartDate(MIN_QUERYABLE_DATE);
    query.setInterval(new Period(1999, TimeUnit.YEAR));
    assertInsertedPropertyReturned(property, query);
}
Also used : PropertyQuery(com.axibase.tsd.api.model.property.PropertyQuery) Period(com.axibase.tsd.api.model.Period) Property(com.axibase.tsd.api.model.property.Property) Test(org.testng.annotations.Test)

Example 47 with Period

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

the class PropertyQueryTest method testStartDateInFuture.

/**
 * #NoTicket
 */
@Test
public void testStartDateInFuture() throws Exception {
    final Property property = new Property("query-type19", "query-entity19");
    property.addTag("t1", "tv1");
    property.addKey("k1", "kv1");
    property.setDate(getNextDay());
    insertPropertyCheck(property);
    PropertyQuery query = new PropertyQuery(property.getType(), property.getEntity(), property.getKey());
    query.setStartDate(property.getDate());
    query.setInterval(new Period(2, TimeUnit.DAY));
    assertInsertedPropertyReturned(property, query);
}
Also used : PropertyQuery(com.axibase.tsd.api.model.property.PropertyQuery) Period(com.axibase.tsd.api.model.Period) Property(com.axibase.tsd.api.model.property.Property) Test(org.testng.annotations.Test)

Example 48 with Period

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

the class SeriesQueryDateFilterTest method testIntervalAndEnd.

@Issue("3030")
@Test
public void testIntervalAndEnd() throws Exception {
    Series series = new Series("datefilter-e-2", "datefilter-m-2");
    series.addSamples(DATE_FILTER_DEFAULT_SAMPLE);
    insertSeriesCheck(Collections.singletonList(series));
    SeriesQuery query = new SeriesQuery(series.getEntity(), series.getMetric());
    query.setInterval(new Period(300, TimeUnit.YEAR));
    query.setEndDate(MAX_STORABLE_DATE);
    Response response = querySeries(query);
    assertEquals("Response code mismatch", OK.getStatusCode(), response.getStatus());
    final String expected = jacksonMapper.writeValueAsString(Collections.singletonList(series));
    final String given = response.readEntity(String.class);
    assertTrue("Stored series mismatch", compareJsonString(expected, given));
}
Also used : Response(javax.ws.rs.core.Response) Series(com.axibase.tsd.api.model.series.Series) 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 49 with Period

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

the class SeriesQueryGroupExampleTest method testExampleSumAggregation.

@Issue("2995")
@Test(description = "https://github.com/axibase/atsd-docs/blob/master/api/data/series/group.md#group-aggregation")
public void testExampleSumAggregation() throws Exception {
    SeriesQuery query = prepareDefaultQuery("2016-06-25T08:00:00Z", "2016-06-25T08:01:00Z");
    query.setGroup(new Group(GroupType.SUM, new Period(10, TimeUnit.SECOND)));
    List<Sample> expectedSamples = Arrays.asList(Sample.ofDateInteger("2016-06-25T08:00:00.000Z", 15), Sample.ofDateInteger("2016-06-25T08:00:10.000Z", 21), Sample.ofDateInteger("2016-06-25T08:00:30.000Z", 16), Sample.ofDateInteger("2016-06-25T08:00:40.000Z", 20), Sample.ofDateInteger("2016-06-25T08:00:50.000Z", 19));
    List<Series> groupedSeries = querySeriesAsList(query);
    assertEquals("Response should contain only one series", 1, groupedSeries.size());
    List<Sample> givenSamples = groupedSeries.get(0).getData();
    final String actual = jacksonMapper.writeValueAsString(givenSamples);
    final String expected = jacksonMapper.writeValueAsString(expectedSamples);
    assertTrue("Grouped series do not match to expected", compareJsonString(expected, actual));
}
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 50 with Period

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

the class SeriesQueryGroupExampleTest method testExampleSumAggregationToGroup.

@Issue("2995")
@Test(description = "https://github.com/axibase/atsd-docs/blob/master/api/data/series/group.md#group-aggregation")
public void testExampleSumAggregationToGroup() throws Exception {
    SeriesQuery query = prepareDefaultQuery("2016-06-25T08:00:00Z", "2016-06-25T08:01:00Z");
    query.setGroup(new Group(GroupType.SUM, null, 1));
    query.setAggregate(new Aggregate(AggregationType.COUNT, new Period(10, TimeUnit.SECOND)));
    List<Sample> expectedSamples = Arrays.asList(Sample.ofDateInteger("2016-06-25T08:00:00.000Z", 3), Sample.ofDateInteger("2016-06-25T08:00:10.000Z", 3), Sample.ofDateInteger("2016-06-25T08:00:30.000Z", 2), Sample.ofDateInteger("2016-06-25T08:00:40.000Z", 2), Sample.ofDateInteger("2016-06-25T08:00:50.000Z", 1));
    List<Series> groupedSeries = querySeriesAsList(query);
    assertEquals("Response should contain only one series", 1, groupedSeries.size());
    List<Sample> givenSamples = groupedSeries.get(0).getData();
    final String actual = jacksonMapper.writeValueAsString(givenSamples);
    final String expected = jacksonMapper.writeValueAsString(expectedSamples);
    assertTrue("Grouped series do not match to expected", compareJsonString(expected, actual));
}
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) Aggregate(com.axibase.tsd.api.model.series.query.transformation.aggregate.Aggregate) Issue(io.qameta.allure.Issue) Test(org.testng.annotations.Test)

Aggregations

Period (com.axibase.tsd.api.model.Period)54 Test (org.testng.annotations.Test)49 Issue (io.qameta.allure.Issue)47 SeriesQuery (com.axibase.tsd.api.model.series.query.SeriesQuery)43 Aggregate (com.axibase.tsd.api.model.series.query.transformation.aggregate.Aggregate)25 BigDecimal (java.math.BigDecimal)23 Group (com.axibase.tsd.api.model.series.query.transformation.group.Group)14 Rate (com.axibase.tsd.api.model.series.query.transformation.rate.Rate)8 Response (javax.ws.rs.core.Response)7 PropertyQuery (com.axibase.tsd.api.model.property.PropertyQuery)6 List (java.util.List)6 Property (com.axibase.tsd.api.model.property.Property)5 MessageQuery (com.axibase.tsd.api.model.message.MessageQuery)4 AggregationInterpolate (com.axibase.tsd.api.model.series.query.transformation.AggregationInterpolate)4 Message (com.axibase.tsd.api.model.message.Message)3 Series (com.axibase.tsd.api.model.series.Series)3 Metric (com.axibase.tsd.api.model.metric.Metric)2 Threshold (com.axibase.tsd.api.model.series.query.transformation.aggregate.Threshold)1 Interpolate (com.axibase.tsd.api.model.series.query.transformation.interpolate.Interpolate)1 Alignment (com.axibase.tsd.api.model.sql.function.interpolate.Alignment)1