mirror of
https://github.com/nasa/openmct.git
synced 2025-01-27 14:49:28 +00:00
bea5002752
Add test cases related to throttled loading of domain objects to index, nasa/openmctweb#141.
294 lines
11 KiB
JavaScript
294 lines
11 KiB
JavaScript
/*****************************************************************************
|
|
* 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,jasmine*/
|
|
|
|
/**
|
|
* SearchSpec. Created by shale on 07/31/2015.
|
|
*/
|
|
define(
|
|
["../../src/services/GenericSearchProvider"],
|
|
function (GenericSearchProvider) {
|
|
"use strict";
|
|
|
|
describe("The generic search provider ", function () {
|
|
var mockQ,
|
|
mockLog,
|
|
mockThrottle,
|
|
mockDeferred,
|
|
mockObjectService,
|
|
mockObjectPromise,
|
|
mockChainedPromise,
|
|
mockDomainObjects,
|
|
mockCapability,
|
|
mockCapabilityPromise,
|
|
mockWorkerService,
|
|
mockWorker,
|
|
mockTopic,
|
|
mockMutationTopic,
|
|
mockRoots = ['root1', 'root2'],
|
|
mockThrottledFn,
|
|
throttledCallCount,
|
|
provider,
|
|
mockProviderResults;
|
|
|
|
function resolveObjectPromises() {
|
|
var i;
|
|
for (i = 0; i < mockObjectPromise.then.calls.length; i += 1) {
|
|
mockChainedPromise.then.calls[i].args[0](
|
|
mockObjectPromise.then.calls[i]
|
|
.args[0](mockDomainObjects)
|
|
);
|
|
}
|
|
}
|
|
|
|
function resolveThrottledFn() {
|
|
if (mockThrottledFn.calls.length > throttledCallCount) {
|
|
mockThrottle.mostRecentCall.args[0]();
|
|
throttledCallCount = mockThrottledFn.calls.length;
|
|
}
|
|
}
|
|
|
|
function resolveAsyncTasks() {
|
|
resolveThrottledFn();
|
|
resolveObjectPromises();
|
|
}
|
|
|
|
beforeEach(function () {
|
|
mockQ = jasmine.createSpyObj(
|
|
"$q",
|
|
[ "defer" ]
|
|
);
|
|
mockLog = jasmine.createSpyObj(
|
|
"$log",
|
|
[ "error", "warn", "info", "debug" ]
|
|
);
|
|
mockDeferred = jasmine.createSpyObj(
|
|
"deferred",
|
|
[ "resolve", "reject"]
|
|
);
|
|
mockDeferred.promise = "mock promise";
|
|
mockQ.defer.andReturn(mockDeferred);
|
|
|
|
mockThrottle = jasmine.createSpy("throttle");
|
|
mockThrottledFn = jasmine.createSpy("throttledFn");
|
|
throttledCallCount = 0;
|
|
|
|
mockObjectService = jasmine.createSpyObj(
|
|
"objectService",
|
|
[ "getObjects" ]
|
|
);
|
|
mockObjectPromise = jasmine.createSpyObj(
|
|
"promise",
|
|
[ "then", "catch" ]
|
|
);
|
|
mockChainedPromise = jasmine.createSpyObj(
|
|
"chainedPromise",
|
|
[ "then" ]
|
|
);
|
|
mockObjectService.getObjects.andReturn(mockObjectPromise);
|
|
|
|
mockTopic = jasmine.createSpy('topic');
|
|
|
|
mockWorkerService = jasmine.createSpyObj(
|
|
"workerService",
|
|
[ "run" ]
|
|
);
|
|
mockWorker = jasmine.createSpyObj(
|
|
"worker",
|
|
[ "postMessage" ]
|
|
);
|
|
mockWorkerService.run.andReturn(mockWorker);
|
|
|
|
mockCapabilityPromise = jasmine.createSpyObj(
|
|
"promise",
|
|
[ "then", "catch" ]
|
|
);
|
|
|
|
mockDomainObjects = {};
|
|
['a', 'root1', 'root2'].forEach(function (id) {
|
|
mockDomainObjects[id] = (
|
|
jasmine.createSpyObj(
|
|
"domainObject",
|
|
[
|
|
"getId",
|
|
"getModel",
|
|
"hasCapability",
|
|
"getCapability",
|
|
"useCapability"
|
|
]
|
|
)
|
|
);
|
|
mockDomainObjects[id].getId.andReturn(id);
|
|
mockDomainObjects[id].getCapability.andReturn(mockCapability);
|
|
mockDomainObjects[id].useCapability.andReturn(mockCapabilityPromise);
|
|
mockDomainObjects[id].getModel.andReturn({});
|
|
});
|
|
|
|
mockCapability = jasmine.createSpyObj(
|
|
"capability",
|
|
[ "invoke", "listen" ]
|
|
);
|
|
mockCapability.invoke.andReturn(mockCapabilityPromise);
|
|
mockDomainObjects.a.getCapability.andReturn(mockCapability);
|
|
mockMutationTopic = jasmine.createSpyObj(
|
|
'mutationTopic',
|
|
[ 'listen' ]
|
|
);
|
|
mockTopic.andCallFake(function (key) {
|
|
return key === 'mutation' && mockMutationTopic;
|
|
});
|
|
mockThrottle.andReturn(mockThrottledFn);
|
|
mockObjectPromise.then.andReturn(mockChainedPromise);
|
|
|
|
provider = new GenericSearchProvider(
|
|
mockQ,
|
|
mockLog,
|
|
mockThrottle,
|
|
mockObjectService,
|
|
mockWorkerService,
|
|
mockTopic,
|
|
mockRoots
|
|
);
|
|
});
|
|
|
|
it("indexes tree on initialization", function () {
|
|
var i;
|
|
|
|
resolveThrottledFn();
|
|
|
|
expect(mockObjectService.getObjects).toHaveBeenCalled();
|
|
expect(mockObjectPromise.then).toHaveBeenCalled();
|
|
|
|
// Call through the root-getting part
|
|
resolveObjectPromises();
|
|
|
|
mockRoots.forEach(function (id) {
|
|
expect(mockWorker.postMessage).toHaveBeenCalledWith({
|
|
request: 'index',
|
|
model: mockDomainObjects[id].getModel(),
|
|
id: id
|
|
});
|
|
});
|
|
});
|
|
|
|
it("indexes members of composition", function () {
|
|
mockDomainObjects.root1.getModel.andReturn({
|
|
composition: ['a']
|
|
});
|
|
|
|
resolveAsyncTasks();
|
|
resolveAsyncTasks();
|
|
|
|
expect(mockWorker.postMessage).toHaveBeenCalledWith({
|
|
request: 'index',
|
|
model: mockDomainObjects.a.getModel(),
|
|
id: 'a'
|
|
});
|
|
});
|
|
|
|
it("listens for changes to mutation", function () {
|
|
expect(mockMutationTopic.listen)
|
|
.toHaveBeenCalledWith(jasmine.any(Function));
|
|
mockMutationTopic.listen.mostRecentCall
|
|
.args[0](mockDomainObjects.a);
|
|
|
|
resolveAsyncTasks();
|
|
|
|
expect(mockWorker.postMessage).toHaveBeenCalledWith({
|
|
request: 'index',
|
|
model: mockDomainObjects.a.getModel(),
|
|
id: mockDomainObjects.a.getId()
|
|
});
|
|
});
|
|
|
|
it("sends search queries to the worker", function () {
|
|
var timestamp = Date.now();
|
|
provider.query(' test "query" ', timestamp, 1, 2);
|
|
expect(mockWorker.postMessage).toHaveBeenCalledWith({
|
|
request: "search",
|
|
input: ' test "query" ',
|
|
timestamp: timestamp,
|
|
maxNumber: 1,
|
|
timeout: 2
|
|
});
|
|
});
|
|
|
|
it("gives an empty result for an empty query", function () {
|
|
var timestamp = Date.now(),
|
|
queryOutput;
|
|
|
|
queryOutput = provider.query('', timestamp, 1, 2);
|
|
expect(queryOutput.hits).toEqual([]);
|
|
expect(queryOutput.total).toEqual(0);
|
|
|
|
queryOutput = provider.query();
|
|
expect(queryOutput.hits).toEqual([]);
|
|
expect(queryOutput.total).toEqual(0);
|
|
});
|
|
|
|
it("handles responses from the worker", function () {
|
|
var timestamp = Date.now(),
|
|
event = {
|
|
data: {
|
|
request: "search",
|
|
results: {
|
|
1: 1,
|
|
2: 2
|
|
},
|
|
total: 2,
|
|
timedOut: false,
|
|
timestamp: timestamp
|
|
}
|
|
};
|
|
|
|
provider.query(' test "query" ', timestamp);
|
|
mockWorker.onmessage(event);
|
|
mockObjectPromise.then.mostRecentCall.args[0](mockDomainObjects);
|
|
expect(mockDeferred.resolve).toHaveBeenCalled();
|
|
});
|
|
|
|
it("warns when objects are unavailable", function () {
|
|
resolveAsyncTasks();
|
|
expect(mockLog.warn).not.toHaveBeenCalled();
|
|
mockChainedPromise.then.mostRecentCall.args[0](
|
|
mockObjectPromise.then.mostRecentCall.args[1]()
|
|
);
|
|
expect(mockLog.warn).toHaveBeenCalled();
|
|
});
|
|
|
|
it("throttles the loading of objects to index", function () {
|
|
expect(mockObjectService.getObjects).not.toHaveBeenCalled();
|
|
resolveThrottledFn();
|
|
expect(mockObjectService.getObjects).toHaveBeenCalled();
|
|
});
|
|
|
|
it("logs when all objects have been processed", function () {
|
|
expect(mockLog.info).not.toHaveBeenCalled();
|
|
resolveAsyncTasks();
|
|
resolveThrottledFn();
|
|
expect(mockLog.info).toHaveBeenCalled();
|
|
});
|
|
|
|
});
|
|
}
|
|
);
|