vault/ui/tests/integration/components/sidebar/nav/tools-test.js
Angel Garbarino 967c241c15
Add API Explorer Link to Sidebar Nav under tools (#21578)
* wip

* add outlet and sidebar nav link

* add changelog

* fix tests

* address pr comment
2023-07-05 18:05:32 +00:00

45 lines
1.7 KiB
JavaScript

import { module, test } from 'qunit';
import { setupRenderingTest } from 'ember-qunit';
import { render } from '@ember/test-helpers';
import hbs from 'htmlbars-inline-precompile';
import { stubFeaturesAndPermissions } from 'vault/tests/helpers/components/sidebar-nav';
import { toolsActions } from 'vault/helpers/tools-actions';
import { capitalize } from '@ember/string';
const renderComponent = () => {
return render(hbs`
<Sidebar::Frame @isVisible={{true}}>
<div id="modal-wormhole"></div>
<Sidebar::Nav::Tools />
</Sidebar::Frame>
`);
};
module('Integration | Component | sidebar-nav-tools', function (hooks) {
setupRenderingTest(hooks);
test('it should hide links user does not have access too', async function (assert) {
await renderComponent();
assert
.dom('[data-test-sidebar-nav-link]')
.exists({ count: 2 }, 'Nav links are hidden other than back link and api explorer.');
});
test('it should render nav headings and links', async function (assert) {
const links = ['Back to main navigation', ...toolsActions(), 'API Explorer'];
stubFeaturesAndPermissions(this.owner);
await renderComponent();
assert.dom('[data-test-sidebar-nav-heading]').exists({ count: 1 }, 'Correct number of headings render');
assert.dom('[data-test-sidebar-nav-heading="Tools"]').hasText('Tools', 'Tools heading renders');
assert
.dom('[data-test-sidebar-nav-link]')
.exists({ count: links.length }, 'Correct number of links render');
links.forEach((link) => {
const name = capitalize(link);
assert.dom(`[data-test-sidebar-nav-link="${name}"]`).hasText(name, `${name} link renders`);
});
});
});