mirror of
https://github.com/hashicorp/vault.git
synced 2025-08-15 02:57:04 +02:00
* add ember-cli-deprecation-workflow * this._router in routes to quiet deprecation * mark style bindings as htmlSafe strings * simplify authenticate service hook with async fn * don't serialize aliases relationship on entities * update ember-test-selectors so we can use supportsDataTestProperties * allow duplicate flash messages because we don't want a log warning * update ember-concurrency for better error message * use ember-qunit instead of ember-cli-qunit * update ember-cli-page-object so we're not using a beta lol * ignore test-helper jquery context warning * fix race condition in pgp-file test by using ember-concurrency task and test waiter * await cli commands * fail tests if async leakage is detected * update auth-jwt component and tests to be simpler * fix linting * review feedback
61 lines
2.6 KiB
JavaScript
61 lines
2.6 KiB
JavaScript
import { currentRouteName } from '@ember/test-helpers';
|
|
import { module, test } from 'qunit';
|
|
import { setupApplicationTest } from 'ember-qunit';
|
|
import editPage from 'vault/tests/pages/secrets/backend/kv/edit-secret';
|
|
import showPage from 'vault/tests/pages/secrets/backend/kv/show';
|
|
import listPage from 'vault/tests/pages/secrets/backend/list';
|
|
import consolePanel from 'vault/tests/pages/components/console/ui-panel';
|
|
import authPage from 'vault/tests/pages/auth';
|
|
|
|
import { create } from 'ember-cli-page-object';
|
|
|
|
import apiStub from 'vault/tests/helpers/noop-all-api-requests';
|
|
|
|
const cli = create(consolePanel);
|
|
|
|
module('Acceptance | secrets/generic/create', function(hooks) {
|
|
setupApplicationTest(hooks);
|
|
|
|
hooks.beforeEach(function() {
|
|
this.server = apiStub({ usePassthrough: true });
|
|
return authPage.login();
|
|
});
|
|
|
|
hooks.afterEach(function() {
|
|
this.server.shutdown();
|
|
});
|
|
|
|
test('it creates and can view a secret with the generic backend', async function(assert) {
|
|
const path = `generic-${new Date().getTime()}`;
|
|
const kvPath = `generic-kv-${new Date().getTime()}`;
|
|
await cli.runCommands([`write sys/mounts/${path} type=generic`, `write ${path}/foo bar=baz`]);
|
|
await listPage.visitRoot({ backend: path });
|
|
assert.equal(currentRouteName(), 'vault.cluster.secrets.backend.list-root', 'navigates to the list page');
|
|
assert.equal(listPage.secrets.length, 1, 'lists one secret in the backend');
|
|
|
|
await listPage.create();
|
|
await editPage.createSecret(kvPath, 'foo', 'bar');
|
|
assert.equal(currentRouteName(), 'vault.cluster.secrets.backend.show', 'redirects to the show page');
|
|
assert.ok(showPage.editIsPresent, 'shows the edit button');
|
|
});
|
|
|
|
test('upgrading generic to version 2 lists all existing secrets, and CRUD continues to work', async function(assert) {
|
|
const path = `generic-${new Date().getTime()}`;
|
|
const kvPath = `generic-kv-${new Date().getTime()}`;
|
|
await cli.runCommands([
|
|
`write sys/mounts/${path} type=generic`,
|
|
`write ${path}/foo bar=baz`,
|
|
// upgrade to version 2 generic mount
|
|
`write sys/mounts/${path}/tune options=version=2`,
|
|
]);
|
|
await listPage.visitRoot({ backend: path });
|
|
assert.equal(currentRouteName(), 'vault.cluster.secrets.backend.list-root', 'navigates to the list page');
|
|
assert.equal(listPage.secrets.length, 1, 'lists the old secret in the backend');
|
|
|
|
await listPage.create();
|
|
await editPage.createSecret(kvPath, 'foo', 'bar');
|
|
await listPage.visitRoot({ backend: path });
|
|
assert.equal(listPage.secrets.length, 2, 'lists two secrets in the backend');
|
|
});
|
|
});
|