mirror of
https://github.com/hashicorp/vault.git
synced 2025-08-20 06:01:10 +02:00
* runs ember-cli-update to 4.4.0 * updates yarn.lock * updates dependencies causing runtime errors (#17135) * Inject Store Service When Accessed Implicitly (#17345) * adds codemod for injecting store service * adds custom babylon parser with decorators-legacy plugin for jscodeshift transforms * updates inject-store-service codemod to only look for .extend object expressions and adds recast options * runs inject-store-service codemod on js files * replace query-params helper with hash (#17404) * Updates/removes dependencies throwing errors in Ember 4.4 (#17396) * updates ember-responsive to latest * updates ember-composable-helpers to latest and uses includes helper since contains was removed * updates ember-concurrency to latest * updates ember-cli-clipboard to latest * temporary workaround for toolbar-link component throwing errors for using params arg with LinkTo * adds missing store injection to auth configure route * fixes issue with string-list component throwing error for accessing prop in same computation * fixes non-iterable query params issue in mfa methods controller * refactors field-to-attrs to handle belongsTo rather than fragments * converts mount-config fragment to belongsTo on auth-method model * removes ember-api-actions and adds tune method to auth-method adapter * converts cluster replication attributes from fragment to relationship * updates ember-data, removes ember-data-fragments and updates yarn to latest * removes fragments from secret-engine model * removes fragment from test-form-model * removes commented out code * minor change to inject-store-service codemod and runs again on js files * Remove LinkTo positional params (#17421) * updates ember-cli-page-object to latest version * update toolbar-link to support link-to args and not positional params * adds replace arg to toolbar-link component * Clean up js lint errors (#17426) * replaces assert.equal to assert.strictEqual * update eslint no-console to error and disables invididual intended uses of console * cleans up hbs lint warnings (#17432) * Upgrade bug and test fixes (#17500) * updates inject-service codemod to take arg for service name and runs for flashMessages service * fixes hbs lint error after merging main * fixes flash messages * updates more deps * bug fixes * test fixes * updates ember-cli-content-security-policy and prevents default form submission throwing errors * more bug and test fixes * removes commented out code * fixes issue with code-mirror modifier sending change event on setup causing same computation error * Upgrade Clean Up (#17543) * updates deprecation workflow and filter * cleans up build errors, removes unused ivy-codemirror and sass and updates ember-cli-sass and node-sass to latest * fixes control groups test that was skipped after upgrade * updates control group service tests * addresses review feedback * updates control group service handleError method to use router.currentURL rather that transition.intent.url * adds changelog entry
82 lines
3.5 KiB
JavaScript
82 lines
3.5 KiB
JavaScript
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');
|
|
let 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');
|
|
});
|
|
});
|