mirror of
https://github.com/nasa/openmct.git
synced 2025-01-03 03:46:42 +00:00
db97acb61e
* 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>
257 lines
9.7 KiB
JavaScript
257 lines
9.7 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.
|
|
*****************************************************************************/
|
|
|
|
const { test } = require('../../../fixtures');
|
|
const { expect } = require('@playwright/test');
|
|
const path = require('path');
|
|
|
|
const TEST_TEXT = 'Testing text for entries.';
|
|
const TEST_TEXT_NAME = 'Test Page';
|
|
const CUSTOM_NAME = 'CUSTOM_NAME';
|
|
const NOTEBOOK_DROP_AREA = '.c-notebook__drag-area';
|
|
|
|
test.describe('Restricted Notebook', () => {
|
|
test.beforeEach(async ({ page }) => {
|
|
await startAndAddRestrictedNotebookObject(page);
|
|
});
|
|
|
|
test('Can be renamed @addInit', async ({ page }) => {
|
|
await expect(page.locator('.l-browse-bar__object-name')).toContainText(`Unnamed ${CUSTOM_NAME}`);
|
|
});
|
|
|
|
test('Can be deleted if there are no locked pages @addInit', async ({ page }) => {
|
|
await openContextMenuRestrictedNotebook(page);
|
|
|
|
const menuOptions = page.locator('.c-menu ul');
|
|
await expect.soft(menuOptions).toContainText('Remove');
|
|
|
|
const restrictedNotebookTreeObject = page.locator(`a:has-text("Unnamed ${CUSTOM_NAME}")`);
|
|
|
|
// notbook tree object exists
|
|
expect.soft(await restrictedNotebookTreeObject.count()).toEqual(1);
|
|
|
|
// Click Remove Text
|
|
await page.locator('text=Remove').click();
|
|
|
|
// Click 'OK' on confirmation window and wait for save banner to appear
|
|
await Promise.all([
|
|
page.waitForNavigation(),
|
|
page.locator('text=OK').click(),
|
|
page.waitForSelector('.c-message-banner__message')
|
|
]);
|
|
await page.locator('.c-message-banner__close-button').click();
|
|
|
|
// has been deleted
|
|
expect(await restrictedNotebookTreeObject.count()).toEqual(0);
|
|
});
|
|
|
|
test('Can be locked if at least one page has one entry @addInit', async ({ page }) => {
|
|
|
|
await enterTextEntry(page);
|
|
|
|
const commitButton = page.locator('button:has-text("Commit Entries")');
|
|
expect(await commitButton.count()).toEqual(1);
|
|
});
|
|
|
|
});
|
|
|
|
test.describe('Restricted Notebook with at least one entry and with the page locked @addInit', () => {
|
|
|
|
test.beforeEach(async ({ page }) => {
|
|
await startAndAddRestrictedNotebookObject(page);
|
|
await enterTextEntry(page);
|
|
await lockPage(page);
|
|
|
|
// FIXME: Give ample time for the mutation to happen
|
|
// https://github.com/nasa/openmct/issues/5409
|
|
// eslint-disable-next-line playwright/no-wait-for-timeout
|
|
await page.waitForTimeout(1 * 1000);
|
|
|
|
// open sidebar
|
|
await page.locator('button.c-notebook__toggle-nav-button').click();
|
|
});
|
|
|
|
test('Locked page should now be in a locked state @addInit', async ({ page }, testInfo) => {
|
|
test.fixme(testInfo.project === 'chrome-beta', "Test is unreliable on chrome-beta");
|
|
// main lock message on page
|
|
const lockMessage = page.locator('text=This page has been committed and cannot be modified or removed');
|
|
expect.soft(await lockMessage.count()).toEqual(1);
|
|
|
|
// lock icon on page in sidebar
|
|
const pageLockIcon = page.locator('ul.c-notebook__pages li div.icon-lock');
|
|
expect.soft(await pageLockIcon.count()).toEqual(1);
|
|
|
|
// no way to remove a restricted notebook with a locked page
|
|
await openContextMenuRestrictedNotebook(page);
|
|
const menuOptions = page.locator('.c-menu ul');
|
|
|
|
await expect(menuOptions).not.toContainText('Remove');
|
|
});
|
|
|
|
test('Can still: add page, rename, add entry, delete unlocked pages @addInit', async ({ page }) => {
|
|
// Click text=Page Add >> button
|
|
await Promise.all([
|
|
page.waitForNavigation(),
|
|
page.locator('text=Page Add >> button').click()
|
|
]);
|
|
// Click text=Unnamed Page >> nth=1
|
|
await page.locator('text=Unnamed Page').nth(1).click();
|
|
// Press a with modifiers
|
|
await page.locator('text=Unnamed Page').nth(1).fill(TEST_TEXT_NAME);
|
|
|
|
// expect to be able to rename unlocked pages
|
|
const newPageElement = page.locator(`text=${TEST_TEXT_NAME}`);
|
|
const newPageCount = await newPageElement.count();
|
|
await newPageElement.press('Enter'); // exit contenteditable state
|
|
expect.soft(newPageCount).toEqual(1);
|
|
|
|
// enter test text
|
|
await enterTextEntry(page);
|
|
|
|
// expect new page to be lockable
|
|
const commitButton = page.locator('BUTTON:HAS-TEXT("COMMIT ENTRIES")');
|
|
expect.soft(await commitButton.count()).toEqual(1);
|
|
|
|
// Click text=Unnamed PageTest Page >> button
|
|
await page.locator('text=Unnamed PageTest Page >> button').click();
|
|
// Click text=Delete Page
|
|
await page.locator('text=Delete Page').click();
|
|
// Click text=Ok
|
|
await Promise.all([
|
|
page.waitForNavigation(),
|
|
page.locator('text=Ok').click()
|
|
]);
|
|
|
|
// deleted page, should no longer exist
|
|
const deletedPageElement = page.locator(`text=${TEST_TEXT_NAME}`);
|
|
expect(await deletedPageElement.count()).toEqual(0);
|
|
});
|
|
});
|
|
|
|
test.describe('Restricted Notebook with a page locked and with an embed @addInit', () => {
|
|
|
|
test.beforeEach(async ({ page }) => {
|
|
await startAndAddRestrictedNotebookObject(page);
|
|
await dragAndDropEmbed(page);
|
|
});
|
|
|
|
test('Allows embeds to be deleted if page unlocked @addInit', async ({ page }) => {
|
|
// Click .c-ne__embed__name .c-popup-menu-button
|
|
await page.locator('.c-ne__embed__name .c-popup-menu-button').click(); // embed popup menu
|
|
|
|
const embedMenu = page.locator('body >> .c-menu');
|
|
await expect(embedMenu).toContainText('Remove This Embed');
|
|
});
|
|
|
|
test('Disallows embeds to be deleted if page locked @addInit', async ({ page }) => {
|
|
await lockPage(page);
|
|
// Click .c-ne__embed__name .c-popup-menu-button
|
|
await page.locator('.c-ne__embed__name .c-popup-menu-button').click(); // embed popup menu
|
|
|
|
const embedMenu = page.locator('body >> .c-menu');
|
|
await expect(embedMenu).not.toContainText('Remove This Embed');
|
|
});
|
|
|
|
});
|
|
|
|
/**
|
|
* @param {import('@playwright/test').Page} page
|
|
*/
|
|
async function startAndAddRestrictedNotebookObject(page) {
|
|
// eslint-disable-next-line no-undef
|
|
await page.addInitScript({ path: path.join(__dirname, 'addInitRestrictedNotebook.js') });
|
|
//Go to baseURL
|
|
await page.goto('/', { waitUntil: 'networkidle' });
|
|
//Click the Create button
|
|
await page.click('button:has-text("Create")');
|
|
// Click text=CUSTOME_NAME
|
|
await page.click(`text=${CUSTOM_NAME}`); // secondarily tests renamability also
|
|
// Click text=OK
|
|
await Promise.all([
|
|
page.waitForNavigation({waitUntil: 'networkidle'}),
|
|
page.click('text=OK')
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* @param {import('@playwright/test').Page} page
|
|
*/
|
|
async function enterTextEntry(page) {
|
|
// Click .c-notebook__drag-area
|
|
await page.locator(NOTEBOOK_DROP_AREA).click();
|
|
|
|
// enter text
|
|
await page.locator('div.c-ne__text').click();
|
|
await page.locator('div.c-ne__text').fill(TEST_TEXT);
|
|
await page.locator('div.c-ne__text').press('Enter');
|
|
}
|
|
|
|
/**
|
|
* @param {import('@playwright/test').Page} page
|
|
*/
|
|
async function dragAndDropEmbed(page) {
|
|
// Click button:has-text("Create")
|
|
await page.locator('button:has-text("Create")').click();
|
|
// Click li:has-text("Sine Wave Generator")
|
|
await page.locator('li:has-text("Sine Wave Generator")').click();
|
|
// Click form[name="mctForm"] >> text=My Items
|
|
await page.locator('form[name="mctForm"] >> text=My Items').click();
|
|
// Click text=OK
|
|
await page.locator('text=OK').click();
|
|
// Click text=Open MCT My Items >> span >> nth=3
|
|
await page.locator('text=Open MCT My Items >> span').nth(3).click();
|
|
// Click text=Unnamed CUSTOM_NAME
|
|
await Promise.all([
|
|
page.waitForNavigation(),
|
|
page.locator('text=Unnamed CUSTOM_NAME').click()
|
|
]);
|
|
|
|
await page.dragAndDrop('text=UNNAMED SINE WAVE GENERATOR', NOTEBOOK_DROP_AREA);
|
|
}
|
|
|
|
/**
|
|
* @param {import('@playwright/test').Page} page
|
|
*/
|
|
async function lockPage(page) {
|
|
const commitButton = page.locator('button:has-text("Commit Entries")');
|
|
await commitButton.click();
|
|
|
|
//Wait until Lock Banner is visible
|
|
await page.locator('text=Lock Page').click();
|
|
}
|
|
|
|
/**
|
|
* @param {import('@playwright/test').Page} page
|
|
*/
|
|
async function openContextMenuRestrictedNotebook(page) {
|
|
const myItemsFolder = page.locator('text=Open MCT My Items >> span').nth(3);
|
|
const className = await myItemsFolder.getAttribute('class');
|
|
if (!className.includes('c-disclosure-triangle--expanded')) {
|
|
await myItemsFolder.click();
|
|
}
|
|
|
|
// Click a:has-text("Unnamed CUSTOM_NAME")
|
|
await page.locator(`a:has-text("Unnamed ${CUSTOM_NAME}")`).click({
|
|
button: 'right'
|
|
});
|
|
}
|