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
131 lines
3.1 KiB
JavaScript
131 lines
3.1 KiB
JavaScript
import {
|
|
attribute,
|
|
create,
|
|
clickable,
|
|
collection,
|
|
hasClass,
|
|
isHidden,
|
|
isPresent,
|
|
property,
|
|
text,
|
|
} from 'ember-cli-page-object';
|
|
|
|
export default create({
|
|
navbar: {
|
|
scope: '[data-test-global-header]',
|
|
|
|
regionSwitcher: {
|
|
scope: '[data-test-region-switcher-parent]',
|
|
isPresent: isPresent(),
|
|
open: clickable('.ember-power-select-trigger'),
|
|
options: collection('.ember-power-select-option', {
|
|
label: text(),
|
|
}),
|
|
},
|
|
|
|
search: {
|
|
scope: '[data-test-search-parent]',
|
|
|
|
click: clickable('.ember-power-select-trigger'),
|
|
|
|
groups: collection('.ember-power-select-group', {
|
|
testContainer: '.ember-power-select-options',
|
|
resetScope: true,
|
|
name: text('.ember-power-select-group-name'),
|
|
|
|
options: collection('.ember-power-select-option'),
|
|
}),
|
|
|
|
noOptionsShown: isHidden('.ember-power-select-options', {
|
|
testContainer: '.ember-basic-dropdown-content',
|
|
resetScope: true,
|
|
}),
|
|
|
|
field: {
|
|
scope: '.ember-power-select-search input',
|
|
testContainer: 'html',
|
|
resetScope: true,
|
|
},
|
|
},
|
|
|
|
end: {
|
|
scope: '.navbar-end',
|
|
|
|
consulLink: {
|
|
scope: '[data-test-header-consul-link]',
|
|
text: text(),
|
|
link: property('href'),
|
|
},
|
|
|
|
vaultLink: {
|
|
scope: '[data-test-header-vault-link]',
|
|
text: text(),
|
|
link: property('href'),
|
|
},
|
|
|
|
signInLink: {
|
|
scope: '[data-test-header-signin-link]',
|
|
text: text(),
|
|
link: property('href'),
|
|
},
|
|
|
|
profileDropdown: {
|
|
scope: '[data-test-header-profile-dropdown]',
|
|
text: text(),
|
|
open: clickable(),
|
|
options: collection('.dropdown-label', {
|
|
label: text(),
|
|
choose: clickable(),
|
|
}),
|
|
},
|
|
},
|
|
},
|
|
|
|
gutter: {
|
|
scope: '[data-test-gutter-menu]',
|
|
visitJobs: clickable('[data-test-gutter-link="jobs"]'),
|
|
|
|
optimize: {
|
|
scope: '[data-test-gutter-link="optimize"]',
|
|
},
|
|
|
|
variables: {
|
|
scope: '[data-test-gutter-link="variables"]',
|
|
},
|
|
|
|
visitClients: clickable('[data-test-gutter-link="clients"]'),
|
|
visitServers: clickable('[data-test-gutter-link="servers"]'),
|
|
visitStorage: clickable('[data-test-gutter-link="storage"]'),
|
|
},
|
|
|
|
breadcrumbs: collection('[data-test-breadcrumb]', {
|
|
id: attribute('data-test-breadcrumb'),
|
|
text: text(),
|
|
visit: clickable(),
|
|
}),
|
|
|
|
breadcrumbFor(id) {
|
|
return this.breadcrumbs.toArray().find((crumb) => crumb.id === id);
|
|
},
|
|
|
|
error: {
|
|
isPresent: isPresent('[data-test-error]'),
|
|
title: text('[data-test-error-title]'),
|
|
message: text('[data-test-error-message]'),
|
|
},
|
|
|
|
inlineError: {
|
|
isShown: isPresent('[data-test-inline-error]'),
|
|
title: text('[data-test-inline-error-title]'),
|
|
message: text('[data-test-inline-error-body]'),
|
|
dismiss: clickable('[data-test-inline-error-close]'),
|
|
|
|
isDanger: hasClass('is-danger', '[data-test-inline-error]'),
|
|
isWarning: hasClass('is-warning', '[data-test-inline-error]'),
|
|
},
|
|
|
|
keyboard: {
|
|
modalShown: isPresent('.keyboard-shortcuts'),
|
|
},
|
|
});
|