87 lines
3.6 KiB
JavaScript
87 lines
3.6 KiB
JavaScript
/**
|
|
* Copyright (c) HashiCorp, Inc.
|
|
* SPDX-License-Identifier: MPL-2.0
|
|
*/
|
|
|
|
import { module, test } from 'qunit';
|
|
import { currentURL, visit, fillIn } from '@ember/test-helpers';
|
|
import { setupApplicationTest } from 'ember-qunit';
|
|
import Pretender from 'pretender';
|
|
import logout from 'vault/tests/pages/logout';
|
|
import { getManagedNamespace } from 'vault/routes/vault/cluster';
|
|
|
|
const FEATURE_FLAGS_RESPONSE = {
|
|
feature_flags: ['VAULT_CLOUD_ADMIN_NAMESPACE'],
|
|
};
|
|
|
|
module('Acceptance | Enterprise | Managed namespace root', function (hooks) {
|
|
setupApplicationTest(hooks);
|
|
|
|
hooks.beforeEach(function () {
|
|
/**
|
|
* Since the features are fetched on the application load,
|
|
* we have to populate them on the beforeEach hook because
|
|
* the fetch won't trigger again within the tests
|
|
*/
|
|
this.server = new Pretender(function () {
|
|
this.get('/v1/sys/internal/ui/feature-flags', () => {
|
|
return [200, { 'Content-Type': 'application/json' }, JSON.stringify(FEATURE_FLAGS_RESPONSE)];
|
|
});
|
|
this.get('/v1/sys/health', this.passthrough);
|
|
this.get('/v1/sys/seal-status', this.passthrough);
|
|
this.get('/v1/sys/license/features', this.passthrough);
|
|
this.get('/v1/sys/internal/ui/mounts', this.passthrough);
|
|
});
|
|
});
|
|
|
|
hooks.afterEach(function () {
|
|
this.server.shutdown();
|
|
});
|
|
|
|
test('it shows the managed namespace toolbar when feature flag exists', async function (assert) {
|
|
await logout.visit();
|
|
await visit('/vault/auth');
|
|
assert.ok(currentURL().startsWith('/vault/auth'), 'Redirected to auth');
|
|
assert.ok(currentURL().includes('?namespace=admin'), 'with base namespace');
|
|
assert.dom('[data-test-namespace-toolbar]').doesNotExist('Normal namespace toolbar does not exist');
|
|
assert.dom('[data-test-managed-namespace-toolbar]').exists('Managed namespace toolbar exists');
|
|
assert.dom('[data-test-managed-namespace-root]').hasText('/admin', 'Shows /admin namespace prefix');
|
|
assert.dom('input#namespace').hasAttribute('placeholder', '/ (Default)');
|
|
await fillIn('input#namespace', '/foo');
|
|
const encodedNamespace = encodeURIComponent('admin/foo');
|
|
assert.strictEqual(
|
|
currentURL(),
|
|
`/vault/auth?namespace=${encodedNamespace}&with=token`,
|
|
'Correctly prepends root to namespace'
|
|
);
|
|
});
|
|
|
|
test('getManagedNamespace helper works as expected', function (assert) {
|
|
let managedNs = getManagedNamespace(null, 'admin');
|
|
assert.strictEqual(managedNs, 'admin', 'returns root ns when no namespace present');
|
|
managedNs = getManagedNamespace('admin/', 'admin');
|
|
assert.strictEqual(managedNs, 'admin', 'returns root ns when matches passed ns');
|
|
managedNs = getManagedNamespace('adminfoo/', 'admin');
|
|
assert.strictEqual(
|
|
managedNs,
|
|
'admin/adminfoo/',
|
|
'appends passed namespace to root even if it matches without slashes'
|
|
);
|
|
managedNs = getManagedNamespace('admin/foo/', 'admin');
|
|
assert.strictEqual(managedNs, 'admin/foo/', 'returns passed namespace if it starts with root and /');
|
|
});
|
|
|
|
test('it redirects to root prefixed ns when non-root passed', async function (assert) {
|
|
await logout.visit();
|
|
await visit('/vault/auth?namespace=admindev');
|
|
assert.ok(currentURL().startsWith('/vault/auth'), 'Redirected to auth');
|
|
assert.ok(
|
|
currentURL().includes(`?namespace=${encodeURIComponent('admin/admindev')}`),
|
|
'with appended namespace'
|
|
);
|
|
|
|
assert.dom('[data-test-managed-namespace-root]').hasText('/admin', 'Shows /admin namespace prefix');
|
|
assert.dom('input#namespace').hasValue('/admindev', 'Input has /dev value');
|
|
});
|
|
});
|