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) {
assert.expect(4);
const enabled = { Secrets: true, Authentication: true, Policies: false, Tools: false };
await render(hbs``);
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``);
assert.true(component.hasDisabledStartButton);
});
test('it enables the start button when user has permission and wizard items are checked', async function (assert) {
await render(hbs``);
await component.selectSecrets();
assert.false(component.hasDisabledStartButton);
});
});