mirror of
https://github.com/nasa/openmct.git
synced 2025-05-31 14:40:48 +00:00
* Bump d3-selection from 1.3.2 to 3.0.0 Bumps [d3-selection](https://github.com/d3/d3-selection) from 1.3.2 to 3.0.0. - [Release notes](https://github.com/d3/d3-selection/releases) - [Commits](https://github.com/d3/d3-selection/compare/v1.3.2...v3.0.0) --- updated-dependencies: - dependency-name: d3-selection dependency-type: direct:development update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] <support@github.com> * Remove snapshot * Fix imagery filter slider drag in flexible layouts (#5326) (#5350) * Dont' mutate a stacked plot unless its user initiated (#5357) * Port grid icons and imagery test to release 2.0.5 from master (#5360) * Port grid icons to release 2.0.5 from master * Port imagery test to release/2.0.5 * Restrict timestrip composition to time based plots, plans and imagery (#5161) * Restrict timestrip composition to time based plots, plans and imagery * Adds unit tests for timeline composition policy * Addresses review comments Improves tests * Reuse test objects Co-authored-by: Jamie V <jamie.j.vigliotta@nasa.gov> * Include objectStyles reference to conditionSetIdentifier in imports (#5354) * Include objectStyles reference to conditionSetIdentifier in imports * Add tests for export * Refactored some code and removed console log * Remove workarounds for chrome 'scrollTop' issue (#5375) * Fix naming of method (#5368) * Imagery View does not discard old images when they fall out of bounds (#5351) * change to using telemetry collection * fix tests * added more unit tests * Cherrypicked commits (#5390) Co-authored-by: unlikelyzero <jchill2@gmail.com> * [Timer] Update 3dot menu actions appropriately (#5387) * Call `removeAllListeners()` after emit * Manually show/hide actions if within a view * remove sneaky `console.log()` * Add Timer e2e test * Add to comments * Avoid hard waits in Timer e2e test - Assert against timer view state instead of menu options * Let's also test actions from the Timer view * 5391 Add preview and drag support to Grand Search (#5394) * add preview and drag actions * added unit test, simplified remove action * do not hide search results in preview mode when clicking outside search results * add semantic aria labels to enable e2e tests * readd preview * add e2e test * remove commented out url * add percy snapshot and add search to ci * make percy stuff work * linting * fix percy again * move percy snapshots to a visual test * added separate visual test and changed test to fixtures * fix fixtures path * addressing review comments * 5361 tags not persisting locally (#5408) * fixed typo * remove unneeded lookup * fix tags adding and deleting * more reliable way to remove tags * break tests up for parallel execution * fixed notebook tagging test * enable e2e tests * made schedule index comment more clear and fix uppercase/lowercase issue * address e2e changes * add unit test to bump coverage * fix typo * need to check on annotation creation if provider exists or not * added fixtures * undo silly couchdb commit * Plot progress bar fix for 2.0.5 (#5386) * Add .bind(this) to stopLoading() in loadMoreData() * Replace load spinner with progress bar for plots * Add loading delay prop to swg * fix linting errors * match load order * Update accessibility * Add Math.max to timeout to handle negative inputs * Moved math.max to load delay variable * Add loading fix for stacked plots * Move loadingUpdate func into plot item for update * Merge conflict resolve * Check if delay is 0 and send, put post in a func * Put obj directly to model, removed computed prop * Lint fix * Fix template where legend was not displayed * Remove commented out template * Fixed failing test Co-authored-by: unlikelyzero <jchill2@gmail.com> * Make plans non editable. (#5377) * Make plans non editable. * Add unit test for fix * [CouchDB] Better determination of indicator status (#5415) * Add unknown state, remove maintenance state * Handle all CouchDB status codes - Set unknown status if we receive an unhandled code * Include status code in error messages * SharedWorker can send unknown status * Add test for unknown status * Gauge fixes for Firefox and units display (#5369) * Closes #5323, #5325. Parent branch is release/2.0.5. - Significant work refactoring SVG markup and CSS for dial gauge; - Fixed missing `v-if` to control display of units for #5325; - Fixed bad `.length` test for limit properties; * Closes #5323, #5325 - Add 'value out of range' indicator * Closes #5323, #5325 - More accurate element naming; - Fix cross-browser problems with current value display in dial gauge; - Refinements to "out of range" indicator approach; - Fixed size of "Amplitude" input in Sine Wave Generator; * Closes #5323, #5325 - Styles and stubbed in code to support needle meter type; * Closes #5323, #5325 - Stubbed in markup and CSS for needle-style meter; * Closes #5323, #5325 - Fixed missing `js-*` classes that were failing npm run test; * Closes #5323, #5325 - Fix to not display meter value bar unless a data value is expected; * Addressing PR comments - Renamed method for clarity; - Added null value check in method `valueExpected`; * [Static Root] Return leafValue if null/undefined/false (#5416) * Return leafValue if null/undefined/false * Added a null to the test json * Show a better default poll question (#5425) * 5361 Tags not persisting when several notebook entries are created at once (#5428) * add end to end test to catch multiple entry errors * click expansion triangle instead * fix race condition between annotation creation and mutation * make sure notebook tags run in e2e * address PR comments * Handle missing objects gracefully (#5399) * Handle missing object errors for display layouts * Handle missing object errors for Overlay Plots * Add check for this.config * Add try/catch statement & check if obj is missing * Changed console.error to console.warn * Lint fix * Fix for this.metadata.value is undefined * Add e2e test * Update comment text * Add reload check and @private, verify console.warn * Redid assignment and metadata check * Fix typo * Changed assignment and metadata check * Redid checks for isMissing(object) * Lint fix * Backmerge e2e code coverage changes and fixes into release/2.0.5 (#5431) * [Telemetry Collections] Respect "Latest" Strategy Option (#5421) * Respect latest strategy in Telemetry Collections to limit potential memory growth. * fix sourcemaps (#5373) Co-authored-by: John Hill <john.c.hill@nasa.gov> * Debounce status summary (#5448) Co-authored-by: John Hill <john.c.hill@nasa.gov> * No gauge (#5451) * Installed gauge plugin by default * Make gauge part of standard install in e2e suite and add restrictednotebook Co-authored-by: Andrew Henry <akhenry@gmail.com> * [CouchDB] Always subscribe to the CouchDB changes feed (#5434) * Add unknown state, remove maintenance state * Handle all CouchDB status codes - Set unknown status if we receive an unhandled code * Include status code in error messages * SharedWorker can send unknown status * Add test for unknown status * Always subscribe to CouchDB changes feed - Always subscribe to the CouchDB changes feed, even if there are no observable objects, since we are also checking the status of CouchDB via this feed. * Update indicator status if not using SharedWorker * Start listening to changes feed on first request * fix test * adjust test to hopefully avoid race condition * lint Co-authored-by: John Hill <john.c.hill@nasa.gov> Co-authored-by: Andrew Henry <akhenry@gmail.com> Co-authored-by: Scott Bell <scott@traclabs.com> * Fix for Fault Management Visual Bugs (#5376) * Closes #5365 * General visual improvements Co-authored-by: Charles Hacskaylo <charlesh88@gmail.com> Co-authored-by: Andrew Henry <akhenry@gmail.com> * fix pathing (#5452) Co-authored-by: Jesse Mazzella <ozyx@users.noreply.github.com> * [Static Root] Static Root Plugin not loading (#5455) * Log if hitting falsy leafValue * Add some logging * Remove logs and specify null/undefined Co-authored-by: Jesse Mazzella <ozyx@users.noreply.github.com> * Allow endpoints with a single enum metadata value in Bar/Line graphs (#5443) * If there is only 1 metadata value, set yKey to none. Also, fix bug for determining the name of a metadata value * Update tests for enum metadata values Co-authored-by: John Hill <john.c.hill@nasa.gov> Co-authored-by: Andrew Henry <akhenry@gmail.com> * [Remote Clock] Wait for first tick and recalculate historical request bounds (#5433) * Updated to ES6 class * added request intercept functionality to telemetry api, added a request interceptor for remote clock * add remoteClock e2e test stub Co-authored-by: Jamie V <jamie.j.vigliotta@nasa.gov> Co-authored-by: Andrew Henry <akhenry@gmail.com> * Fix for missing object for LADTableSet (#5458) * Handle missing object errors for display layouts Co-authored-by: Andrew Henry <akhenry@gmail.com> * removing the call for default import now that TelemetryAPI is an ES6 class (#5461) * [Remote Clock] Fix requestInterceptor typo (#5462) * Fix typo in telemetry request interceptor Co-authored-by: Jamie V <jamie.j.vigliotta@nasa.gov> Co-authored-by: Andrew Henry <akhenry@gmail.com> * Lock model (#5457) * Lock event Model to prevent reactification * de-reactify all the things * Make API properties writable to allow test mocks to override them * Fix merge conflict * Added plot interceptor for missing series config (#5422) Co-authored-by: Andrew Henry <akhenry@gmail.com> Co-authored-by: Shefali Joshi <simplyrender@gmail.com> * Remove performance marks (#5465) * Remove performance marks * Retain performance mark in view large. It doesn't happen very often and it's needed for an automated performance test * Use timeKey for time comparison (#5471) * Fix couchdb no response (#5474) * Update the creation date only when the document is created for the first time * If there is no response from a bulk get, couch db has issues * Check the response - if it's null, don't apply interceptors * Fix shelved alarms (#5479) * Fix the logic around shelved alarms * Remove application router listener * Release 2.0.5 UI and Gauge fixes (#5470) * Various UI fixes - Tweak to Gauge properties form for clarity and usability. - Fix Gauge 'dial' type not obeying "Show units" property setting, closes #5325. - Tweaks to Operator Status UI label and layout for clarity. - Changed name and description of Graph object for clarity and consistency. - Fixed CSS classing that was coloring Export menu items text incorrectly. - Fixed icon-to-text vertical alignment in `.c-object-label`. - Fix for broken layout in imagery local controls (brightness, layers, magnification). Co-authored-by: Andrew Henry <akhenry@gmail.com> * Stacked plot interceptor rename (#5468) * Rename stacked plot interceptor and move to folder Co-authored-by: Andrew Henry <akhenry@gmail.com> * Clear data when time bounds are changed (#5482) * Clear data when time bounds are changed Also react to clear data action Ensure that the yKey is set to 'none' if there is no range with array Values * Refactor trace updates to a method * get rid of root (#5483) * Do not pass onPartialResponse option on to upstream telemetry (#5486) * Fix all of the e2e tests (#5477) * Fix timer test * be explicit about the warnings text * add full suite to CI to enable CircleCI Checks * add back in devtool=false for CI env so firefox tests run * add framework suite * Don't install webpack HMR in CI * Fix playwright version installs * exclude HMR if running tests in any environment - use NODE_ENV=TEST to exclude webpack HMR - deparameterize some of the playwright configs * use lower-case 'test' * timer hover fix * conditionally skip for firefox due to missing console events * increase timeouts to give time for mutation * no need to close save banner * remove devtool setting * revert * update snapshots * disable video to save some resources * use one worker * more timeouts :) * Remove `browser.close()` and `page.close()` as it was breaking other tests * Remove unnecessary awaits and fix func call syntax * Fix image reset test * fix restrictedNotebook tests * revert playwright-ci.config settings * increase timeout for polling imagery test * remove unnecessary waits * disable notebook lock test for chrome-beta as its unreliable - remove some unnecessary 'wait for save banner' logic - remove unused await - mark imagery test as slow in chrome-beta * LINT!! *shakes fist* * don't run full e2e suite per commit * disable video in all configs * add flakey zoom comment * exclude webpack HMR in non-development modes Co-authored-by: Jesse Mazzella <jesse.d.mazzella@nasa.gov> Co-authored-by: Jesse Mazzella <ozyx@users.noreply.github.com> * lint fix Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Joshi <simplyrender@gmail.com> Co-authored-by: Jesse Mazzella <ozyx@users.noreply.github.com> Co-authored-by: Jamie V <jamie.j.vigliotta@nasa.gov> Co-authored-by: Andrew Henry <akhenry@gmail.com> Co-authored-by: Scott Bell <scott@traclabs.com> Co-authored-by: unlikelyzero <jchill2@gmail.com> Co-authored-by: Alize Nguyen <alizenguyen@gmail.com> Co-authored-by: Charles Hacskaylo <charlesh88@gmail.com> Co-authored-by: Khalid Adil <khalidadil29@gmail.com> Co-authored-by: rukmini-bose <48999852+rukmini-bose@users.noreply.github.com> Co-authored-by: Jesse Mazzella <jesse.d.mazzella@nasa.gov>
454 lines
16 KiB
JavaScript
454 lines
16 KiB
JavaScript
/*****************************************************************************
|
|
* Open MCT, Copyright (c) 2014-2022, 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.
|
|
*****************************************************************************/
|
|
import TablePlugin from './plugin.js';
|
|
import Vue from 'vue';
|
|
import {
|
|
createOpenMct,
|
|
createMouseEvent,
|
|
spyOnBuiltins,
|
|
resetApplicationState
|
|
} from 'utils/testing';
|
|
|
|
class MockDataTransfer {
|
|
constructor() {
|
|
this.data = {};
|
|
}
|
|
get types() {
|
|
return Object.keys(this.data);
|
|
}
|
|
setData(format, data) {
|
|
this.data[format] = data;
|
|
}
|
|
getData(format) {
|
|
return this.data[format];
|
|
}
|
|
}
|
|
|
|
describe("the plugin", () => {
|
|
let openmct;
|
|
let tablePlugin;
|
|
let element;
|
|
let child;
|
|
let historicalProvider;
|
|
let originalRouterPath;
|
|
let unlistenConfigMutation;
|
|
|
|
beforeEach((done) => {
|
|
openmct = createOpenMct();
|
|
|
|
// Table Plugin is actually installed by default, but because installing it
|
|
// again is harmless it is left here as an examplar for non-default plugins.
|
|
tablePlugin = new TablePlugin();
|
|
openmct.install(tablePlugin);
|
|
|
|
historicalProvider = {
|
|
request: () => {
|
|
return Promise.resolve([]);
|
|
}
|
|
};
|
|
spyOn(openmct.telemetry, 'findRequestProvider').and.returnValue(historicalProvider);
|
|
|
|
element = document.createElement('div');
|
|
child = document.createElement('div');
|
|
element.appendChild(child);
|
|
|
|
openmct.time.timeSystem('utc', {
|
|
start: 0,
|
|
end: 4
|
|
});
|
|
|
|
openmct.types.addType('test-object', {
|
|
creatable: true
|
|
});
|
|
|
|
spyOnBuiltins(['requestAnimationFrame']);
|
|
window.requestAnimationFrame.and.callFake((callBack) => {
|
|
callBack();
|
|
});
|
|
|
|
originalRouterPath = openmct.router.path;
|
|
|
|
openmct.on('start', done);
|
|
openmct.startHeadless();
|
|
});
|
|
|
|
afterEach(() => {
|
|
openmct.time.timeSystem('utc', {
|
|
start: 0,
|
|
end: 1
|
|
});
|
|
|
|
if (unlistenConfigMutation) {
|
|
unlistenConfigMutation();
|
|
}
|
|
|
|
return resetApplicationState(openmct);
|
|
});
|
|
|
|
describe("defines a table object", function () {
|
|
it("that is creatable", () => {
|
|
let tableType = openmct.types.get('table');
|
|
expect(tableType.definition.creatable).toBe(true);
|
|
});
|
|
});
|
|
|
|
it("provides a table view for objects with telemetry", () => {
|
|
const testTelemetryObject = {
|
|
id: "test-object",
|
|
type: "test-object",
|
|
telemetry: {
|
|
values: [{
|
|
key: "some-key"
|
|
}]
|
|
}
|
|
};
|
|
|
|
const applicableViews = openmct.objectViews.get(testTelemetryObject, []);
|
|
let tableView = applicableViews.find((viewProvider) => viewProvider.key === 'table');
|
|
expect(tableView).toBeDefined();
|
|
});
|
|
|
|
describe("The table view", () => {
|
|
let testTelemetryObject;
|
|
let applicableViews;
|
|
let tableViewProvider;
|
|
let tableView;
|
|
let tableInstance;
|
|
let mockClock;
|
|
|
|
beforeEach(async () => {
|
|
openmct.time.timeSystem('utc', {
|
|
start: 0,
|
|
end: 4
|
|
});
|
|
|
|
mockClock = jasmine.createSpyObj("clock", [
|
|
"on",
|
|
"off",
|
|
"currentValue"
|
|
]);
|
|
mockClock.key = 'mockClock';
|
|
mockClock.currentValue.and.returnValue(1);
|
|
|
|
openmct.time.addClock(mockClock);
|
|
openmct.time.clock('mockClock', {
|
|
start: 0,
|
|
end: 4
|
|
});
|
|
|
|
testTelemetryObject = {
|
|
identifier: {
|
|
namespace: "",
|
|
key: "test-object"
|
|
},
|
|
type: "test-object",
|
|
name: "Test Object",
|
|
telemetry: {
|
|
values: [{
|
|
key: "utc",
|
|
format: "utc",
|
|
name: "Time",
|
|
hints: {
|
|
domain: 1
|
|
}
|
|
}, {
|
|
key: "some-key",
|
|
name: "Some attribute",
|
|
hints: {
|
|
range: 1
|
|
}
|
|
}, {
|
|
key: "some-other-key",
|
|
name: "Another attribute",
|
|
hints: {
|
|
range: 2
|
|
}
|
|
}]
|
|
},
|
|
configuration: {
|
|
hiddenColumns: {
|
|
name: false,
|
|
utc: false,
|
|
'some-key': false,
|
|
'some-other-key': false
|
|
}
|
|
}
|
|
};
|
|
const testTelemetry = [
|
|
{
|
|
'utc': 1,
|
|
'some-key': 'some-value 1',
|
|
'some-other-key': 'some-other-value 1'
|
|
},
|
|
{
|
|
'utc': 2,
|
|
'some-key': 'some-value 2',
|
|
'some-other-key': 'some-other-value 2'
|
|
},
|
|
{
|
|
'utc': 3,
|
|
'some-key': 'some-value 3',
|
|
'some-other-key': 'some-other-value 3'
|
|
}
|
|
];
|
|
|
|
historicalProvider.request = () => Promise.resolve(testTelemetry);
|
|
|
|
openmct.router.path = [testTelemetryObject];
|
|
|
|
applicableViews = openmct.objectViews.get(testTelemetryObject, []);
|
|
tableViewProvider = applicableViews.find((viewProvider) => viewProvider.key === 'table');
|
|
tableView = tableViewProvider.view(testTelemetryObject, [testTelemetryObject]);
|
|
tableView.show(child, true);
|
|
|
|
tableInstance = tableView.getTable();
|
|
|
|
await Vue.nextTick();
|
|
});
|
|
|
|
afterEach(() => {
|
|
openmct.router.path = originalRouterPath;
|
|
});
|
|
|
|
it("Shows no progress bar initially", () => {
|
|
let progressBar = element.querySelector('.c-progress-bar');
|
|
|
|
expect(tableInstance.outstandingRequests).toBe(0);
|
|
expect(progressBar).toBeNull();
|
|
});
|
|
|
|
it("Shows a progress bar while making requests", async () => {
|
|
tableInstance.incrementOutstandingRequests();
|
|
await Vue.nextTick();
|
|
|
|
let progressBar = element.querySelector('.c-progress-bar');
|
|
|
|
expect(tableInstance.outstandingRequests).toBe(1);
|
|
expect(progressBar).not.toBeNull();
|
|
|
|
});
|
|
|
|
it("Renders a row for every telemetry datum returned", async () => {
|
|
let rows = element.querySelectorAll('table.c-telemetry-table__body tr');
|
|
await Vue.nextTick();
|
|
expect(rows.length).toBe(3);
|
|
});
|
|
|
|
it("Renders a column for every item in telemetry metadata", () => {
|
|
let headers = element.querySelectorAll('span.c-telemetry-table__headers__label');
|
|
expect(headers.length).toBe(4);
|
|
expect(headers[0].innerText).toBe('Name');
|
|
expect(headers[1].innerText).toBe('Time');
|
|
expect(headers[2].innerText).toBe('Some attribute');
|
|
expect(headers[3].innerText).toBe('Another attribute');
|
|
});
|
|
|
|
it("Supports column reordering via drag and drop", async () => {
|
|
let columns = element.querySelectorAll('tr.c-telemetry-table__headers__labels th');
|
|
let fromColumn = columns[0];
|
|
let toColumn = columns[1];
|
|
let fromColumnText = fromColumn.querySelector('span.c-telemetry-table__headers__label').innerText;
|
|
let toColumnText = toColumn.querySelector('span.c-telemetry-table__headers__label').innerText;
|
|
|
|
let dragStartEvent = createMouseEvent('dragstart');
|
|
let dragOverEvent = createMouseEvent('dragover');
|
|
let dropEvent = createMouseEvent('drop');
|
|
|
|
dragStartEvent.dataTransfer =
|
|
dragOverEvent.dataTransfer =
|
|
dropEvent.dataTransfer = new MockDataTransfer();
|
|
|
|
fromColumn.dispatchEvent(dragStartEvent);
|
|
toColumn.dispatchEvent(dragOverEvent);
|
|
toColumn.dispatchEvent(dropEvent);
|
|
|
|
await Vue.nextTick();
|
|
columns = element.querySelectorAll('tr.c-telemetry-table__headers__labels th');
|
|
let firstColumn = columns[0];
|
|
let secondColumn = columns[1];
|
|
let firstColumnText = firstColumn.querySelector('span.c-telemetry-table__headers__label').innerText;
|
|
let secondColumnText = secondColumn.querySelector('span.c-telemetry-table__headers__label').innerText;
|
|
expect(fromColumnText).not.toEqual(firstColumnText);
|
|
expect(fromColumnText).toEqual(secondColumnText);
|
|
expect(toColumnText).not.toEqual(secondColumnText);
|
|
expect(toColumnText).toEqual(firstColumnText);
|
|
});
|
|
|
|
it("Supports filtering telemetry by regular text search", async () => {
|
|
tableInstance.tableRows.setColumnFilter("some-key", "1");
|
|
await Vue.nextTick();
|
|
let filteredRowElements = element.querySelectorAll('table.c-telemetry-table__body tr');
|
|
|
|
expect(filteredRowElements.length).toEqual(1);
|
|
tableInstance.tableRows.setColumnFilter("some-key", "");
|
|
await Vue.nextTick();
|
|
|
|
let allRowElements = element.querySelectorAll('table.c-telemetry-table__body tr');
|
|
expect(allRowElements.length).toEqual(3);
|
|
});
|
|
|
|
it("Supports filtering using Regex", async () => {
|
|
tableInstance.tableRows.setColumnRegexFilter("some-key", "^some-value$");
|
|
await Vue.nextTick();
|
|
let filteredRowElements = element.querySelectorAll('table.c-telemetry-table__body tr');
|
|
|
|
expect(filteredRowElements.length).toEqual(0);
|
|
|
|
tableInstance.tableRows.setColumnRegexFilter("some-key", "^some-value");
|
|
await Vue.nextTick();
|
|
let allRowElements = element.querySelectorAll('table.c-telemetry-table__body tr');
|
|
|
|
expect(allRowElements.length).toEqual(3);
|
|
});
|
|
|
|
it("displays the correct number of column headers when the configuration is mutated", async () => {
|
|
const tableInstanceConfiguration = tableInstance.domainObject.configuration;
|
|
tableInstanceConfiguration.hiddenColumns['some-key'] = true;
|
|
unlistenConfigMutation = tableInstance.openmct.objects.mutate(tableInstance.domainObject, 'configuration', tableInstanceConfiguration);
|
|
|
|
await Vue.nextTick();
|
|
let tableHeaderElements = element.querySelectorAll('.c-telemetry-table__headers__label');
|
|
expect(tableHeaderElements.length).toEqual(3);
|
|
|
|
tableInstanceConfiguration.hiddenColumns['some-key'] = false;
|
|
unlistenConfigMutation = tableInstance.openmct.objects.mutate(tableInstance.domainObject, 'configuration', tableInstanceConfiguration);
|
|
|
|
await Vue.nextTick();
|
|
tableHeaderElements = element.querySelectorAll('.c-telemetry-table__headers__label');
|
|
expect(tableHeaderElements.length).toEqual(4);
|
|
});
|
|
|
|
it("displays the correct number of table cells in a row when the configuration is mutated", async () => {
|
|
const tableInstanceConfiguration = tableInstance.domainObject.configuration;
|
|
tableInstanceConfiguration.hiddenColumns['some-key'] = true;
|
|
unlistenConfigMutation = tableInstance.openmct.objects.mutate(tableInstance.domainObject, 'configuration', tableInstanceConfiguration);
|
|
|
|
await Vue.nextTick();
|
|
let tableRowCells = element.querySelectorAll('table.c-telemetry-table__body > tbody > tr:first-child td');
|
|
expect(tableRowCells.length).toEqual(3);
|
|
|
|
tableInstanceConfiguration.hiddenColumns['some-key'] = false;
|
|
unlistenConfigMutation = tableInstance.openmct.objects.mutate(tableInstance.domainObject, 'configuration', tableInstanceConfiguration);
|
|
|
|
await Vue.nextTick();
|
|
tableRowCells = element.querySelectorAll('table.c-telemetry-table__body > tbody > tr:first-child td');
|
|
expect(tableRowCells.length).toEqual(4);
|
|
});
|
|
|
|
it("Pauses the table when a row is marked", async () => {
|
|
let firstRow = element.querySelector('table.c-telemetry-table__body > tbody > tr');
|
|
let clickEvent = createMouseEvent('click');
|
|
|
|
// Mark a row
|
|
firstRow.dispatchEvent(clickEvent);
|
|
|
|
await Vue.nextTick();
|
|
|
|
// Verify table is paused
|
|
expect(element.querySelector('div.c-table.is-paused')).not.toBeNull();
|
|
});
|
|
|
|
it("Unpauses the table on user bounds change", async () => {
|
|
let firstRow = element.querySelector('table.c-telemetry-table__body > tbody > tr');
|
|
let clickEvent = createMouseEvent('click');
|
|
|
|
// Mark a row
|
|
firstRow.dispatchEvent(clickEvent);
|
|
|
|
await Vue.nextTick();
|
|
|
|
// Verify table is paused
|
|
expect(element.querySelector('div.c-table.is-paused')).not.toBeNull();
|
|
|
|
const currentBounds = openmct.time.bounds();
|
|
await Vue.nextTick();
|
|
const newBounds = {
|
|
start: currentBounds.start,
|
|
end: currentBounds.end - 3
|
|
};
|
|
|
|
// Manually change the time bounds
|
|
openmct.time.bounds(newBounds);
|
|
await Vue.nextTick();
|
|
|
|
// Verify table is no longer paused
|
|
expect(element.querySelector('div.c-table.is-paused')).toBeNull();
|
|
});
|
|
|
|
it("Unpauses the table on user bounds change if paused by button", async () => {
|
|
const viewContext = tableView.getViewContext();
|
|
|
|
// Pause by button
|
|
viewContext.togglePauseByButton();
|
|
await Vue.nextTick();
|
|
|
|
// Verify table is paused
|
|
expect(element.querySelector('div.c-table.is-paused')).not.toBeNull();
|
|
|
|
const currentBounds = openmct.time.bounds();
|
|
await Vue.nextTick();
|
|
|
|
const newBounds = {
|
|
start: currentBounds.start,
|
|
end: currentBounds.end - 1
|
|
};
|
|
// Manually change the time bounds
|
|
openmct.time.bounds(newBounds);
|
|
|
|
await Vue.nextTick();
|
|
|
|
// Verify table is no longer paused
|
|
expect(element.querySelector('div.c-table.is-paused')).toBeNull();
|
|
});
|
|
|
|
it("Does not unpause the table on tick", async () => {
|
|
const viewContext = tableView.getViewContext();
|
|
|
|
// Pause by button
|
|
viewContext.togglePauseByButton();
|
|
|
|
await Vue.nextTick();
|
|
|
|
// Verify table displays the correct number of rows
|
|
let tableRows = element.querySelectorAll('table.c-telemetry-table__body > tbody > tr');
|
|
expect(tableRows.length).toEqual(3);
|
|
|
|
// Verify table is paused
|
|
expect(element.querySelector('div.c-table.is-paused')).not.toBeNull();
|
|
|
|
// Tick the clock
|
|
openmct.time.tick(1);
|
|
|
|
await Vue.nextTick();
|
|
|
|
// Verify table is still paused
|
|
expect(element.querySelector('div.c-table.is-paused')).not.toBeNull();
|
|
|
|
await Vue.nextTick();
|
|
|
|
// Verify table displays the correct number of rows
|
|
tableRows = element.querySelectorAll('table.c-telemetry-table__body > tbody > tr');
|
|
expect(tableRows.length).toEqual(3);
|
|
});
|
|
});
|
|
});
|