ffd16dfec6
* 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
85 lines
2.7 KiB
JavaScript
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');
|
|
});
|
|
});
|