mirror of
https://github.com/hashicorp/vault.git
synced 2025-11-22 03:01:10 +01:00
* Allow Managed clusters to see Secrets Sync Overview and Sidebar nav (#26649) * update badge text and allow hvd on secrets sync views * update logic in Secrets Sync overview and cta for hvd. * spacing * rearrange based on pr feedback * fix return on badgeText and cluster nav test * fix landing cta tests * update test to reflect new changes * moved call to feature-flags from application route to the service to match patterns * add managed test coverage on overview component test and remove premium feature so cta message appplies to both managed and non-managed clusters * missed service name and unskip admin test * clean up * fix tests * flags test fix * Rename isManaged and managedNamespaceRoot (#26697) * renames * lowercase HVD to match * missed some * test failure * [Secrets Sync] enable access to Sync clients page for HVD clusters (#26713) * feat: split client counts navbar into separate component * acceptance/clients/counts/overview-test: remove tests now covered by int tests * clients counts route: rename isSecretsSyncActivated to showSecretsSync * sync clients page: show unactivated state unless sync client history or feature is activated * client counts navbar: show sync tab only if client history or is /able to be/ activated * clients overview page: only show sync charts if activated * fix: rename isManaged to isHvd * acceptance/counts/overview-test: add HVD tests * acceptance/counts/overview-test: clean up unused cruft * aceptance/clients/counts/overview-test: ensure we dont get false negatives * chore: move Clients::Error to Clients::Counts::Error * chore: calculate showSecretSync in page component instead of route * chore: add copyright headers * acceptance/clients/counts/overview-test: stub activated flags to fix test * [Secrets sync] update sync test selectors (#26824) * acceptance/clients/counts/overview-test: use imported test selectors * general-selectors: add missing emptyStateSubtitle property * acceptance/clients/counts/sync: nest tests in top level module for easier test runs * Add permissions check to show/hide activate button (#26840) * add permissions check to flags service and consume in overview template * add back missing refresh * fix test failures * add test coverage * clean up * address flaky test * grr * address test failures * add changelog * try to fix test failure only on gh * fix fetch to match previous implementation of feature-flags * fix failing test * update comment --------- Co-authored-by: Noelle Daley <noelledaley@users.noreply.github.com> Co-authored-by: clairebontempo@gmail.com <clairebontempo@gmail.com>
81 lines
3.7 KiB
TypeScript
81 lines
3.7 KiB
TypeScript
/**
|
|
* Copyright (c) HashiCorp, Inc.
|
|
* SPDX-License-Identifier: BUSL-1.1
|
|
*/
|
|
|
|
import { findAll } from '@ember/test-helpers';
|
|
|
|
export const GENERAL = {
|
|
breadcrumb: '[data-test-breadcrumbs] li',
|
|
breadcrumbAtIdx: (idx: string) => `[data-test-breadcrumbs] li:nth-child(${idx + 1}) a`,
|
|
breadcrumbs: '[data-test-breadcrumbs]',
|
|
breadcrumbLink: (label: string) => `[data-test-breadcrumb="${label}"] a`,
|
|
title: '[data-test-page-title]',
|
|
headerContainer: 'header.page-header',
|
|
icon: (name: string) => `[data-test-icon="${name}"]`,
|
|
tab: (name: string) => `[data-test-tab="${name}"]`,
|
|
secretTab: (name: string) => `[data-test-secret-list-tab="${name}"]`,
|
|
flashMessage: '[data-test-flash-message]',
|
|
latestFlashContent: '[data-test-flash-message]:last-of-type [data-test-flash-message-body]',
|
|
|
|
filter: (name: string) => `[data-test-filter="${name}"]`,
|
|
filterInput: '[data-test-filter-input]',
|
|
confirmModalInput: '[data-test-confirmation-modal-input]',
|
|
confirmButton: '[data-test-confirm-button]',
|
|
confirmTrigger: '[data-test-confirm-action-trigger]',
|
|
emptyStateTitle: '[data-test-empty-state-title]',
|
|
emptyStateSubtitle: '[data-test-empty-state-subtitle]',
|
|
emptyStateMessage: '[data-test-empty-state-message]',
|
|
emptyStateActions: '[data-test-empty-state-actions]',
|
|
menuTrigger: '[data-test-popup-menu-trigger]',
|
|
listItem: '[data-test-list-item-link]',
|
|
// FORMS
|
|
checkboxByAttr: (attr: string) => `[data-test-checkbox="${attr}"]`,
|
|
enableField: (attr: string) => `[data-test-enable-field="${attr}"] button`,
|
|
fieldByAttr: (attr: string) => `[data-test-field="${attr}"]`,
|
|
infoRowLabel: (label: string) => `[data-test-row-label="${label}"]`,
|
|
infoRowValue: (label: string) => `[data-test-value-div="${label}"]`,
|
|
inputByAttr: (attr: string) => `[data-test-input="${attr}"]`,
|
|
selectByAttr: (attr: string) => `[data-test-select="${attr}"]`,
|
|
toggleInput: (attr: string) => `[data-test-toggle-input="${attr}"]`,
|
|
ttl: {
|
|
toggle: (attr: string) => `[data-test-toggle-label="${attr}"]`,
|
|
input: (attr: string) => `[data-test-ttl-value="${attr}"]`,
|
|
},
|
|
|
|
validation: (attr: string) => `[data-test-field-validation=${attr}]`,
|
|
validationWarning: (attr: string) => `[data-test-validation-warning=${attr}]`,
|
|
messageError: '[data-test-message-error]',
|
|
kvObjectEditor: {
|
|
deleteRow: (idx = 0) => `[data-test-kv-delete-row="${idx}"]`,
|
|
},
|
|
searchSelect: {
|
|
trigger: (id: string) => `[data-test-component="search-select"]#${id} .ember-basic-dropdown-trigger`,
|
|
options: '.ember-power-select-option',
|
|
optionIndex: (text: string) =>
|
|
findAll('.ember-power-select-options li').findIndex((e) => e.textContent?.trim() === text),
|
|
option: (index = 0) => `.ember-power-select-option:nth-child(${index + 1})`,
|
|
selectedOption: (index = 0) => `[data-test-selected-option="${index}"]`,
|
|
noMatch: '.ember-power-select-option--no-matches-message',
|
|
removeSelected: '[data-test-selected-list-button="delete"]',
|
|
},
|
|
overviewCard: {
|
|
title: (title: string) => `[data-test-overview-card-title="${title}"]`,
|
|
description: (title: string) => `[data-test-overview-card-subtitle="${title}"]`,
|
|
content: (title: string) => `[data-test-overview-card-content="${title}"]`,
|
|
action: (title: string) => `[data-test-overview-card-container="${title}"] [data-test-action-text]`,
|
|
actionLink: (label: string) => `[data-test-action-text="${label}"]`,
|
|
},
|
|
pagination: {
|
|
next: '.hds-pagination-nav__arrow--direction-next',
|
|
prev: '.hds-pagination-nav__arrow--direction-prev',
|
|
},
|
|
kvSuggestion: {
|
|
input: '[data-test-kv-suggestion-input]',
|
|
select: '[data-test-kv-suggestion-select]',
|
|
},
|
|
navLink: (label: string) => `[data-test-sidebar-nav-link="${label}"]`,
|
|
cancelButton: '[data-test-cancel]',
|
|
saveButton: '[data-test-save]',
|
|
};
|