use of com.serotonin.m2m2.rt.dataImage.IdPointValueTime in project ma-core-public by infiniteautomation.
the class NumericPointValueDaoTestHelper method testLatestMultiplePointValuesOrderByIdLimit.
public void testLatestMultiplePointValuesOrderByIdLimit() {
MutableInt count1 = new MutableInt();
MutableInt count2 = new MutableInt();
MutableInt mutableIndex = new MutableInt();
MutableLong timestamp1 = new MutableLong(endTs);
MutableLong timestamp2 = new MutableLong(endTs);
this.dao.getLatestPointValues(ids, endTs, true, 20, new PVTQueryCallback<IdPointValueTime>() {
int seriesIdCounter = data.get(seriesId).size() - 1;
int seriesId2Counter = data.get(seriesId2).size() - 4;
@Override
public void row(IdPointValueTime value, int index) throws IOException {
Assert.assertEquals(mutableIndex.intValue(), index);
mutableIndex.increment();
if (index < 20) {
// Should be first id
Assert.assertEquals((int) seriesId, value.getId());
} else {
Assert.assertEquals((int) seriesId2, value.getId());
}
if (value.getId() == seriesId2) {
if (value.getTime() > timestamp2.getValue())
Assert.fail("Timestamp out of order");
timestamp2.setValue(value.getTime());
count2.increment();
// Check value
Assert.assertEquals(data.get(value.getId()).get(seriesId2Counter).getDoubleValue(), value.getDoubleValue(), 0.001);
// Check time
Assert.assertEquals(data.get(value.getId()).get(seriesId2Counter).getTime(), value.getTime());
seriesId2Counter--;
} else {
if (value.getTime() > timestamp1.getValue())
Assert.fail("Timestamp out of order");
timestamp1.setValue(value.getTime());
count1.increment();
// Check value
Assert.assertEquals(data.get(value.getId()).get(seriesIdCounter).getDoubleValue(), value.getDoubleValue(), 0.001);
// Check time
Assert.assertEquals(data.get(value.getId()).get(seriesIdCounter).getTime(), value.getTime());
seriesIdCounter--;
}
}
});
Assert.assertEquals(new Integer(20), count1.getValue());
Assert.assertEquals(new Integer(20), count2.getValue());
}
use of com.serotonin.m2m2.rt.dataImage.IdPointValueTime in project ma-core-public by infiniteautomation.
the class NumericPointValueDaoTestHelper method testBookendMultiplePointValuesLimit.
public void testBookendMultiplePointValuesLimit() {
MutableInt count = new MutableInt();
MutableInt mutableIndex = new MutableInt();
MutableLong timestamp = new MutableLong(startTs - 1);
this.dao.wideBookendQuery(ids, startTs - 1, endTs, false, 20, new BookendQueryCallback<IdPointValueTime>() {
int seriesIdCounter = 0;
// Skip first 3
int seriesId2Counter = 3;
@Override
public void firstValue(IdPointValueTime value, int index, boolean bookend) throws IOException {
Assert.assertEquals(mutableIndex.intValue(), index);
mutableIndex.increment();
if (value.getTime() < timestamp.getValue())
Assert.fail("Timestamp out of order.");
timestamp.setValue(value.getTime());
if (value.getId() == seriesId2) {
// This has a value before the startTs
// Check value
Assert.assertEquals(data.get(value.getId()).get(2).getDoubleValue(), value.getDoubleValue(), 0.001);
// Check time
Assert.assertEquals(startTs - 1, value.getTime());
Assert.assertEquals(true, bookend);
} else {
// Check value is null as no data exists before the startTs for series 1
Assert.assertNull(value.getValue());
// Check time
Assert.assertEquals(startTs - 1, value.getTime());
Assert.assertEquals(true, bookend);
}
}
@Override
public void row(IdPointValueTime value, int index) throws IOException {
Assert.assertEquals(mutableIndex.intValue(), index);
mutableIndex.increment();
count.increment();
if (value.getTime() < timestamp.getValue())
Assert.fail("Timestamp out of order.");
timestamp.setValue(value.getTime());
if (value.getId() == seriesId2) {
// Check value
Assert.assertEquals(data.get(value.getId()).get(seriesId2Counter).getDoubleValue(), value.getDoubleValue(), 0.001);
// Check time
Assert.assertEquals(data.get(value.getId()).get(seriesId2Counter).getTime(), value.getTime());
seriesId2Counter++;
} else {
// Check value
Assert.assertEquals(data.get(value.getId()).get(seriesIdCounter).getDoubleValue(), value.getDoubleValue(), 0.001);
// Check time
Assert.assertEquals(data.get(value.getId()).get(seriesIdCounter).getTime(), value.getTime());
seriesIdCounter++;
}
}
@Override
public void lastValue(IdPointValueTime value, int index, boolean bookend) throws IOException {
Assert.assertEquals(mutableIndex.intValue(), index);
mutableIndex.increment();
if (value.getTime() < timestamp.getValue())
Assert.fail("Timestamp out of order.");
timestamp.setValue(value.getTime());
if (value.getId() == seriesId2) {
// Limited queries bookend
Assert.assertEquals(true, bookend);
// Check value
Assert.assertEquals(data.get(value.getId()).get(--seriesId2Counter).getDoubleValue(), value.getDoubleValue(), 0.001);
// Check time
Assert.assertEquals(endTs, value.getTime());
} else {
// Limited Query Bookend
Assert.assertEquals(true, bookend);
// Check value
Assert.assertEquals(data.get(value.getId()).get(--seriesIdCounter).getDoubleValue(), value.getDoubleValue(), 0.001);
// Check time
Assert.assertEquals(endTs, value.getTime());
// Limited queries do not have bookends
}
}
});
Assert.assertEquals(new Integer(20), count.getValue());
}
use of com.serotonin.m2m2.rt.dataImage.IdPointValueTime in project ma-core-public by infiniteautomation.
the class NumericPointValueDaoTestHelper method testLatestMultiplePointValuesOrderByIdNoLimit.
public void testLatestMultiplePointValuesOrderByIdNoLimit() {
MutableInt count = new MutableInt();
MutableInt mutableIndex = new MutableInt();
MutableLong timestamp1 = new MutableLong(endTs);
MutableLong timestamp2 = new MutableLong(endTs);
this.dao.getLatestPointValues(ids, endTs, true, null, new PVTQueryCallback<IdPointValueTime>() {
int seriesIdCounter = data.get(seriesId).size() - 1;
// Start before last 3 samples (extra)
int seriesId2Counter = data.get(seriesId2).size() - 4;
@Override
public void row(IdPointValueTime value, int index) throws IOException {
Assert.assertEquals(mutableIndex.intValue(), index);
mutableIndex.increment();
count.increment();
if (index < data.get(seriesId).size()) {
// Should be first id
Assert.assertEquals((int) seriesId, value.getId());
} else {
Assert.assertEquals((int) seriesId2, value.getId());
}
if (value.getId() == seriesId2) {
if (value.getTime() > timestamp2.getValue())
Assert.fail("Timestamp out of order.");
timestamp2.setValue(value.getTime());
// Check value
Assert.assertEquals(data.get(value.getId()).get(seriesId2Counter).getDoubleValue(), value.getDoubleValue(), 0.001);
// Check time
Assert.assertEquals(data.get(value.getId()).get(seriesId2Counter).getTime(), value.getTime());
seriesId2Counter--;
} else {
if (value.getTime() > timestamp1.getValue())
Assert.fail("Timestamp out of order.");
timestamp1.setValue(value.getTime());
// Check value
Assert.assertEquals(data.get(value.getId()).get(seriesIdCounter).getDoubleValue(), value.getDoubleValue(), 0.001);
// Check time
Assert.assertEquals(data.get(value.getId()).get(seriesIdCounter).getTime(), value.getTime());
seriesIdCounter--;
}
}
});
// Total is all samples + the extra 3 at the beginning of series2
Assert.assertEquals(new Integer(totalSampleCount * 2 + 3), count.getValue());
}
use of com.serotonin.m2m2.rt.dataImage.IdPointValueTime in project ma-core-public by infiniteautomation.
the class NumericPointValueDaoTestHelper method testBetweenExceptionInCallback.
/* Values Between Tests */
public void testBetweenExceptionInCallback() {
MutableInt count = new MutableInt();
MutableInt mutableIndex = new MutableInt();
MutableLong timestamp = new MutableLong(startTs);
this.dao.getPointValuesBetween(ids, startTs, endTs, false, null, new PVTQueryCallback<IdPointValueTime>() {
int seriesIdCounter = 0;
// Skip first 3
int seriesId2Counter = 3;
@Override
public void row(IdPointValueTime value, int index) throws IOException {
Assert.assertEquals(mutableIndex.intValue(), index);
mutableIndex.increment();
count.increment();
if (value.getTime() < timestamp.getValue())
Assert.fail("Timestamp out of order.");
timestamp.setValue(value.getTime());
if (value.getId() == seriesId2) {
// Check value
Assert.assertEquals(data.get(value.getId()).get(seriesId2Counter).getDoubleValue(), value.getDoubleValue(), 0.001);
// Check time
Assert.assertEquals(data.get(value.getId()).get(seriesId2Counter).getTime(), value.getTime());
seriesId2Counter++;
} else {
// Check value
Assert.assertEquals(data.get(value.getId()).get(seriesIdCounter).getDoubleValue(), value.getDoubleValue(), 0.001);
// Check time
Assert.assertEquals(data.get(value.getId()).get(seriesIdCounter).getTime(), value.getTime());
seriesIdCounter++;
}
if (count.getValue() == 20)
throw new IOException("Exception Test");
}
});
Assert.assertEquals(new Integer(20), count.getValue());
}
use of com.serotonin.m2m2.rt.dataImage.IdPointValueTime in project ma-core-public by infiniteautomation.
the class NumericPointValueDaoTestHelper method testRangeMultiplePointValuesNoLimitOffsetSeries.
public void testRangeMultiplePointValuesNoLimitOffsetSeries() {
MutableInt count = new MutableInt();
MutableInt mutableIndex = new MutableInt();
MutableLong timestamp = new MutableLong(series2StartTs);
this.dao.getPointValuesBetween(ids, series2StartTs, series2EndTs + 1, false, null, new PVTQueryCallback<IdPointValueTime>() {
int seriesIdCounter = 0;
int seriesId2Counter = 0;
@Override
public void row(IdPointValueTime value, int index) throws IOException {
Assert.assertEquals(mutableIndex.intValue(), index);
mutableIndex.increment();
count.increment();
if (value.getTime() < timestamp.getValue())
Assert.fail("Timestamp out of order.");
timestamp.setValue(value.getTime());
if (value.getId() == seriesId2) {
// Check value
Assert.assertEquals(data.get(value.getId()).get(seriesId2Counter).getDoubleValue(), value.getDoubleValue(), 0.001);
// Check time
Assert.assertEquals(data.get(value.getId()).get(seriesId2Counter).getTime(), value.getTime());
seriesId2Counter++;
} else {
// Check value
Assert.assertEquals(data.get(value.getId()).get(seriesIdCounter).getDoubleValue(), value.getDoubleValue(), 0.001);
// Check time
Assert.assertEquals(data.get(value.getId()).get(seriesIdCounter).getTime(), value.getTime());
seriesIdCounter++;
}
}
});
Assert.assertEquals(new Integer(totalSampleCount * 2 + 6), count.getValue());
}
Aggregations