/***************************************************************************** * 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 test suite is dedicated to tests which verify Open MCT's Notification functionality */ import { createDomainObjectWithDefaults, createNotification } from '../../appActions.js'; import { expect, test } from '../../pluginFixtures.js'; test.describe('Notifications List', () => { test.fixme('Notifications can be dismissed individually', async ({ page }) => { test.info().annotations.push({ type: 'issue', description: 'https://github.com/nasa/openmct/issues/6820' }); // Go to baseURL await page.goto('./', { waitUntil: 'domcontentloaded' }); // Create an error notification with the message "Error message" await createNotification(page, { severity: 'error', message: 'Error message' }); // Create an alert notification with the message "Alert message" await createNotification(page, { severity: 'alert', message: 'Alert message' }); // Verify that there is a button with aria-label "Review 2 Notifications" await expect(page.locator('button[aria-label="Review 2 Notifications"]')).toHaveCount(1); // Click on button with aria-label "Review 2 Notifications" await page.getByLabel('Review 2 Notifications').click(); // Click on button with aria-label="Dismiss notification of Error message" await page.getByLabel('Dismiss notification of Error message').click(); // Verify there is no a notification (listitem) with the text "Error message" since it was dismissed expect(await page.locator('div[role="dialog"] div[role="listitem"]').innerText()).not.toContain( 'Error message' ); // Verify there is still a notification (listitem) with the text "Alert message" expect(await page.locator('div[role="dialog"] div[role="listitem"]').innerText()).toContain( 'Alert message' ); // Click on button with aria-label="Dismiss notification of Alert message" await page.getByLabel('Dismiss notification of Alert message').click(); // Verify that there is no dialog since the notification overlay was closed automatically after all notifications were dismissed await expect(page.locator('div[role="dialog"]')).toHaveCount(0); }); }); test.describe('Notification Overlay', () => { test('Closing notification list after notification banner disappeared does not cause it to open automatically', async ({ page }) => { test.info().annotations.push({ type: 'issue', description: 'https://github.com/nasa/openmct/issues/6130' }); // Go to baseURL await page.goto('./', { waitUntil: 'domcontentloaded' }); // Create a new Display Layout object await createDomainObjectWithDefaults(page, { type: 'Display Layout' }); // Dismiss notification banner await page.getByRole('button', { name: 'Dismiss' }).click(); // Click on the button "Review 1 Notification" await page.getByRole('button', { name: 'Review 1 Notification' }).click(); // Verify that Notification List is open await expect(page.getByRole('dialog', { name: 'Overlay' })).toBeVisible(); // Wait until there is no Notification Banner await expect(page.getByRole('alert')).not.toBeAttached(); // Click on the "Close" button of the Notification List await page.getByRole('button', { name: 'Close' }).click(); // On the Display Layout object, click on the "Edit" button await page.getByRole('button', { name: 'Edit Object' }).click(); // Click on the "Save" button await page.getByRole('button', { name: 'Save' }).click(); await page.getByRole('listitem', { name: 'Save and Finish Editing' }).click(); // Verify that Notification List is NOT open await expect(page.getByRole('dialog', { name: 'Overlay' })).toBeHidden(); }); });