Files
vault/ui/tests/acceptance/access/identity/_shared-tests.js
Chelsea Shaw 52c0dc812b UI: Dependency bumps 1.17.x (#26346)
* re-form yarn.lock, remove resolutions that are out of date. resolves:

- mout VAULT-25595 VAULT-25603
- follow-redirects VAULT-25605
- terser VAULT-25594 VAULT-25593
- minimatch VAULT-25591
- loader-utils VAULT-25216 VAULT-25590 VAULT-25589 VAULT-25588 VAULT-25587
- decode-uri-component VAULT-25586
- qs VAULT-25585
- @xmldom/xmldom VAULT-25217

* VAULT-25596 pin async in resolutions due to testem > fireworm

* VAULT-25606 pin nth-check due to ember-svg-jar

* fix typescript errors after bump

* update ember-template-lint to 6.0.0

* Add broken rules to template-eslintrc

* pin ansi-html

* remove ember-d3 in favor of specific d3 libraries we import

* add changelog
2024-04-12 22:13:45 +00:00

83 lines
3.1 KiB
JavaScript

/**
* Copyright (c) HashiCorp, Inc.
* SPDX-License-Identifier: BUSL-1.1
*/
import { settled, currentRouteName, click, waitUntil, find } from '@ember/test-helpers';
import { selectChoose, clickTrigger } from 'ember-power-select/test-support/helpers';
import page from 'vault/tests/pages/access/identity/create';
import showPage from 'vault/tests/pages/access/identity/show';
import indexPage from 'vault/tests/pages/access/identity/index';
import { GENERAL } from 'vault/tests/helpers/general-selectors';
const SELECTORS = {
identityRow: (name) => `[data-test-identity-row="${name}"]`,
popupMenu: '[data-test-popup-menu-trigger]',
menuDelete: '[data-test-popup-menu="delete"]',
};
export const testCRUD = async (name, itemType, assert) => {
await page.visit({ item_type: itemType });
await settled();
await page.editForm.name(name).submit();
await settled();
assert.dom(GENERAL.latestFlashContent).includesText('Successfully saved');
assert.strictEqual(
currentRouteName(),
'vault.cluster.access.identity.show',
`${itemType}: navigates to show on create`
);
assert.ok(showPage.nameContains(name), `${itemType}: renders the name on the show page`);
await indexPage.visit({ item_type: itemType });
await settled();
assert.strictEqual(
indexPage.items.filterBy('name', name).length,
1,
`${itemType}: lists the entity in the entity list`
);
await click(`${SELECTORS.identityRow(name)} ${SELECTORS.popupMenu}`);
await waitUntil(() => find(SELECTORS.menuDelete));
await click(SELECTORS.menuDelete);
await indexPage.confirmDelete();
await settled();
assert.dom(GENERAL.latestFlashContent).includesText('Successfully deleted');
assert.strictEqual(indexPage.items.filterBy('name', name).length, 0, `${itemType}: the row is deleted`);
};
export const testDeleteFromForm = async (name, itemType, assert) => {
await page.visit({ item_type: itemType });
await settled();
await page.editForm.name(name);
await page.editForm.metadataKey('hello');
await page.editForm.metadataValue('goodbye');
await clickTrigger('#policies');
// first option should be "default"
await selectChoose('#policies', '.ember-power-select-option', 0);
await page.editForm.submit();
await click('[data-test-tab-subnav="policies"]');
assert.dom('.list-item-row').exists({ count: 1 }, 'One item is under policies');
await click('[data-test-tab-subnav="metadata"]');
assert.dom('.info-table-row').hasText('hello goodbye', 'Metadata shows on tab');
await showPage.edit();
assert.strictEqual(
currentRouteName(),
'vault.cluster.access.identity.edit',
`${itemType}: navigates to edit on create`
);
await settled();
await page.editForm.delete();
await settled();
await page.editForm.confirmDelete();
await settled();
assert.dom(GENERAL.latestFlashContent).includesText('Successfully deleted');
assert.strictEqual(
currentRouteName(),
'vault.cluster.access.identity.index',
`${itemType}: navigates to list page on delete`
);
assert.strictEqual(
indexPage.items.filterBy('name', name).length,
0,
`${itemType}: the row does not show in the list`
);
};