open-nomad/ui/tests/acceptance/global-header-test.js
Phil Renaud ffd16dfec6
[ui, epic] SSO and Auth improvements (#15110)
* Top nav auth dropdown (#15055)

* Basic dropdown styles

* Some cleanup

* delog

* Default nomad hover state styles

* Component separation-of-concerns and acceptance tests for auth dropdown

* lintfix

* [ui, sso] Handle token expiry 500s (#15073)

* Handle error states generally

* Dont direct, just redirect

* no longer need explicit error on controller

* Redirect on token-doesnt-exist

* Forgot to import our time lib

* Linting on _blank

* Redirect tests

* changelog

* [ui, sso] warn user about pending token expiry (#15091)

* Handle error states generally

* Dont direct, just redirect

* no longer need explicit error on controller

* Linting on _blank

* Custom notification actions and shift the template to within an else block

* Lintfix

* Make the closeAction optional

* changelog

* Add a mirage token that will always expire in 11 minutes

* Test for token expiry with ember concurrency waiters

* concurrency handling for earlier test, and button redirect test

* [ui] if ACLs are disabled, remove the Sign In link from the top of the UI (#15114)

* Remove top nav link if ACLs disabled

* Change to an enabled-by-default model since you get no agent config when ACLs are disabled but you lack a token

* PR feedback addressed; down with double negative conditionals

* lintfix

* ember getter instead of ?.prop

* [SSO] Auth Methods and Mock OIDC Flow (#15155)

* Big ol first pass at a redirect sign in flow

* dont recursively add queryparams on redirect

* Passing state and code qps

* In which I go off the deep end and embed a faux provider page in the nomad ui

* Buggy but self-contained flow

* Flow auto-delay added and a little more polish to resetting token

* secret passing turned to accessor passing

* Handle SSO Failure

* General cleanup and test fix

* Lintfix

* SSO flow acceptance tests

* Percy snapshots added

* Explicitly note the OIDC test route is mirage only

* Handling failure case for complete-auth

* Leentfeex

* Tokens page styles (#15273)

* styling and moving columns around

* autofocus and enter press handling

* Styles refined

* Split up manager and regular tests

* Standardizing to a binary status state

* Serialize auth-methods response to use "name" as primary key (#15380)

* Serializer for unique-by-name

* Use @classic because of class extension
2022-11-28 10:44:52 -05:00

85 lines
2.7 KiB
JavaScript

/* eslint-disable ember-a11y-testing/a11y-audit-called */
import { module, test } from 'qunit';
import { click, visit, currentURL } from '@ember/test-helpers';
import { setupApplicationTest } from 'ember-qunit';
import { setupMirage } from 'ember-cli-mirage/test-support';
import Layout from 'nomad-ui/tests/pages/layout';
let managementToken;
module('Acceptance | global header', function (hooks) {
setupApplicationTest(hooks);
setupMirage(hooks);
test('it diplays no links', async function (assert) {
server.create('agent');
await visit('/');
assert.false(Layout.navbar.end.vaultLink.isVisible);
assert.false(Layout.navbar.end.vaultLink.isVisible);
});
test('it diplays both links', async function (assert) {
server.create('agent', 'withConsulLink', 'withVaultLink');
await visit('/');
assert.true(Layout.navbar.end.vaultLink.isVisible);
assert.true(Layout.navbar.end.vaultLink.isVisible);
});
test('it diplays Consul link', async function (assert) {
server.create('agent', 'withConsulLink');
await visit('/');
assert.true(Layout.navbar.end.consulLink.isVisible);
assert.equal(Layout.navbar.end.consulLink.text, 'Consul');
assert.equal(Layout.navbar.end.consulLink.link, 'http://localhost:8500/ui');
});
test('it diplays Vault link', async function (assert) {
server.create('agent', 'withVaultLink');
await visit('/');
assert.true(Layout.navbar.end.vaultLink.isVisible);
assert.equal(Layout.navbar.end.vaultLink.text, 'Vault');
assert.equal(Layout.navbar.end.vaultLink.link, 'http://localhost:8200/ui');
});
test('it diplays SignIn', async function (assert) {
managementToken = server.create('token');
window.localStorage.clear();
await visit('/');
assert.true(Layout.navbar.end.signInLink.isVisible);
assert.false(Layout.navbar.end.profileDropdown.isVisible);
});
test('it diplays a Profile dropdown', async function (assert) {
managementToken = server.create('token');
window.localStorage.nomadTokenSecret = managementToken.secretId;
await visit('/');
assert.true(Layout.navbar.end.profileDropdown.isVisible);
assert.false(Layout.navbar.end.signInLink.isVisible);
await Layout.navbar.end.profileDropdown.open();
await click('.dropdown-options .ember-power-select-option:nth-child(1)');
assert.equal(
currentURL(),
'/settings/tokens',
'Authroization link takes you to the tokens page'
);
await Layout.navbar.end.profileDropdown.open();
await click('.dropdown-options .ember-power-select-option:nth-child(2)');
assert.equal(window.localStorage.nomadTokenSecret, null, 'Token is wiped');
assert.equal(currentURL(), '/jobs', 'After signout, back on the jobs page');
});
});