mirror of
https://github.com/nasa/openmct.git
synced 2025-01-01 02:46:41 +00:00
168 lines
7.0 KiB
JavaScript
168 lines
7.0 KiB
JavaScript
/*****************************************************************************
|
|
* Open MCT, Copyright (c) 2014-2016, United States Government
|
|
* as represented by the Administrator of the National Aeronautics and Space
|
|
* Administration. All rights reserved.
|
|
*
|
|
* Open MCT is 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
|
|
* http://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.
|
|
*
|
|
* Open MCT includes source code licensed under additional open source
|
|
* licenses. See the Open Source Licenses file (LICENSES.md) included with
|
|
* this source code distribution or the Licensing information page available
|
|
* at runtime from the About dialog for additional information.
|
|
*****************************************************************************/
|
|
|
|
/**
|
|
* MergeModelsSpec. Created by vwoeltje on 11/6/14.
|
|
*/
|
|
define(
|
|
["../../src/elements/PlotLineBuffer"],
|
|
function (PlotLineBuffer) {
|
|
|
|
var TEST_INITIAL_SIZE = 10,
|
|
TEST_MAX_SIZE = 40,
|
|
TEST_DOMAIN_OFFSET = 42;
|
|
|
|
describe("A plot line buffer", function () {
|
|
var mockSeries,
|
|
testDomainValues,
|
|
testRangeValues,
|
|
buffer;
|
|
|
|
beforeEach(function () {
|
|
testDomainValues = [1, 3, 7, 9, 14, 15];
|
|
testRangeValues = [8, 0, 3, 9, 8, 11];
|
|
mockSeries = jasmine.createSpyObj(
|
|
"series",
|
|
['getPointCount', 'getDomainValue', 'getRangeValue']
|
|
);
|
|
mockSeries.getPointCount.andCallFake(function () {
|
|
return testDomainValues.length;
|
|
});
|
|
mockSeries.getDomainValue.andCallFake(function (i) {
|
|
return testDomainValues[i];
|
|
});
|
|
mockSeries.getRangeValue.andCallFake(function (i) {
|
|
return testRangeValues[i];
|
|
});
|
|
|
|
buffer = new PlotLineBuffer(
|
|
TEST_DOMAIN_OFFSET,
|
|
TEST_INITIAL_SIZE,
|
|
TEST_MAX_SIZE
|
|
);
|
|
|
|
// Start with some data in there
|
|
buffer.insert(mockSeries, 0);
|
|
});
|
|
|
|
it("allows insertion of series data", function () {
|
|
// Convert to a regular array for checking.
|
|
// Verify that domain/ranges were interleaved and
|
|
// that domain offset was adjusted for.
|
|
expect(
|
|
Array.prototype.slice.call(buffer.getBuffer()).slice(0, 12)
|
|
).toEqual([-41, 8, -39, 0, -35, 3, -33, 9, -28, 8, -27, 11]);
|
|
expect(buffer.getLength()).toEqual(6);
|
|
});
|
|
|
|
it("finds insertion indexes", function () {
|
|
expect(buffer.findInsertionIndex(0)).toEqual(0);
|
|
expect(buffer.findInsertionIndex(2)).toEqual(1);
|
|
expect(buffer.findInsertionIndex(5)).toEqual(2);
|
|
expect(buffer.findInsertionIndex(10)).toEqual(4);
|
|
expect(buffer.findInsertionIndex(14.5)).toEqual(5);
|
|
expect(buffer.findInsertionIndex(20)).toEqual(6);
|
|
});
|
|
|
|
it("allows insertion in the middle", function () {
|
|
var head = [-41, 8, -39, 0, -35, 3],
|
|
tail = [-33, 9, -28, 8, -27, 11];
|
|
buffer.insert(mockSeries, 3);
|
|
expect(
|
|
Array.prototype.slice.call(buffer.getBuffer()).slice(0, 24)
|
|
).toEqual(head.concat(head).concat(tail).concat(tail));
|
|
expect(buffer.getLength()).toEqual(12);
|
|
});
|
|
|
|
it("allows values to be trimmed from the start", function () {
|
|
buffer.trim(2);
|
|
expect(buffer.getLength()).toEqual(4);
|
|
expect(
|
|
Array.prototype.slice.call(buffer.getBuffer()).slice(0, 8)
|
|
).toEqual([-35, 3, -33, 9, -28, 8, -27, 11]);
|
|
});
|
|
|
|
it("expands buffer when needed to accommodate more data", function () {
|
|
var i;
|
|
|
|
// Initial underlying buffer should be twice initial size...
|
|
// (Since each pair will take up two elements)
|
|
expect(buffer.getBuffer().length).toEqual(20);
|
|
|
|
// Should be able to insert 6 series of 6 points each
|
|
// (After that, we'll hit the test max of 40)
|
|
for (i = 1; i < 15; i += 1) {
|
|
expect(buffer.insertPoint(i * 10, Math.sin(i), i))
|
|
.toBeTruthy();
|
|
}
|
|
|
|
// Buffer should have expanded in the process
|
|
expect(buffer.getBuffer().length).toEqual(40);
|
|
|
|
// Push to maximum size just to make sure...
|
|
for (i = 1; i < 150; i += 1) {
|
|
buffer.insertPoint(i * 10, Math.sin(i), i);
|
|
}
|
|
|
|
expect(buffer.getBuffer().length).toEqual(80);
|
|
});
|
|
|
|
it("ensures a maximum size", function () {
|
|
var i;
|
|
|
|
// Should be able to insert 6 series of 6 points each
|
|
// (After that, we'll hit the test max of 40)
|
|
for (i = 1; i < 6; i += 1) {
|
|
expect(buffer.getLength()).toEqual(6 * i);
|
|
expect(buffer.insert(mockSeries, Number.POSITIVE_INFINITY))
|
|
.toBeTruthy();
|
|
}
|
|
|
|
// Should be maxed out now
|
|
expect(buffer.getLength()).toEqual(36);
|
|
expect(buffer.insert(mockSeries, Number.POSITIVE_INFINITY))
|
|
.toBeFalsy();
|
|
expect(buffer.getLength()).toEqual(36);
|
|
|
|
});
|
|
|
|
it("reduces buffer size when space is no longer needed", function () {
|
|
// Check that actual buffer is sized to the initial size
|
|
// (double TEST_INITIAL_SIZE, since two elements are needed per
|
|
// point; one for domain, one for range)
|
|
expect(buffer.getBuffer().length).toEqual(20);
|
|
// Should have 6 elements now... grow to 24
|
|
buffer.insert(mockSeries, Number.POSITIVE_INFINITY);
|
|
buffer.insert(mockSeries, Number.POSITIVE_INFINITY);
|
|
buffer.insert(mockSeries, Number.POSITIVE_INFINITY);
|
|
// This should have doubled the actual buffer size
|
|
expect(buffer.getBuffer().length).toEqual(80);
|
|
// Remove some values
|
|
buffer.trim(20);
|
|
// Actual buffer size should have been reduced accordingly
|
|
expect(buffer.getBuffer().length).toBeLessThan(80);
|
|
});
|
|
|
|
});
|
|
}
|
|
);
|