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``);
    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.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``);
    await component.selectSecrets();
    assert.equal(component.hasDisabledStartButton, false);
  });
});