From 146e948097ec2c81b6a32e6ab7d6e58bff2c234c Mon Sep 17 00:00:00 2001 From: Victor Woeltjen Date: Fri, 2 Oct 2015 16:46:42 -0700 Subject: [PATCH] [Time Conductor] Remove telemetry series wrapper WTD-1515 --- .../src/ConductorTelemetryDecorator.js | 40 +-------- .../conductor/src/ConductorTelemetrySeries.js | 71 --------------- .../test/ConductorTelemetryDecoratorSpec.js | 21 ----- .../test/ConductorTelemetrySeriesSpec.js | 86 ------------------- platform/features/conductor/test/suite.json | 1 - 5 files changed, 3 insertions(+), 216 deletions(-) delete mode 100644 platform/features/conductor/src/ConductorTelemetrySeries.js delete mode 100644 platform/features/conductor/test/ConductorTelemetrySeriesSpec.js diff --git a/platform/features/conductor/src/ConductorTelemetryDecorator.js b/platform/features/conductor/src/ConductorTelemetryDecorator.js index 9c8126c33f..ed16db7d1b 100644 --- a/platform/features/conductor/src/ConductorTelemetryDecorator.js +++ b/platform/features/conductor/src/ConductorTelemetryDecorator.js @@ -22,8 +22,7 @@ /*global define*/ define( - ['./ConductorTelemetrySeries'], - function (ConductorTelemetrySeries) { + function () { 'use strict'; /** @@ -42,32 +41,6 @@ define( this.telemetryService = telemetryService; } - // Strip out any realtime data series that is outside of the conductor's - // bounds. - ConductorTelemetryDecorator.prototype.pruneNonDisplayable = function (packaged) { - var conductor = this.conductorService.getConductor(), - repackaged = {}; - - function filterSource(packagedBySource) { - var repackagedBySource = {}; - - Object.keys(packagedBySource).forEach(function (k) { - repackagedBySource[k] = new ConductorTelemetrySeries( - packagedBySource[k], - conductor - ); - }); - - return repackagedBySource; - } - - Object.keys(packaged).forEach(function (source) { - repackaged[source] = filterSource(packaged[source]); - }); - - return repackaged; - }; - ConductorTelemetryDecorator.prototype.amendRequests = function (requests) { var conductor = this.conductorService.getConductor(), start = conductor.displayStart(), @@ -86,21 +59,14 @@ define( ConductorTelemetryDecorator.prototype.requestTelemetry = function (requests) { var self = this; return this.telemetryService - .requestTelemetry(this.amendRequests(requests)) - .then(function (packaged) { - return self.pruneNonDisplayable(packaged); - }); + .requestTelemetry(this.amendRequests(requests)); }; ConductorTelemetryDecorator.prototype.subscribe = function (callback, requests) { var self = this; - function internalCallback(packagedSeries) { - return callback(self.pruneNonDisplayable(packagedSeries)); - } - return this.telemetryService - .subscribe(internalCallback, this.amendRequests(requests)); + .subscribe(callback, this.amendRequests(requests)); }; return ConductorTelemetryDecorator; diff --git a/platform/features/conductor/src/ConductorTelemetrySeries.js b/platform/features/conductor/src/ConductorTelemetrySeries.js deleted file mode 100644 index aa6ec0ec63..0000000000 --- a/platform/features/conductor/src/ConductorTelemetrySeries.js +++ /dev/null @@ -1,71 +0,0 @@ -/***************************************************************************** - * Open MCT Web, Copyright (c) 2014-2015, United States Government - * as represented by the Administrator of the National Aeronautics and Space - * Administration. All rights reserved. - * - * Open MCT Web 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 Web 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. - *****************************************************************************/ - -/*global define*/ - -define( - function () { - 'use strict'; - - - /** - * Bound a series of telemetry such that it only includes - * points from within the time conductor's displayable window. - * - * @param {TelemetrySeries} series the telemetry series - * @param {platform/features/conductor.TimeConductor} the - * time conductor instance which bounds this series - * @constructor - * @implements {TelemetrySeries} - */ - function ConductorTelemetrySeries(series, conductor) { - var max = series.getPointCount() - 1; - - function binSearch(min, max, value) { - var mid = Math.floor((min + max) / 2); - - return min > max ? min : - series.getDomainValue(mid) < value ? - binSearch(mid + 1, max, value) : - binSearch(min, mid - 1, value); - } - - this.startIndex = binSearch(0, max, conductor.displayStart()); - this.endIndex = binSearch(0, max, conductor.displayEnd()); - this.series = series; - } - - ConductorTelemetrySeries.prototype.getPointCount = function () { - return Math.max(0, this.endIndex - this.startIndex); - }; - - ConductorTelemetrySeries.prototype.getDomainValue = function (i, d) { - return this.series.getDomainValue(i + this.startIndex, d); - }; - - ConductorTelemetrySeries.prototype.getRangeValue = function (i, r) { - return this.series.getRangeValue(i + this.startIndex, r); - }; - - return ConductorTelemetrySeries; - } -); diff --git a/platform/features/conductor/test/ConductorTelemetryDecoratorSpec.js b/platform/features/conductor/test/ConductorTelemetryDecoratorSpec.js index 84812b541a..9a5efc2448 100644 --- a/platform/features/conductor/test/ConductorTelemetryDecoratorSpec.js +++ b/platform/features/conductor/test/ConductorTelemetryDecoratorSpec.js @@ -110,27 +110,6 @@ define( }]); }); - it("prunes historical values to the displayable range", function () { - var packagedTelemetry; - decorator.requestTelemetry([{ source: "abc", key: "xyz" }]); - packagedTelemetry = mockPromise.then.mostRecentCall.args[0]({ - "abc": { "xyz": mockSeries } - }); - expect(seriesIsInWindow(packagedTelemetry.abc.xyz)) - .toBeTruthy(); - }); - - it("prunes subscribed values to the displayable range", function () { - var mockCallback = jasmine.createSpy('callback'), - packagedTelemetry; - decorator.subscribe(mockCallback, [{ source: "abc", key: "xyz" }]); - mockTelemetryService.subscribe.mostRecentCall.args[0]({ - "abc": { "xyz": mockSeries } - }); - packagedTelemetry = mockCallback.mostRecentCall.args[0]; - expect(seriesIsInWindow(packagedTelemetry.abc.xyz)) - .toBeTruthy(); - }); }); } diff --git a/platform/features/conductor/test/ConductorTelemetrySeriesSpec.js b/platform/features/conductor/test/ConductorTelemetrySeriesSpec.js deleted file mode 100644 index ea884f74f3..0000000000 --- a/platform/features/conductor/test/ConductorTelemetrySeriesSpec.js +++ /dev/null @@ -1,86 +0,0 @@ -/***************************************************************************** - * Open MCT Web, Copyright (c) 2014-2015, United States Government - * as represented by the Administrator of the National Aeronautics and Space - * Administration. All rights reserved. - * - * Open MCT Web 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 Web 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. - *****************************************************************************/ -/*global define,describe,it,expect,beforeEach,waitsFor,jasmine*/ - -define( - ["../src/ConductorTelemetrySeries"], - function (ConductorTelemetrySeries) { - "use strict"; - - describe("ConductorTelemetrySeries", function () { - var mockSeries, - mockConductor, - testArray, - series; - - beforeEach(function () { - testArray = [ -10, 0, 42, 1977, 12321 ]; - - mockSeries = jasmine.createSpyObj( - 'series', - [ 'getPointCount', 'getDomainValue', 'getRangeValue' ] - ); - mockConductor = jasmine.createSpyObj( - 'conductor', - [ 'queryStart', 'queryEnd', 'displayStart', 'displayEnd' ] - ); - - mockSeries.getPointCount.andCallFake(function () { - return testArray.length; - }); - mockSeries.getDomainValue.andCallFake(function (i) { - return testArray[i]; - }); - mockSeries.getRangeValue.andCallFake(function (i) { - return testArray[i] * 2; - }); - - mockConductor.displayStart.andReturn(0); - mockConductor.displayEnd.andReturn(2000); - - series = new ConductorTelemetrySeries( - mockSeries, - mockConductor - ); - }); - - it("reduces the apparent size of a series", function () { - expect(series.getPointCount()).toEqual(3); - }); - - it("maps domain value indexes to the displayable range", function () { - [0, 1, 2].forEach(function (i) { - expect(series.getDomainValue(i)) - .toEqual(mockSeries.getDomainValue(i + 1)); - }); - }); - - it("maps range value indexes to the displayable range", function () { - [0, 1, 2].forEach(function (i) { - expect(series.getRangeValue(i)) - .toEqual(mockSeries.getRangeValue(i + 1)); - }); - }); - - }); - } -); diff --git a/platform/features/conductor/test/suite.json b/platform/features/conductor/test/suite.json index 0c469617de..9343b8e422 100644 --- a/platform/features/conductor/test/suite.json +++ b/platform/features/conductor/test/suite.json @@ -2,6 +2,5 @@ "ConductorRepresenter", "ConductorService", "ConductorTelemetryDecorator", - "ConductorTelemetrySeries", "TimeConductor" ]