mirror of
https://github.com/hashicorp/vault.git
synced 2025-08-24 16:11:08 +02:00
152 lines
5.6 KiB
JavaScript
152 lines
5.6 KiB
JavaScript
/**
|
|
* Copyright (c) HashiCorp, Inc.
|
|
* SPDX-License-Identifier: BUSL-1.1
|
|
*/
|
|
|
|
import { module, test } from 'qunit';
|
|
import { setupRenderingTest } from 'ember-qunit';
|
|
import { setupEngine } from 'ember-engines/test-support';
|
|
import { setupMirage } from 'ember-cli-mirage/test-support';
|
|
import { render, click, fillIn } from '@ember/test-helpers';
|
|
import hbs from 'htmlbars-inline-precompile';
|
|
import { allowAllCapabilitiesStub } from 'vault/tests/helpers/stubs';
|
|
import { createSecretsEngine, generateBreadcrumbs } from 'vault/tests/helpers/ldap/ldap-helpers';
|
|
import sinon from 'sinon';
|
|
import { LDAP_SELECTORS } from 'vault/tests/helpers/ldap/ldap-selectors';
|
|
|
|
module('Integration | Component | ldap | Page::Roles', function (hooks) {
|
|
setupRenderingTest(hooks);
|
|
setupEngine(hooks, 'ldap');
|
|
setupMirage(hooks);
|
|
|
|
hooks.beforeEach(function () {
|
|
this.server.post('/sys/capabilities-self', allowAllCapabilitiesStub());
|
|
|
|
this.store = this.owner.lookup('service:store');
|
|
this.backend = createSecretsEngine(this.store);
|
|
this.breadcrumbs = generateBreadcrumbs(this.backend.id);
|
|
|
|
for (const type of ['static', 'dynamic']) {
|
|
this.store.pushPayload('ldap/role', {
|
|
modelName: 'ldap/role',
|
|
backend: 'ldap-test',
|
|
type,
|
|
...this.server.create('ldap-role', type, { name: `${type}-test` }),
|
|
});
|
|
}
|
|
this.backend = this.store.peekRecord('secret-engine', 'ldap-test');
|
|
this.roles = this.store.peekAll('ldap/role');
|
|
this.roles.meta = {
|
|
currentPage: 1,
|
|
pageSize: 10,
|
|
filteredTotal: this.roles.length,
|
|
total: this.roles.length,
|
|
};
|
|
this.promptConfig = false;
|
|
|
|
this.renderComponent = () => {
|
|
return render(
|
|
hbs`<Page::Roles
|
|
@promptConfig={{this.promptConfig}}
|
|
@backendModel={{this.backend}}
|
|
@roles={{this.roles}}
|
|
@breadcrumbs={{this.breadcrumbs}}
|
|
@pageFilter={{this.pageFilter}}
|
|
/>`,
|
|
{ owner: this.engine }
|
|
);
|
|
};
|
|
});
|
|
|
|
test('it should render tab page header and config cta', async function (assert) {
|
|
this.promptConfig = true;
|
|
|
|
await this.renderComponent();
|
|
|
|
assert.dom('.title svg').hasClass('hds-icon-folder-users', 'LDAP icon renders in title');
|
|
assert.dom('.title').hasText('ldap-test', 'Mount path renders in title');
|
|
assert
|
|
.dom('[data-test-toolbar-action="config"]')
|
|
.hasText('Configure LDAP', 'Correct toolbar action renders');
|
|
assert.dom('[data-test-config-cta]').exists('Config cta renders');
|
|
});
|
|
|
|
test('it should render create roles cta', async function (assert) {
|
|
this.roles = null;
|
|
|
|
await this.renderComponent();
|
|
|
|
assert.dom('[data-test-toolbar-action="role"]').hasText('Create role', 'Toolbar action has correct text');
|
|
assert
|
|
.dom('[data-test-toolbar-action="role"] svg')
|
|
.hasClass('hds-icon-plus', 'Toolbar action has correct icon');
|
|
assert
|
|
.dom('[data-test-filter-input]')
|
|
.doesNotExist('Roles filter input is hidden when roles have not been created');
|
|
assert.dom('[data-test-empty-state-title]').hasText('No roles created yet', 'Title renders');
|
|
assert
|
|
.dom('[data-test-empty-state-message]')
|
|
.hasText(
|
|
'Roles in Vault will allow you to manage LDAP credentials. Create a role to get started.',
|
|
'Message renders'
|
|
);
|
|
});
|
|
|
|
test('it should render roles list', async function (assert) {
|
|
await this.renderComponent();
|
|
|
|
assert.dom('[data-test-list-item-content] svg').hasClass('hds-icon-user', 'List item icon renders');
|
|
assert
|
|
.dom(LDAP_SELECTORS.roleItem('static', 'static-test'))
|
|
.hasText(this.roles[0].name, 'List item name renders');
|
|
assert
|
|
.dom('[data-test-role-type-badge="static-test"]')
|
|
.hasText(this.roles[0].type, 'List item type badge renders');
|
|
|
|
await click('[data-test-popup-menu-trigger]');
|
|
assert.dom('[data-test-edit]').hasText('Edit', 'Edit link renders in menu');
|
|
assert.dom('[data-test-get-creds]').hasText('Get credentials', 'Get credentials link renders in menu');
|
|
assert
|
|
.dom('[data-test-rotate-creds]')
|
|
.hasText('Rotate credentials', 'Rotate credentials link renders in menu');
|
|
assert.dom('[data-test-details]').hasText('Details', 'Details link renders in menu');
|
|
assert.dom('[data-test-delete]').hasText('Delete', 'Details link renders in menu');
|
|
|
|
await click('[data-test-popup-menu-trigger]:last-of-type');
|
|
assert
|
|
.dom('[data-test-popup-menu-trigger]:last-of-type [data-test-rotate-creds]')
|
|
.doesNotExist('Rotate credentials link is hidden for dynamic type');
|
|
});
|
|
|
|
test('it should filter roles', async function (assert) {
|
|
const currentRouteName = 'vault.cluster.secrets.backend.ldap.roles';
|
|
this.router = this.owner.lookup('service:router');
|
|
const transitionStub = sinon.stub(this.router, 'transitionTo');
|
|
// stub because the component calls either "roles.subdirectory" or "roles.index"
|
|
// depending on where it renders
|
|
sinon.stub(this.router, 'currentRoute').value({
|
|
name: currentRouteName,
|
|
});
|
|
this.roles.meta.filteredTotal = 0;
|
|
this.pageFilter = 'foo';
|
|
|
|
await this.renderComponent();
|
|
|
|
assert
|
|
.dom('[data-test-empty-state-title]')
|
|
.hasText('There are no roles matching "foo"', 'Filter message renders');
|
|
|
|
await fillIn('[data-test-filter-input]', 'bar');
|
|
|
|
const [calledRoute, calledParams] = transitionStub.lastCall.args;
|
|
assert.strictEqual(calledRoute, currentRouteName);
|
|
assert.propEqual(
|
|
calledParams,
|
|
{
|
|
queryParams: { pageFilter: 'bar' },
|
|
},
|
|
'Transition called with correct query params on filter change'
|
|
);
|
|
});
|
|
});
|