mirror of
https://github.com/nasa/openmct.git
synced 2025-01-01 10:56:41 +00:00
172e0b23fd
* fix: remove redundant eslint rules * chore: bump `prettier` to v2.8.7 * docs: vue files to use html comments for licenses - Prettier's Vue parser freaks out if it sees a *.js style comment in a *.vue file. * docs: more licenses for vue files * fix: don't ignore *.vue files * fix: use defaults for tabWidth and printWidth * simplify .prettierignore * enforce a printWidth of 100 * fix: use `eslint-plugin-prettier`, remove conflicting rules * test: fix gauge tests (for real) * test: fix notebook test selectors * test: fix restrictedNotebook test selectors * test: remove useless assignment * lint: __dirname as global * lint: revert eslint config + whitespace changes, commit new config * style: remove unnecessary string concat of literals * test: fix missed gauge test * fix: use new eslint rules * feat: add blank `.git-blame-ignore-revs` file * docs: update to mention Prettier and format. * Revert "test: fix gauge tests (for real)" This reverts commit 6afad450389edc2f16ff0d00c9524621a7ba53bc. * Revert "test: fix notebook test selectors" This reverts commit 17fe1cbbff02e9298f041b5ea0fea5494fe54d94. * Revert "test: fix restrictedNotebook test selectors" This reverts commit 97e0ede826b7dd61c5443845443d806a56f3f305. * Revert "test: fix missed gauge test" This reverts commit e2398fc38ca94beff2066cc253173412ad47f8b9. * test: fix gauge tests (no formatting) * test: update notebook e2e selectors (no formatting) * test: update restrictedNotebook e2e selectors (no formatting) * fix: temporarily disable lint check
155 lines
6.9 KiB
JavaScript
155 lines
6.9 KiB
JavaScript
/*****************************************************************************
|
|
* Open MCT, Copyright (c) 2014-2023, 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.
|
|
*****************************************************************************/
|
|
/* global __dirname */
|
|
/*
|
|
* This test suite is dedicated to testing the operator status plugin.
|
|
*/
|
|
|
|
const path = require('path');
|
|
const { test, expect } = require('../../../../pluginFixtures');
|
|
|
|
/*
|
|
|
|
Precondition: Inject Example User, Operator Status Plugins
|
|
Verify that user 1 sees updates from user/role 2 (Not possible without openmct-yamcs implementation)
|
|
|
|
Clear Role Status of single user test
|
|
STUB (test.fixme) Rolling through each
|
|
|
|
*/
|
|
|
|
test.describe('Operator Status', () => {
|
|
test.beforeEach(async ({ page }) => {
|
|
// FIXME: determine if plugins will be added to index.html or need to be injected
|
|
await page.addInitScript({ path: path.join(__dirname, '../../../../helper/', 'addInitExampleUser.js')});
|
|
await page.addInitScript({ path: path.join(__dirname, '../../../../helper/', 'addInitOperatorStatus.js')});
|
|
await page.goto('./', { waitUntil: 'domcontentloaded' });
|
|
});
|
|
|
|
// verify that operator status is visible
|
|
test('operator status is visible and expands when clicked', async ({ page }) => {
|
|
await expect(page.locator('div[title="Set my operator status"]')).toBeVisible();
|
|
await page.locator('div[title="Set my operator status"]').click();
|
|
|
|
// expect default status to be 'GO'
|
|
await expect(page.locator('.c-status-poll-panel')).toBeVisible();
|
|
});
|
|
|
|
test('poll question indicator remains when blank poll set', async ({ page }) => {
|
|
await expect(page.locator('div[title="Set the current poll question"]')).toBeVisible();
|
|
await page.locator('div[title="Set the current poll question"]').click();
|
|
// set to blank
|
|
await page.getByRole('button', { name: 'Update' }).click();
|
|
|
|
// should still be visible
|
|
await expect(page.locator('div[title="Set the current poll question"]')).toBeVisible();
|
|
});
|
|
|
|
// Verify that user 1 sees updates from user/role 2 (Not possible without openmct-yamcs implementation)
|
|
test('operator status table reflects answered values', async ({ page }) => {
|
|
// user navigates to operator status poll
|
|
const statusPollIndicator = page.locator('div[title="Set my operator status"]');
|
|
await statusPollIndicator.click();
|
|
|
|
// get user role value
|
|
const userRole = page.locator('.c-status-poll-panel__user-role');
|
|
const userRoleText = await userRole.innerText();
|
|
|
|
// get selected status value
|
|
const selectStatus = page.locator('select[name="setStatus"]');
|
|
await selectStatus.selectOption({ index: 1});
|
|
const initialStatusValue = await selectStatus.inputValue();
|
|
|
|
// open manage status poll
|
|
const manageStatusPollIndicator = page.locator('div[title="Set the current poll question"]');
|
|
await manageStatusPollIndicator.click();
|
|
// parse the table row values
|
|
const row = page.locator(`tr:has-text("${userRoleText}")`);
|
|
const rowValues = await row.innerText();
|
|
const rowValuesArr = rowValues.split('\t');
|
|
const COLUMN_STATUS_INDEX = 1;
|
|
// check initial set value matches status table
|
|
expect(rowValuesArr[COLUMN_STATUS_INDEX].toLowerCase())
|
|
.toEqual(initialStatusValue.toLowerCase());
|
|
|
|
// change user status
|
|
await statusPollIndicator.click();
|
|
// FIXME: might want to grab a dynamic option instead of arbitrary
|
|
await page.locator('select[name="setStatus"]').selectOption({ index: 2});
|
|
const updatedStatusValue = await selectStatus.inputValue();
|
|
// verify user status is reflected in table
|
|
await manageStatusPollIndicator.click();
|
|
|
|
const updatedRow = page.locator(`tr:has-text("${userRoleText}")`);
|
|
const updatedRowValues = await updatedRow.innerText();
|
|
const updatedRowValuesArr = updatedRowValues.split('\t');
|
|
|
|
expect(updatedRowValuesArr[COLUMN_STATUS_INDEX].toLowerCase())
|
|
.toEqual(updatedStatusValue.toLowerCase());
|
|
|
|
});
|
|
|
|
test('clear poll button removes poll responses', async ({ page }) => {
|
|
// user navigates to operator status poll
|
|
const statusPollIndicator = page.locator('div[title="Set my operator status"]');
|
|
await statusPollIndicator.click();
|
|
|
|
// get user role value
|
|
const userRole = page.locator('.c-status-poll-panel__user-role');
|
|
const userRoleText = await userRole.innerText();
|
|
|
|
// get selected status value
|
|
const selectStatus = page.locator('select[name="setStatus"]');
|
|
// FIXME: might want to grab a dynamic option instead of arbitrary
|
|
await selectStatus.selectOption({ index: 1});
|
|
const initialStatusValue = await selectStatus.inputValue();
|
|
|
|
// open manage status poll
|
|
const manageStatusPollIndicator = page.locator('div[title="Set the current poll question"]');
|
|
await manageStatusPollIndicator.click();
|
|
// parse the table row values
|
|
const row = page.locator(`tr:has-text("${userRoleText}")`);
|
|
const rowValues = await row.innerText();
|
|
const rowValuesArr = rowValues.split('\t');
|
|
const COLUMN_STATUS_INDEX = 1;
|
|
// check initial set value matches status table
|
|
expect(rowValuesArr[COLUMN_STATUS_INDEX].toLowerCase())
|
|
.toEqual(initialStatusValue.toLowerCase());
|
|
|
|
// clear the poll
|
|
await page.locator('button[title="Clear the previous poll question"]').click();
|
|
|
|
const updatedRow = page.locator(`tr:has-text("${userRoleText}")`);
|
|
const updatedRowValues = await updatedRow.innerText();
|
|
const updatedRowValuesArr = updatedRowValues.split('\t');
|
|
const UNSET_VALUE_LABEL = 'Not set';
|
|
expect(updatedRowValuesArr[COLUMN_STATUS_INDEX])
|
|
.toEqual(UNSET_VALUE_LABEL);
|
|
|
|
});
|
|
|
|
test.fixme('iterate through all possible response values', async ({ page }) => {
|
|
// test all possible respone values for the poll
|
|
});
|
|
|
|
});
|