54 lines
1.9 KiB
JavaScript
54 lines
1.9 KiB
JavaScript
import { module, test } from 'qunit';
|
|
import { setupRenderingTest } from 'ember-qunit';
|
|
import { render } from '@ember/test-helpers';
|
|
import { create } from 'ember-cli-page-object';
|
|
import featuresSelection from 'vault/tests/pages/components/wizard/features-selection';
|
|
import hbs from 'htmlbars-inline-precompile';
|
|
import Service from '@ember/service';
|
|
|
|
const component = create(featuresSelection);
|
|
|
|
const permissionsService = Service.extend({
|
|
hasPermission(path) {
|
|
// This enables the Secrets and Authentication wizard items and disables the others.
|
|
const allowedPaths = ['sys/mounts/example', 'sys/auth', 'sys/auth/foo', 'sys/wrapping/wrap'];
|
|
if (allowedPaths.includes(path)) {
|
|
return true;
|
|
}
|
|
return false;
|
|
},
|
|
});
|
|
|
|
module('Integration | Component | features-selection', function(hooks) {
|
|
setupRenderingTest(hooks);
|
|
|
|
hooks.beforeEach(function() {
|
|
this.owner.register('service:permissions', permissionsService);
|
|
});
|
|
|
|
test('it disables and enables wizard items according to user permissions', async function(assert) {
|
|
const enabled = { Secrets: true, Authentication: true, Policies: false, Tools: false };
|
|
await render(hbs`{{wizard/features-selection}}`);
|
|
|
|
component.wizardItems.forEach(i => {
|
|
assert.equal(
|
|
i.hasDisabledTooltip,
|
|
!enabled[i.text],
|
|
'shows a tooltip only when the wizard item is not enabled'
|
|
);
|
|
});
|
|
});
|
|
|
|
test('it disables the start button if no wizard items are checked', async function(assert) {
|
|
await render(hbs`{{wizard/features-selection}}`);
|
|
assert.equal(component.hasDisabledStartButton, true);
|
|
});
|
|
|
|
test('it enables the start button when user has permission and wizard items are checked', async function(assert) {
|
|
await render(hbs`{{wizard/features-selection}}`);
|
|
await component.selectSecrets();
|
|
|
|
assert.equal(component.hasDisabledStartButton, false);
|
|
});
|
|
});
|