open-vault/ui/tests/integration/components/oidc/assignment-form-test.js

164 lines
6.4 KiB
JavaScript

import { module, test } from 'qunit';
import { setupRenderingTest } from 'ember-qunit';
import { render, fillIn, click, findAll } from '@ember/test-helpers';
import { hbs } from 'ember-cli-htmlbars';
import { setupMirage } from 'ember-cli-mirage/test-support';
import ENV from 'vault/config/environment';
import { overrideMirageResponse } from 'vault/tests/helpers/oidc-config';
module('Integration | Component | oidc/assignment-form', function (hooks) {
setupRenderingTest(hooks);
setupMirage(hooks);
hooks.before(function () {
ENV['ember-cli-mirage'].handler = 'oidcConfig';
});
hooks.after(function () {
ENV['ember-cli-mirage'].handler = null;
});
hooks.beforeEach(function () {
this.store = this.owner.lookup('service:store');
this.server.post('/sys/capabilities-self', () => {});
});
test('it should save new assignment', async function (assert) {
assert.expect(6);
this.model = this.store.createRecord('oidc/assignment');
this.server.post('/identity/oidc/assignment/test', (schema, req) => {
assert.ok(true, 'Request made to save assignment');
return JSON.parse(req.requestBody);
});
this.onSave = () => assert.ok(true, 'onSave callback fires on save success');
await render(hbs`
<Oidc::AssignmentForm
@model={{this.model}}
@onCancel={{this.onCancel}}
@onSave={{this.onSave}}
/>
`);
assert.dom('[data-test-oidc-assignment-title]').hasText('Create assignment', 'Form title renders');
assert.dom('[data-test-oidc-assignment-save]').hasText('Create', 'Save button has correct label');
await click('[data-test-oidc-assignment-save]');
assert
.dom('[data-test-inline-alert]')
.hasText('Name is required.', 'Validation message is shown for name');
assert.equal(findAll('[data-test-inline-error-message]').length, 2, `there are two validations errors.`);
await fillIn('[data-test-input="name"]', 'test');
await click('[data-test-component="search-select"]#entities .ember-basic-dropdown-trigger');
await click('.ember-power-select-option');
await click('[data-test-oidc-assignment-save]');
});
test('it should populate fields with model data on edit view and update an assignment', async function (assert) {
assert.expect(6);
this.store.pushPayload('oidc/assignment', {
modelName: 'oidc/assignment',
name: 'test',
entity_ids: ['1234-12345'],
group_ids: ['abcdef-123'],
});
this.model = this.store.peekRecord('oidc/assignment', 'test');
await render(hbs`
<Oidc::AssignmentForm
@model={{this.model}}
@onCancel={{this.onCancel}}
@onSave={{this.onSave}}
/>
`);
assert.dom('[data-test-oidc-assignment-title]').hasText('Edit assignment', 'Form title renders');
assert.dom('[data-test-oidc-assignment-save]').hasText('Update', 'Save button has correct label');
assert.dom('[data-test-input="name"]').isDisabled('Name input is disabled when editing');
assert.dom('[data-test-input="name"]').hasValue('test', 'Name input is populated with model value');
assert
.dom('[data-test-search-select="entities"] [data-test-smaller-id="true"]')
.hasText('1234-12345', 'entity id renders in selected option');
assert
.dom('[data-test-search-select="groups"] [data-test-smaller-id="true"]')
.hasText('abcdef-123', 'group id renders in selected option');
});
test('it should use fallback component on create if no permissions for entities or groups', async function (assert) {
assert.expect(2);
this.model = this.store.createRecord('oidc/assignment');
this.server.get('/identity/entity/id', () => overrideMirageResponse(403));
this.server.get('/identity/group/id', () => overrideMirageResponse(403));
await render(hbs`
<Oidc::AssignmentForm
@model={{this.model}}
@onCancel={{this.onCancel}}
@onSave={{this.onSave}}
/>
`);
assert
.dom('[data-test-component="search-select"]#entities [data-test-component="string-list"]')
.exists('entities string list fallback component exists');
assert
.dom('[data-test-component="search-select"]#groups [data-test-component="string-list"]')
.exists('groups string list fallback component exists');
});
test('it should use fallback component on edit if no permissions for entities or groups', async function (assert) {
assert.expect(8);
this.store.pushPayload('oidc/assignment', {
modelName: 'oidc/assignment',
name: 'test',
entity_ids: ['1234-12345'],
group_ids: ['abcdef-123'],
});
this.model = this.store.peekRecord('oidc/assignment', 'test');
this.server.get('/identity/entity/id', () => overrideMirageResponse(403));
this.server.get('/identity/group/id', () => overrideMirageResponse(403));
await render(hbs`
<Oidc::AssignmentForm
@model={{this.model}}
@onCancel={{this.onCancel}}
@onSave={{this.onSave}}
/>
`);
assert
.dom('[data-test-component="search-select"]#entities [data-test-component="string-list"]')
.exists('entities string list fallback component exists');
assert
.dom('[data-test-component="search-select"]#entities [data-test-string-list-input="0"]')
.hasValue('1234-12345', 'first row pre-populated with model entity');
assert
.dom(
'[data-test-component="search-select"]#entities [data-test-string-list-row="0"] [data-test-string-list-button="delete"]'
)
.exists('first row renders delete icon');
assert
.dom(
'[data-test-component="search-select"]#entities [data-test-string-list-row="1"] [data-test-string-list-button="add"]'
)
.exists('second row renders add icon');
assert
.dom('[data-test-component="search-select"]#groups [data-test-component="string-list"]')
.exists('groups string list fallback component exists');
assert
.dom('[data-test-component="search-select"]#groups [data-test-string-list-input="0"]')
.hasValue('abcdef-123', 'first row pre-populated with model group');
assert
.dom(
'[data-test-component="search-select"]#groups [data-test-string-list-row="0"] [data-test-string-list-button="delete"]'
)
.exists('first row renders delete icon');
assert
.dom(
'[data-test-component="search-select"]#groups [data-test-string-list-row="1"] [data-test-string-list-button="add"]'
)
.exists('second row renders add icon');
});
});