mirror of
https://github.com/nasa/openmct.git
synced 2024-12-24 07:16:39 +00:00
0413e77d8a
* fix: update broken locator * update eslint package * first pass of lint fixes * update package * change ruleset * update component tests to match linting rules * driveby * start to factor out bad locators * update gauge component * update notebook snapshot drop area * Update plot aria * add draggable true to tree items * update package * driveby to remove dead code * unneeded * unneeded * tells a screenreader that this is a row and a cell * adds an id for dragondrops * this should be a button * first pass at fixing tooltip selectors * review comments * Updating more tests * update to remove expect expect given our use of check functions * add expand component * move role around * update more locators * force * new local storage * remove choochoo steps * test: do `lint:fix` and also add back accidentally removed code * test: add back more removed code * test: remove `unstable` annotation from tests which are not unstable * test: remove invalid test-- the "new" time conductor doesn't allow for millisecond changes in fixed time * test: fix unstable gauge test * test: remove useless asserts-- this was secretly non-functional. now that we've fixed it, it makes no sense and just fails * test: add back accidentally removed changes * test: revert changes that break test * test: more fixes * Remove all notion of the unstable/stable e2e tests * test: eviscerate the flake with FACTS and LOGIC * test: fix anotha one * lint fixes * test: no need to wait for save dialog * test: fix more tests * lint: fix more warnings * test: fix anotha one * test: use `toHaveLength` instead of `.length).toBe()` * test: stabilize tabs view example imagery test * fix: more tests be fixed * test: more `toHaveCount()`s please * test: revert more accidentally removed fixes * test: fix selector * test: fix anotha one * update lint rules to clean up bad locators in shared fixtures * update and remove bad appActions * test: fix some restricted notebook tests * test: mass find/replace to enforce `toHaveCount()` instead of `.count()).toBe()` * Remove some bad appActions and update text * test: fix da tree tests * test: await not await await * test: fix upload plan appAction and add a11y * Updating externalFixtures with best practice locators and add missing appAction framework tests * test: fix test * test: fix appAction test for plans * test: yum yum fix'em up and get rid of some dragon drops * fix: alas, a `.only()` got my hopes up that i was done fixing tests * test: add `setTimeConductorMode` test "suite" which covers most TC related appActions * test: fix arg * test(couchdb): fix some network tests via expect polling * Stabalize visual test * getCanasPixels * test: stabilize tooltip telemetry table test, better a11y for tooltips * chore: update to use `docker compose` instead of `docker-compose` * New rules, new tests, new me * fix sort order * test: add `waitForPlotsToRender` framework test, passthru timeout override * test: remove `clockOptions` test as we have `page.clock` now * test: refactor out `overrideClock` * test: use `clock.install` instead * test: use `clock.install` instead * time clock fix * test: fix timer tests * remove ever reference to old base fixture * test: stabilize restricted notebook test * lint fixes * test: use clock.install * update timelist * test: update visual tests to use `page.clock()`, update snapshots * test: stabilize tree renaming/reordering test * a11y: add aria-label and role=region to object view * refactor: use `dragTo` * refactor: use `dragTo`, other small fixes * test: use `page.clock()` to stabilize tooltip telemetry table test * test: use web-first assertion to stabilize staleness test * test: knock out a few more `page.click`s * test: destroy all `page.click()`s * refactor: consistently use `'Ok'` instead of `'OK'` and `'Ok'` mixed * test: remove gauge aria label * test: more test fixes * test: more fixes and refactors * docs: add comment * test: refactor all instances of `dragAndDrop` * test: remove redundant test (covered in previous test steps) * test: stabilize imagery operations tests for display layout * chore: remove bad unicorn rule * chore(lint): remove unused disable directives --------- Co-authored-by: Jesse Mazzella <jesse.d.mazzella@nasa.gov>
130 lines
5.0 KiB
JavaScript
130 lines
5.0 KiB
JavaScript
/*****************************************************************************
|
|
* Open MCT, Copyright (c) 2014-2024, 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.
|
|
*****************************************************************************/
|
|
|
|
/**
|
|
* This file is dedicated to extending the base functionality of the `@playwright/test` framework.
|
|
* The functions in this file should be viewed as temporary or a shim to be removed as the RFEs in
|
|
* the Playwright GitHub repo are implemented. Functions which serve those RFEs are marked with corresponding
|
|
* GitHub issues.
|
|
*/
|
|
|
|
import { expect, request, test } from '@playwright/test';
|
|
import fs from 'fs';
|
|
import path from 'path';
|
|
import { fileURLToPath } from 'url';
|
|
import { v4 as uuid } from 'uuid';
|
|
|
|
/**
|
|
* Takes a `ConsoleMessage` and returns a formatted string. Used to enable console log error detection.
|
|
* @see {@link https://github.com/microsoft/playwright/discussions/11690 Github Discussion}
|
|
* @private
|
|
* @param {import('@playwright/test').ConsoleMessage} msg
|
|
* @returns {string} formatted string with message type, text, url, and line and column numbers
|
|
*/
|
|
function _consoleMessageToString(msg) {
|
|
const { url, lineNumber, columnNumber } = msg.location();
|
|
|
|
return `[${msg.type()}] ${msg.text()} at (${url} ${lineNumber}:${columnNumber})`;
|
|
}
|
|
|
|
/**
|
|
* Wait for all animations within the given element and subtrees to finish. Useful when
|
|
* verifying that css transitions have completed.
|
|
* @see {@link https://github.com/microsoft/playwright/issues/15660 Github RFE}
|
|
* @param {import('@playwright/test').Locator} locator
|
|
* @return {Promise<Animation[]>}
|
|
*/
|
|
function waitForAnimations(locator) {
|
|
return locator.evaluate((element) =>
|
|
Promise.all(element.getAnimations({ subtree: true }).map((animation) => animation.finished))
|
|
);
|
|
}
|
|
|
|
const istanbulCLIOutput = fileURLToPath(new URL('.nyc_output', import.meta.url));
|
|
|
|
const extendedTest = test.extend({
|
|
/**
|
|
* Path to output raw coverage files. Can be overridden in Playwright config file.
|
|
* @see {@link https://github.com/mxschmitt/playwright-test-coverage Github Example Project}
|
|
* @constant {string}
|
|
*/
|
|
|
|
coveragePath: [istanbulCLIOutput, { option: true }],
|
|
/**
|
|
* Extends the base context class to add codecoverage shim.
|
|
* @see {@link https://github.com/mxschmitt/playwright-test-coverage Github Project}
|
|
*/
|
|
context: async ({ context, coveragePath }, use) => {
|
|
await context.addInitScript(() =>
|
|
window.addEventListener('beforeunload', () =>
|
|
window.collectIstanbulCoverage(JSON.stringify(window.__coverage__))
|
|
)
|
|
);
|
|
await fs.promises.mkdir(coveragePath, { recursive: true });
|
|
await context.exposeFunction('collectIstanbulCoverage', (coverageJSON) => {
|
|
if (coverageJSON) {
|
|
fs.writeFileSync(
|
|
path.join(coveragePath, `playwright_coverage_${uuid()}.json`),
|
|
coverageJSON
|
|
);
|
|
}
|
|
});
|
|
|
|
await use(context);
|
|
for (const page of context.pages()) {
|
|
await page.evaluate(() => {
|
|
window.collectIstanbulCoverage(JSON.stringify(window.__coverage__));
|
|
});
|
|
}
|
|
},
|
|
/**
|
|
* If true, will assert against any console.error calls that occur during the test. Assertions occur
|
|
* during test teardown (after the test has completed).
|
|
*
|
|
* Default: `true`
|
|
*/
|
|
failOnConsoleError: [true, { option: true }],
|
|
/**
|
|
* Extends the base page class to enable console log error detection.
|
|
* @see {@link https://github.com/microsoft/playwright/discussions/11690 Github Discussion}
|
|
*/
|
|
page: async ({ page, failOnConsoleError }, use) => {
|
|
// Capture any console errors during test execution
|
|
const messages = [];
|
|
page.on('console', (msg) => messages.push(msg));
|
|
|
|
await use(page);
|
|
|
|
// Assert against console errors during teardown
|
|
if (failOnConsoleError) {
|
|
messages.forEach((msg) =>
|
|
// eslint-disable-next-line playwright/no-standalone-expect
|
|
expect
|
|
.soft(msg.type(), `Console error detected: ${_consoleMessageToString(msg)}`)
|
|
.not.toEqual('error')
|
|
);
|
|
}
|
|
}
|
|
});
|
|
|
|
export { expect, request, extendedTest as test, waitForAnimations };
|