162 lines
5.2 KiB
TypeScript
162 lines
5.2 KiB
TypeScript
/*
|
|
* Copyright The OpenTelemetry Authors
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* https://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
import * as api from '@opentelemetry/api';
|
|
import * as assert from 'assert';
|
|
|
|
import { SumAggregator } from '../../src/aggregator';
|
|
import { AggregationTemporality } from '../../src/export/AggregationTemporality';
|
|
import { DataPointType } from '../../src/export/MetricData';
|
|
import { MetricCollectorHandle } from '../../src/state/MetricCollector';
|
|
import { SyncMetricStorage } from '../../src/state/SyncMetricStorage';
|
|
import { NoopAttributesProcessor } from '../../src/view/AttributesProcessor';
|
|
import {
|
|
assertMetricData,
|
|
assertDataPoint,
|
|
commonAttributes,
|
|
commonValues,
|
|
defaultInstrumentDescriptor,
|
|
} from '../util';
|
|
|
|
const deltaCollector: MetricCollectorHandle = {
|
|
selectAggregationTemporality: () => AggregationTemporality.DELTA,
|
|
};
|
|
|
|
const cumulativeCollector: MetricCollectorHandle = {
|
|
selectAggregationTemporality: () => AggregationTemporality.CUMULATIVE,
|
|
};
|
|
|
|
describe('SyncMetricStorage', () => {
|
|
describe('record', () => {
|
|
it('no exceptions on record', () => {
|
|
const metricStorage = new SyncMetricStorage(
|
|
defaultInstrumentDescriptor,
|
|
new SumAggregator(true),
|
|
new NoopAttributesProcessor()
|
|
);
|
|
|
|
for (const value of commonValues) {
|
|
for (const attributes of commonAttributes) {
|
|
metricStorage.record(value, attributes, api.context.active(), [0, 0]);
|
|
}
|
|
}
|
|
});
|
|
});
|
|
|
|
describe('collect', () => {
|
|
describe('Delta Collector', () => {
|
|
const collectors = [deltaCollector];
|
|
it('should collect and reset memos', async () => {
|
|
const metricStorage = new SyncMetricStorage(
|
|
defaultInstrumentDescriptor,
|
|
new SumAggregator(true),
|
|
new NoopAttributesProcessor()
|
|
);
|
|
metricStorage.record(1, {}, api.context.active(), [0, 0]);
|
|
metricStorage.record(2, {}, api.context.active(), [1, 1]);
|
|
metricStorage.record(3, {}, api.context.active(), [2, 2]);
|
|
{
|
|
const metric = metricStorage.collect(
|
|
deltaCollector,
|
|
collectors,
|
|
[3, 3]
|
|
);
|
|
|
|
assertMetricData(metric, DataPointType.SUM);
|
|
assert.strictEqual(metric.dataPoints.length, 1);
|
|
assertDataPoint(metric.dataPoints[0], {}, 6, [0, 0], [3, 3]);
|
|
}
|
|
|
|
// The attributes should not be memorized.
|
|
{
|
|
const metric = metricStorage.collect(
|
|
deltaCollector,
|
|
collectors,
|
|
[4, 4]
|
|
);
|
|
|
|
assertMetricData(metric, DataPointType.SUM);
|
|
assert.strictEqual(metric.dataPoints.length, 0);
|
|
}
|
|
|
|
metricStorage.record(1, {}, api.context.active(), [5, 5]);
|
|
{
|
|
const metric = metricStorage.collect(
|
|
deltaCollector,
|
|
[deltaCollector],
|
|
[6, 6]
|
|
);
|
|
|
|
assertMetricData(metric, DataPointType.SUM);
|
|
assert.strictEqual(metric.dataPoints.length, 1);
|
|
assertDataPoint(metric.dataPoints[0], {}, 1, [5, 5], [6, 6]);
|
|
}
|
|
});
|
|
});
|
|
|
|
describe('Cumulative Collector', () => {
|
|
const collectors = [cumulativeCollector];
|
|
it('should collect cumulative metrics', async () => {
|
|
const metricStorage = new SyncMetricStorage(
|
|
defaultInstrumentDescriptor,
|
|
new SumAggregator(true),
|
|
new NoopAttributesProcessor()
|
|
);
|
|
metricStorage.record(1, {}, api.context.active(), [0, 0]);
|
|
metricStorage.record(2, {}, api.context.active(), [1, 1]);
|
|
metricStorage.record(3, {}, api.context.active(), [2, 2]);
|
|
{
|
|
const metric = metricStorage.collect(
|
|
cumulativeCollector,
|
|
collectors,
|
|
[3, 3]
|
|
);
|
|
|
|
assertMetricData(metric, DataPointType.SUM);
|
|
assert.strictEqual(metric.dataPoints.length, 1);
|
|
assertDataPoint(metric.dataPoints[0], {}, 6, [0, 0], [3, 3]);
|
|
}
|
|
|
|
// The attributes should be memorized.
|
|
{
|
|
const metric = metricStorage.collect(
|
|
cumulativeCollector,
|
|
collectors,
|
|
[4, 4]
|
|
);
|
|
|
|
assertMetricData(metric, DataPointType.SUM);
|
|
assert.strictEqual(metric.dataPoints.length, 1);
|
|
assertDataPoint(metric.dataPoints[0], {}, 6, [0, 0], [4, 4]);
|
|
}
|
|
|
|
metricStorage.record(1, {}, api.context.active(), [5, 5]);
|
|
{
|
|
const metric = metricStorage.collect(
|
|
cumulativeCollector,
|
|
collectors,
|
|
[6, 6]
|
|
);
|
|
|
|
assertMetricData(metric, DataPointType.SUM);
|
|
assert.strictEqual(metric.dataPoints.length, 1);
|
|
assertDataPoint(metric.dataPoints[0], {}, 7, [0, 0], [6, 6]);
|
|
}
|
|
});
|
|
});
|
|
});
|
|
});
|