/** * 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'); }); });