mirror of
https://github.com/nasa/openmct.git
synced 2025-01-07 05:38:42 +00:00
0a19ab4389
open #90 Squashed commit of the following: commita2d06583ca
Merge:74f289c
5d5425d
Author: Victor Woeltjen <victor.woeltjen@nasa.gov> Date: Tue Oct 27 14:04:49 2015 -0700 Merge pull request #216 from nasa/open-vista54a Review and integrate open-vista54a into master commit5d5425db04
Author: Charles Hacskaylo <charlesh88@gmail.com> Date: Tue Oct 27 11:50:16 2015 -0700 [Frontend] Finessing and verifying CSS vista#54 Verified against fixed position and scrolling views using SineWave generator; font-size of glyph tweaked; commita8856c0612
Author: Charles Hacskaylo <charlesh88@gmail.com> Date: Tue Oct 27 11:40:35 2015 -0700 [Frontend] Platform-specific mods to limits vista#54 Refactor limits into multiple classes, separating upr/lwr from red/yellow; Modded SineWaveLimitCapability accordingly; Normalized upr/lwr glyphs; (cherry picked from commit a26d71b) commit74f289cb34
Merge:4ec243c
29bdc9d
Author: akhenry <akhenry@gmail.com> Date: Tue Oct 27 10:48:33 2015 -0700 Merge pull request #206 from nasa/open150b [Plot] Ignore empty lines commit4ec243c6fb
Merge:407d988
3d996ac
Author: Victor Woeltjen <victor.woeltjen@nasa.gov> Date: Sat Oct 24 07:48:45 2015 -0700 Merge pull request #212 from nasa/open211 [RequireJS] Specify path for uuid commit407d9881ff
Merge:6ee622b
21739ff
Author: akhenry <akhenry@gmail.com> Date: Fri Oct 23 19:16:51 2015 -0700 Merge pull request #200 from nasa/open-toc [Documentation] Add table of contents commit6ee622b3f5
Merge:099d70b
87e317a
Author: akhenry <akhenry@gmail.com> Date: Fri Oct 23 17:04:04 2015 -0700 Merge pull request #192 from nasa/open153 [CI] Remove non-existent bundle from procfile commit099d70b8d9
Merge:90828ef
8e2a2ee
Author: akhenry <akhenry@gmail.com> Date: Fri Oct 23 17:00:46 2015 -0700 Merge pull request #175 from nasa/open147 [Entanglement] Add "Go To Original" action commit3d996ac466
Author: Pete Richards <peter.l.richards@nasa.gov> Date: Fri Oct 23 16:32:05 2015 -0700 [RequireJS] Specify path for uuid Specify path for uuid, making it available for any code that would require it, without that code needing to know the path to it. Fixes https://github.com/nasa/openmctweb/issues/211. commit90828ef63d
Merge:bf24ac7
dbebf08
Author: Pete Richards <peter.l.richards@nasa.gov> Date: Fri Oct 23 16:23:29 2015 -0700 Merge remote-tracking branch 'github-open/open181' into open-master commit29bdc9d574
Author: Victor Woeltjen <victor.woeltjen@nasa.gov> Date: Fri Oct 23 13:04:06 2015 -0700 [Plot] Ignore empty lines Ignore empty lines (plot lines with no data) when determining domain extrema; avoids failure to draw multiple plot lines in a telemetry panel, nasa/openmctweb#150. commitbf24ac7c93
Author: Victor Woeltjen <victor.woeltjen@nasa.gov> Date: Fri Oct 23 12:14:46 2015 -0700 [Search] Update field name Update field name in GenericSearchProvider to reflect changes from nasa/openmctweb#193. Avoids exceptions on mutation. Additionally, add test case exercising relevant code and verifying that reindexing is scheduled upon mutation as expected. commit59f094763b
Merge:3080861
496cf85
Author: Victor Woeltjen <victor.woeltjen@nasa.gov> Date: Thu Oct 22 16:58:02 2015 -0700 Merge pull request #193 from nasa/search-performance Search performance commitdbebf08500
Author: Victor Woeltjen <victor.woeltjen@nasa.gov> Date: Wed Oct 21 15:38:58 2015 -0700 [Time Controller] Add test cases ...to verify behavior on text entry of dates. commit847c356063
Author: Victor Woeltjen <victor.woeltjen@nasa.gov> Date: Wed Oct 21 15:26:42 2015 -0700 [Time Controller] Change color when input is invalid nasa/openmctweb#181 commit06bcd28558
Author: Victor Woeltjen <victor.woeltjen@nasa.gov> Date: Wed Oct 21 15:22:00 2015 -0700 [Time Controller] Keep inputs in sync Keep inputs in sync with displayed data in time controller, without overwriting user-entered text. nasa/openmctweb#181 commitf88e8ebb51
Author: Victor Woeltjen <victor.woeltjen@nasa.gov> Date: Wed Oct 21 15:08:44 2015 -0700 [Time Controller] Update model state for text entry commit6d2b2fd81e
Author: Victor Woeltjen <victor.woeltjen@nasa.gov> Date: Wed Oct 21 14:46:12 2015 -0700 [Time Controller] Parse user-entered timestamps nasa/openmctweb#181. commit608800ae63
Merge:07818b0
fb0ce1e
Author: Victor Woeltjen <victor.woeltjen@nasa.gov> Date: Wed Oct 21 14:40:42 2015 -0700 Merge remote-tracking branch 'github/master' into open181 Conflicts: platform/commonUI/general/res/templates/controls/time-controller.html commit07818b0a6d
Author: Victor Woeltjen <victor.woeltjen@nasa.gov> Date: Wed Oct 21 14:35:18 2015 -0700 [Time Controller] Show bounds in a text field Show bounds in a text field to allow user editing; supports manual editing of time controller bounds, nasa/openmctweb#181. commit496cf85b7e
Author: Pete Richards <peter.l.richards@nasa.gov> Date: Wed Oct 21 09:46:32 2015 -0700 [JSDoc] Correct mistake commit833f57e284
Author: Pete Richards <peter.l.richards@nasa.gov> Date: Wed Oct 21 07:39:59 2015 -0700 [Search] Don't block UI between requests Timeout subsequent calls to keepIndexing at the end of a indexRequest, so that UI operations are not blocked. commit9a63e99710
Author: Pete Richards <peter.l.richards@nasa.gov> Date: Tue Oct 20 16:01:42 2015 -0700 [Search] Add spec for ElasticSearchProvider Add spec coverage for ElasticSearchProvider. Also remove unneeded guards for max number of results, as the aggregator will always provide a max number of results. commit21739fffd9
Author: Victor Woeltjen <victor.woeltjen@nasa.gov> Date: Tue Oct 20 15:52:49 2015 -0700 [Documentation] Add table of contents Add table of contents to generated documents, without modifying document sources; nasa/openmctweb#189. commit77d81f899b
Author: Pete Richards <peter.l.richards@nasa.gov> Date: Tue Oct 20 15:31:33 2015 -0700 [Style] JSLint compliance commitfe3263fdfe
Author: Pete Richards <peter.l.richards@nasa.gov> Date: Tue Oct 20 15:27:46 2015 -0700 [Search] Remove invalid specs commitce42429fbd
Author: Pete Richards <peter.l.richards@nasa.gov> Date: Tue Oct 20 15:14:43 2015 -0700 [Search] expose constants, add fudge factor The SearchAggregator exposes it's constants to add stability to tests. It also has a fudge factor which increaases the number of results it requests from providers to better support pagination when using client side filtering. commit76151d09a0
Author: Pete Richards <peter.l.richards@nasa.gov> Date: Tue Oct 20 15:13:37 2015 -0700 [Search] use service for filters, add spec Add a spec for the SearchController, and use the SearchService to execute filters by supplying a filterPredicate. commitec7e6cc5b4
Author: Pete Richards <peter.l.richards@nasa.gov> Date: Tue Oct 20 13:55:46 2015 -0700 [Search] Update spec for Generic Search Worker commit1ddce48f7e
Author: Pete Richards <peter.l.richards@nasa.gov> Date: Tue Oct 20 13:12:04 2015 -0700 [Search] Specs for GenericSearchProvider Write specs for GenericSearchProvider and resolve some implementation bugs they uncovered. commit98b5ff3c77
Author: Pete Richards <peter.l.richards@nasa.gov> Date: Fri Oct 16 18:14:33 2015 -0700 [Search] Decrement number of pending requests commit14094a48fc
Author: Pete Richards <peter.l.richards@nasa.gov> Date: Fri Oct 16 17:33:23 2015 -0700 [Search] Remove old specs in prep for rewrite Remove old specs in prep for rewrite. commit8e2a2eeba5
Author: Victor Woeltjen <victor.woeltjen@nasa.gov> Date: Mon Oct 19 12:08:49 2015 -0700 [Entanglement] Add license headers ...per code review feedback from nasa/openmctweb#175 commit0f63e4dde9
Author: Pete Richards <peter.l.richards@nasa.gov> Date: Fri Oct 16 17:06:23 2015 -0700 [Tests] Rewrite search aggregator specs commit12efb47be7
Author: Pete Richards <peter.l.richards@nasa.gov> Date: Fri Oct 16 16:09:51 2015 -0700 [Search] Remove timeouts and timestamps Remove timeouts and timestamps which were not effectively doing anything. commita2fce8e56c
Author: Pete Richards <peter.l.richards@nasa.gov> Date: Fri Oct 16 16:05:31 2015 -0700 [Search] Rewrite elasticsearch provider with prototype Rewrite the elasticsearch provider to use prototypes and clean up the implementation. Now returns a modelResults object to keep it in line with the general search provider. commit78e5c0143b
Author: Pete Richards <peter.l.richards@nasa.gov> Date: Fri Oct 16 15:26:46 2015 -0700 [Search] Overhaul generic search provider Rewrite the generic search provider to use prototypes. Increase performance by utilizing the model service instead of the object service, and use a simplified method of request queueing. commit099591ad2e
Author: Pete Richards <peter.l.richards@nasa.gov> Date: Fri Oct 16 15:26:04 2015 -0700 [Search] Aggregator returns objects, providers return models Search providers return search results as models for domain objects, as the actual number of max results is enforced by the aggregator, and because the individual providers store and return the models for their objects already. This lowers the amount of resources consumed instantiating domain objects, and also allows the individual search providers to implement function-based filtering on domain object models, which is beneficial as it allows the search filtering in the search controller to be done before paginating of results. commitb5505f372f
Author: Pete Richards <peter.l.richards@nasa.gov> Date: Fri Oct 16 12:39:41 2015 -0700 [Search] Generic Worker Performance Tweaks The generic search worker now does indexing work during the index operation, ensuring that queries do not have to do extraneous or repeat calculations. Change the return format slightly and fixed a bug in the GenericSearchProvider which caused more objects than intended to be returned from the provider. commit9ad860babd
Author: Pete Richards <peter.l.richards@nasa.gov> Date: Fri Oct 16 12:34:47 2015 -0700 [Search] Rewrite search controller, tidy Rewrite the search controller, making numerous changes and using prototypical style. First, the search controller immediately hides previous results when a new search is started. Secondly, the search controller ensures that search results displayed match the currently entered query, preventing race conditions. Finally, the search controller uses a poor filtering option that means it may not display all results. commit87e317a6f5
Author: Pete Richards <peter.l.richards@nasa.gov> Date: Fri Oct 16 11:33:42 2015 -0700 [CI] Remove non-existent bundle from procfile Remove the example/localstorage bundle from the procfile. Fixes #153. commitbf41d82a78
Author: Victor Woeltjen <victor.woeltjen@nasa.gov> Date: Tue Oct 6 16:50:35 2015 -0700 [Entanglement] Restore missing specs Restore specs which had been omitted from suite.json (but currently succeed for the relevant scripts); done in the context of nasa/openmctweb#147 commita4944717a1
Author: Victor Woeltjen <victor.woeltjen@nasa.gov> Date: Tue Oct 6 16:47:37 2015 -0700 [Location] Test getOriginal method commit70bbd3cf97
Author: Victor Woeltjen <victor.woeltjen@nasa.gov> Date: Tue Oct 6 16:37:37 2015 -0700 [Entanglement] Add test cases for Go To Original commite3afaf0842
Author: Victor Woeltjen <victor.woeltjen@nasa.gov> Date: Tue Oct 6 16:22:16 2015 -0700 [Entanglement] Add Go To Original nasa/openmctweb#147 commit60f2f9fb6c
Author: Victor Woeltjen <victor.woeltjen@nasa.gov> Date: Tue Oct 6 16:08:48 2015 -0700 [Location] Add getOriginal method Add a getOriginal method to the location capability, to simplify loading of original versions of objects. nasa/openmctweb#147
224 lines
7.3 KiB
JavaScript
224 lines
7.3 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,runs,waitsFor,beforeEach,jasmine,Worker,
|
|
require,afterEach*/
|
|
|
|
/**
|
|
* SearchSpec. Created by shale on 07/31/2015.
|
|
*/
|
|
define([
|
|
|
|
], function (
|
|
|
|
) {
|
|
'use strict';
|
|
|
|
describe('GenericSearchWorker', function () {
|
|
// If this test fails, make sure this path is correct
|
|
var worker,
|
|
objectX,
|
|
objectY,
|
|
objectZ,
|
|
itemsToIndex,
|
|
onMessage,
|
|
data,
|
|
waitForResult;
|
|
|
|
beforeEach(function () {
|
|
worker = new Worker(
|
|
require.toUrl('platform/search/src/services/GenericSearchWorker.js')
|
|
);
|
|
|
|
objectX = {
|
|
id: 'x',
|
|
model: {name: 'object xx'}
|
|
};
|
|
objectY = {
|
|
id: 'y',
|
|
model: {name: 'object yy'}
|
|
};
|
|
objectZ = {
|
|
id: 'z',
|
|
model: {name: 'object zz'}
|
|
};
|
|
itemsToIndex = [
|
|
objectX,
|
|
objectY,
|
|
objectZ
|
|
];
|
|
|
|
itemsToIndex.forEach(function (item) {
|
|
worker.postMessage({
|
|
request: 'index',
|
|
id: item.id,
|
|
model: item.model
|
|
});
|
|
});
|
|
|
|
onMessage = jasmine.createSpy('onMessage');
|
|
worker.addEventListener('message', onMessage);
|
|
|
|
waitForResult = function () {
|
|
waitsFor(function () {
|
|
if (onMessage.calls.length > 0) {
|
|
data = onMessage.calls[0].args[0].data;
|
|
return true;
|
|
}
|
|
return false;
|
|
});
|
|
};
|
|
});
|
|
|
|
afterEach(function () {
|
|
worker.terminate();
|
|
});
|
|
|
|
it('returns search results for partial term matches', function () {
|
|
|
|
worker.postMessage({
|
|
request: 'search',
|
|
input: 'obj',
|
|
maxResults: 100,
|
|
queryId: 123
|
|
});
|
|
|
|
waitForResult();
|
|
|
|
runs(function () {
|
|
expect(onMessage).toHaveBeenCalled();
|
|
|
|
expect(data.request).toBe('search');
|
|
expect(data.total).toBe(3);
|
|
expect(data.queryId).toBe(123);
|
|
expect(data.results.length).toBe(3);
|
|
expect(data.results[0].item.id).toBe('x');
|
|
expect(data.results[0].item.model).toEqual(objectX.model);
|
|
expect(data.results[0].matchCount).toBe(1);
|
|
expect(data.results[1].item.id).toBe('y');
|
|
expect(data.results[1].item.model).toEqual(objectY.model);
|
|
expect(data.results[1].matchCount).toBe(1);
|
|
expect(data.results[2].item.id).toBe('z');
|
|
expect(data.results[2].item.model).toEqual(objectZ.model);
|
|
expect(data.results[2].matchCount).toBe(1);
|
|
});
|
|
});
|
|
|
|
it('scores exact term matches higher', function () {
|
|
worker.postMessage({
|
|
request: 'search',
|
|
input: 'object',
|
|
maxResults: 100,
|
|
queryId: 234
|
|
});
|
|
|
|
waitForResult();
|
|
|
|
runs(function () {
|
|
expect(data.queryId).toBe(234);
|
|
expect(data.results.length).toBe(3);
|
|
expect(data.results[0].item.id).toBe('x');
|
|
expect(data.results[0].matchCount).toBe(1.5);
|
|
});
|
|
});
|
|
|
|
it('can find partial term matches', function () {
|
|
worker.postMessage({
|
|
request: 'search',
|
|
input: 'x',
|
|
maxResults: 100,
|
|
queryId: 345
|
|
});
|
|
|
|
waitForResult();
|
|
|
|
runs(function () {
|
|
expect(data.queryId).toBe(345);
|
|
expect(data.results.length).toBe(1);
|
|
expect(data.results[0].item.id).toBe('x');
|
|
expect(data.results[0].matchCount).toBe(1);
|
|
});
|
|
});
|
|
|
|
it('matches individual terms', function () {
|
|
worker.postMessage({
|
|
request: 'search',
|
|
input: 'x y z',
|
|
maxResults: 100,
|
|
queryId: 456
|
|
});
|
|
|
|
waitForResult();
|
|
|
|
runs(function () {
|
|
expect(data.queryId).toBe(456);
|
|
expect(data.results.length).toBe(3);
|
|
expect(data.results[0].item.id).toBe('x');
|
|
expect(data.results[0].matchCount).toBe(1);
|
|
expect(data.results[1].item.id).toBe('y');
|
|
expect(data.results[1].matchCount).toBe(1);
|
|
expect(data.results[2].item.id).toBe('z');
|
|
expect(data.results[1].matchCount).toBe(1);
|
|
});
|
|
});
|
|
|
|
it('scores exact matches highest', function () {
|
|
worker.postMessage({
|
|
request: 'search',
|
|
input: 'object xx',
|
|
maxResults: 100,
|
|
queryId: 567
|
|
});
|
|
|
|
waitForResult();
|
|
|
|
runs(function () {
|
|
expect(data.queryId).toBe(567);
|
|
expect(data.results.length).toBe(3);
|
|
expect(data.results[0].item.id).toBe('x');
|
|
expect(data.results[0].matchCount).toBe(103);
|
|
expect(data.results[1].matchCount).toBe(1.5);
|
|
expect(data.results[2].matchCount).toBe(1.5);
|
|
});
|
|
});
|
|
|
|
it('scores multiple term match above single match', function () {
|
|
worker.postMessage({
|
|
request: 'search',
|
|
input: 'obj x',
|
|
maxResults: 100,
|
|
queryId: 678
|
|
});
|
|
|
|
waitForResult();
|
|
|
|
runs(function () {
|
|
expect(data.queryId).toBe(678);
|
|
expect(data.results.length).toBe(3);
|
|
expect(data.results[0].item.id).toBe('x');
|
|
expect(data.results[0].matchCount).toBe(2);
|
|
expect(data.results[1].matchCount).toBe(1);
|
|
expect(data.results[2].matchCount).toBe(1);
|
|
});
|
|
});
|
|
});
|
|
});
|