Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Clear active role if no longer in available roles #7345

Merged
69 changes: 69 additions & 0 deletions e2e/tests/functional/userRoles.e2e.spec.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,69 @@
/*****************************************************************************
* 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.
*****************************************************************************/

import { fileURLToPath } from 'url';

import { expect, test } from '../../pluginFixtures.js';

test.describe('User Roles', () => {
test('Role prompting', async ({ page }) => {
await page.addInitScript({
path: fileURLToPath(new URL('../../helper/addInitExampleUser.js', import.meta.url))
});
await page.goto('./', { waitUntil: 'domcontentloaded' });

// we have multiple available roles, so it should prompt the user
await expect(page.getByText('Select Role')).toBeVisible();
await page.getByRole('combobox').selectOption('driver');
await page.getByRole('button', { name: 'Select' }).click();
await expect(page.getByLabel('User Role')).toContainText('driver');

// attempt changing the role to another valid available role
await page.getByRole('button', { name: 'Change Role' }).click();
await page.getByRole('combobox').selectOption('flight');
await page.getByRole('button', { name: 'Select' }).click();
await expect(page.getByLabel('User Role')).toContainText('flight');

// reload page
await page.reload({ waitUntil: 'domcontentloaded' });
// should still be logged in as flight, and tell the user as much
await expect(page.getByLabel('User Role')).toContainText('flight');
await expect(page.getByText("You're logged in as role flight")).toBeVisible();

// change active role in local storage to "apple_role", a bogus role not in the list of available roles
await page.evaluate(() => {
const openmct = window.openmct;
openmct.user.setActiveRole('apple_role');
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

super cool

});

// reload page
await page.reload({ waitUntil: 'domcontentloaded' });

// verify that role is prompted
await expect(page.getByText('Select Role')).toBeVisible();

// select real role of "driver"
await page.getByRole('combobox').selectOption('driver');
await page.getByRole('button', { name: 'Select' }).click();
await expect(page.getByLabel('User Role')).toContainText('driver');
});
});
22 changes: 16 additions & 6 deletions src/plugins/userIndicator/components/UserIndicator.vue
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@

<template>
<div class="c-indicator icon-person c-indicator--clickable">
<span class="label c-indicator__label">
<span class="label c-indicator__label" aria-label="User Role">
{{ role ? `${userName}: ${role}` : userName }}
<button v-if="availableRoles?.length > 1" @click="promptForRoleSelection">Change Role</button>
</span>
Expand Down Expand Up @@ -65,18 +65,28 @@
const UserAPI = this.openmct.user;
const activeRole = UserAPI.getActiveRole();
this.role = activeRole;
if (!activeRole) {
this.promptForRoleSelection();
this.availableRoles = await this.openmct.user.getPossibleRoles();

Check warning on line 69 in src/plugins/userIndicator/components/UserIndicator.vue

View check run for this annotation

Codecov / codecov/patch

src/plugins/userIndicator/components/UserIndicator.vue#L68-L69

Added lines #L68 - L69 were not covered by tests
// clear role if it's not in list of available roles, e.g., removed by admin
if (!this.availableRoles?.includes(this.role)) {
this.role = null;

Check warning on line 72 in src/plugins/userIndicator/components/UserIndicator.vue

View check run for this annotation

Codecov / codecov/patch

src/plugins/userIndicator/components/UserIndicator.vue#L72

Added line #L72 was not covered by tests
UserAPI.setActiveRole(null);
scottbell marked this conversation as resolved.
Show resolved Hide resolved
}

// see if we need to prompt for role selection
if (!this.role) {
this.promptForRoleSelection(this.availableRoles);
} else {
// only notify the user if they have more than one role available
this.availableRoles = await this.openmct.user.getPossibleRoles();
if (this.availableRoles.length > 1) {
this.openmct.notifications.info(`You're logged in as role ${activeRole}`);
}
}
},
async promptForRoleSelection() {
this.availableRoles = await this.openmct.user.getPossibleRoles();
async promptForRoleSelection(passedAvailableRoles) {
scottbell marked this conversation as resolved.
Show resolved Hide resolved
if (!passedAvailableRoles) {

Check warning on line 87 in src/plugins/userIndicator/components/UserIndicator.vue

View check run for this annotation

Codecov / codecov/patch

src/plugins/userIndicator/components/UserIndicator.vue#L86-L87

Added lines #L86 - L87 were not covered by tests
this.availableRoles = await this.openmct.user.getPossibleRoles();
}

Check warning on line 89 in src/plugins/userIndicator/components/UserIndicator.vue

View check run for this annotation

Codecov / codecov/patch

src/plugins/userIndicator/components/UserIndicator.vue#L89

Added line #L89 was not covered by tests
const selectionOptions = this.availableRoles.map((role) => ({
key: role,
name: role
Expand Down
Loading