open-vault/ui/tests/integration/components/pki/page/pki-key-list-test.js
claire bontempo 04396e5f9c
UI/pki key workflow tests (#18496)
* wip tests

* fix links

* Revert "wip tests"

This reverts commit aed9bb9b8fffb1b4d52d9c27644033ff3d983fff.

* wip tests

* add policy generator

* add workflow tests for key

* change apostrophe -___-

* fix workflow tests

* add update to key form tests

* fix capability check for read

* finish tests

* fix flash messages;

* rename policy generator file, update tests
2023-01-03 18:00:29 -08:00

102 lines
3.6 KiB
JavaScript

import { module, test } from 'qunit';
import { setupRenderingTest } from 'ember-qunit';
import { click, render } from '@ember/test-helpers';
import { hbs } from 'ember-cli-htmlbars';
import { setupEngine } from 'ember-engines/test-support';
import { setupMirage } from 'ember-cli-mirage/test-support';
import { SELECTORS } from 'vault/tests/helpers/pki/page/pki-keys';
module('Integration | Component | pki key list page', function (hooks) {
setupRenderingTest(hooks);
setupEngine(hooks, 'pki');
setupMirage(hooks);
hooks.beforeEach(function () {
this.store = this.owner.lookup('service:store');
this.secretMountPath = this.owner.lookup('service:secret-mount-path');
this.secretMountPath.currentPath = 'pki-test';
this.store.pushPayload('pki/key', {
modelName: 'pki/key',
key_id: '724862ff-6438-bad0-b598-77a6c7f4e934',
key_type: 'ec',
key_name: 'test-key',
});
this.store.pushPayload('pki/key', {
modelName: 'pki/key',
key_id: '9fdddf12-9ce3-0268-6b34-dc1553b00175',
key_type: 'rsa',
key_name: 'another-key',
});
this.keyModels = this.store.peekAll('pki/key');
});
test('it renders empty state when no keys exist', async function (assert) {
assert.expect(3);
this.keyModels = [];
await render(
hbs`
<Page::PkiKeyList
@keyModels={{this.keyModels}}
@mountPoint="vault.cluster.secrets.backend.pki"
@canImportKey={{true}}
@canGenerateKey={{true}}
/>,
`,
{ owner: this.engine }
);
assert
.dom('[data-test-empty-state-title]')
.hasText('No keys yet', 'renders empty state that no keys exist');
assert.dom(SELECTORS.importKey).exists('renders toolbar with import action');
assert.dom(SELECTORS.generateKey).exists('renders toolbar with generate action');
});
test('it renders list of keys and actions when permission allowed', async function (assert) {
assert.expect(6);
await render(
hbs`
<Page::PkiKeyList
@keyModels={{this.keyModels}}
@mountPoint="vault.cluster.secrets.backend.pki"
@canImportKey={{true}}
@canGenerateKey={{true}}
@canRead={{true}}
@canEdit={{true}}
/>,
`,
{ owner: this.engine }
);
assert
.dom(SELECTORS.keyId)
.hasText('724862ff-6438-bad0-b598-77a6c7f4e934', 'linked block renders key id');
assert.dom(SELECTORS.keyName).hasText('test-key', 'linked block renders key name');
assert.dom(SELECTORS.importKey).exists('renders import action');
assert.dom(SELECTORS.generateKey).exists('renders generate action');
await click(SELECTORS.popupMenuTrigger);
assert.dom(SELECTORS.popupMenuDetails).exists('details link exists');
assert.dom(SELECTORS.popupMenuEdit).exists('edit link exists');
});
test('it hides or disables actions when permission denied', async function (assert) {
assert.expect(4);
await render(
hbs`
<Page::PkiKeyList
@keyModels={{this.keyModels}}
@mountPoint="vault.cluster.secrets.backend.pki"
@canImportKey={{false}}
@canGenerateKey={{false}}
@canRead={{false}}
@canEdit={{false}}
/>,
`,
{ owner: this.engine }
);
assert.dom(SELECTORS.importKey).doesNotExist('renders import action');
assert.dom(SELECTORS.generateKey).doesNotExist('renders generate action');
await click(SELECTORS.popupMenuTrigger);
assert.dom(SELECTORS.popupMenuDetails).hasClass('disabled', 'details link enabled');
assert.dom(SELECTORS.popupMenuEdit).hasClass('disabled', 'edit link enabled');
});
});