import { later, _cancelTimers as cancelTimers } from '@ember/runloop'; import { module, test } from 'qunit'; import { setupRenderingTest } from 'ember-qunit'; import { render, settled } from '@ember/test-helpers'; import { setupMirage } from 'ember-cli-mirage/test-support'; import { allowAllCapabilitiesStub, noopStub } from 'vault/tests/helpers/stubs'; import hbs from 'htmlbars-inline-precompile'; import { create } from 'ember-cli-page-object'; import mountBackendForm from '../../pages/components/mount-backend-form'; import sinon from 'sinon'; const component = create(mountBackendForm); module('Integration | Component | mount backend form', function (hooks) { setupRenderingTest(hooks); setupMirage(hooks); hooks.beforeEach(function () { this.owner.lookup('service:flash-messages').registerTypes(['success', 'danger']); this.store = this.owner.lookup('service:store'); this.server.post('/sys/capabilities-self', allowAllCapabilitiesStub()); this.server.post('/sys/auth/foo', noopStub()); this.server.post('/sys/mounts/foo', noopStub()); this.onMountSuccess = sinon.spy(); }); hooks.afterEach(function () { this.server.shutdown(); }); module('auth method', function (hooks) { hooks.beforeEach(function () { this.model = this.store.createRecord('auth-method'); this.model.set('config', this.store.createRecord('mount-config')); }); test('it renders default state', async function (assert) { await render( hbs`` ); assert.strictEqual( component.header, 'Enable an Authentication Method', 'renders auth header in default state' ); assert.ok(component.types.length > 0, 'renders type picker'); }); test('it changes path when type is changed', async function (assert) { await render( hbs`` ); await component.selectType('aws'); await component.next(); assert.strictEqual(component.pathValue, 'aws', 'sets the value of the type'); await component.back(); await component.selectType('approle'); await component.next(); assert.strictEqual(component.pathValue, 'approle', 'updates the value of the type'); }); test('it keeps path value if the user has changed it', async function (assert) { await render( hbs`` ); await component.selectType('approle'); await component.next(); assert.strictEqual(this.model.type, 'approle', 'Updates type on model'); assert.strictEqual(component.pathValue, 'approle', 'defaults to approle (first in the list)'); await component.path('newpath'); assert.strictEqual(this.model.path, 'newpath', 'Updates path on model'); await component.back(); assert.strictEqual(this.model.type, '', 'Clears type on back'); assert.strictEqual(this.model.path, 'newpath', 'Path is still newPath'); await component.selectType('aws'); await component.next(); assert.strictEqual(this.model.type, 'aws', 'Updates type on model'); assert.strictEqual(component.pathValue, 'newpath', 'keeps custom path value'); }); test('it calls mount success', async function (assert) { assert.expect(2); this.server.post('/sys/auth/foo', () => { assert.ok(true, 'it calls enable on an auth method'); return [204, { 'Content-Type': 'application/json' }]; }); const spy = sinon.spy(); this.set('onMountSuccess', spy); await render( hbs`` ); await component.mount('approle', 'foo'); later(() => cancelTimers(), 50); await settled(); assert.ok(spy.calledOnce, 'calls the passed success method'); }); }); module('secrets engine', function (hooks) { hooks.beforeEach(function () { this.model = this.store.createRecord('secret-engine'); this.model.set('config', this.store.createRecord('mount-config')); }); test('it renders secret specific headers', async function (assert) { await render( hbs`` ); assert.strictEqual(component.header, 'Enable a Secrets Engine', 'renders secrets header'); assert.ok(component.types.length > 0, 'renders type picker'); }); test('it changes path when type is changed', async function (assert) { await render( hbs`` ); await component.selectType('kv'); await component.next(); assert.strictEqual(component.pathValue, 'kv', 'sets the value of the type'); await component.back(); await component.selectType('ssh'); await component.next(); assert.strictEqual(component.pathValue, 'ssh', 'updates the value of the type'); }); test('it keeps path value if the user has changed it', async function (assert) { await render( hbs`` ); await component.selectType('kv'); await component.next(); assert.strictEqual(this.model.type, 'kv', 'Updates type on model'); assert.strictEqual(component.pathValue, 'kv', 'path matches mount type'); await component.path('newpath'); assert.strictEqual(this.model.path, 'newpath', 'Updates path on model'); await component.back(); assert.strictEqual(this.model.type, '', 'Clears type on back'); assert.strictEqual(this.model.path, 'newpath', 'path is still newpath'); await component.selectType('ssh'); await component.next(); assert.strictEqual(this.model.type, 'ssh', 'Updates type on model'); assert.strictEqual(component.pathValue, 'newpath', 'path stays the same'); }); test('it calls mount success', async function (assert) { assert.expect(2); this.server.post('/sys/mounts/foo', () => { assert.ok(true, 'it calls enable on an secrets engine'); return [204, { 'Content-Type': 'application/json' }]; }); const spy = sinon.spy(); this.set('onMountSuccess', spy); await render( hbs`` ); await component.mount('ssh', 'foo'); later(() => cancelTimers(), 50); await settled(); assert.ok(spy.calledOnce, 'calls the passed success method'); }); }); });