Files
vault/ui/tests/acceptance/unseal-test.js
Matthew Irish 49ee9e72a7 ui: add ember exam (#24669)
* feature(ember-exam): add ember-exam to split ui tests and run them in parallel

* update yarn.lock

* update package.json scripts

* test(oidc): comment out test with race condition in oidc test

* chore(test): use 127.0.0.1 in testem config and add uuid to pki mount path

* test(kv-workflow): make policy creation unique per-test

* chore(test): use --preserve-test-name so flakey test reporting is preserved

* yarn test:filter runs ember test instead of exam for easier filtering

* fix kv control group tests

---------

Co-authored-by: Chelsea Shaw <cshaw@hashicorp.com>
2024-01-08 11:17:11 -06:00

50 lines
1.4 KiB
JavaScript

/**
* Copyright (c) HashiCorp, Inc.
* SPDX-License-Identifier: BUSL-1.1
*/
import { click, currentRouteName, currentURL, fillIn, settled, visit } from '@ember/test-helpers';
import { module, test } from 'qunit';
import { setupApplicationTest } from 'ember-qunit';
import VAULT_KEYS from 'vault/tests/helpers/vault-keys';
import authPage from 'vault/tests/pages/auth';
import { pollCluster } from 'vault/tests/helpers/poll-cluster';
const { unsealKeys } = VAULT_KEYS;
module.skip('Acceptance | unseal', function (hooks) {
setupApplicationTest(hooks);
hooks.beforeEach(function () {
return authPage.login();
});
test('seal then unseal', async function (assert) {
await visit('/vault/settings/seal');
assert.strictEqual(currentURL(), '/vault/settings/seal');
// seal
await click('[data-test-seal]');
await click('[data-test-confirm-button]');
await pollCluster(this.owner);
await settled();
assert.strictEqual(currentURL(), '/vault/unseal', 'vault is on the unseal page');
// unseal
for (const key of unsealKeys) {
await fillIn('[data-test-shamir-key-input]', key);
await click('button[type="submit"]');
await pollCluster(this.owner);
await settled();
}
assert.dom('[data-test-cluster-status]').doesNotExist('ui does not show sealed warning');
assert.strictEqual(currentRouteName(), 'vault.cluster.auth', 'vault is ready to authenticate');
});
});