/* eslint-disable ember-a11y-testing/a11y-audit-called */
import { module, test } from 'qunit';
import { setupRenderingTest } from 'ember-qunit';
import { click, findAll, render } from '@ember/test-helpers';
import { hbs } from 'ember-cli-htmlbars';
module('Integration | Component | breadcrumbs', function (hooks) {
setupRenderingTest(hooks);
test('it declaratively renders a list of registered crumbs', async function (assert) {
this.set('isRegistered', false);
this.set('toggleCrumb', () => this.set('isRegistered', !this.isRegistered));
await render(hbs`
{{#each bb as |crumb|}}
{{crumb.args.crumb}}
{{/each}}
{{#if this.isRegistered}}
{{/if}}
`);
assert
.dom('[data-test-crumb]')
.exists({ count: 1 }, 'We register one crumb');
assert
.dom('[data-test-crumb]')
.hasText('Zoey', 'The first registered crumb is Zoey');
await click('[data-test-button]');
const crumbs = await findAll('[data-test-crumb]');
assert
.dom('[data-test-crumb]')
.exists({ count: 2 }, 'The second crumb registered successfully');
assert
.dom(crumbs[0])
.hasText(
'Zoey',
'Breadcrumbs maintain the order in which they are declared'
);
assert
.dom(crumbs[1])
.hasText(
'Tomster',
'Breadcrumbs maintain the order in which they are declared'
);
await click('[data-test-button]');
assert
.dom('[data-test-crumb]')
.exists({ count: 1 }, 'We deregister one crumb');
assert
.dom('[data-test-crumb]')
.hasText(
'Zoey',
'Zoey remains in the template after Tomster deregisters'
);
});
test('it can register complex crumb objects', async function (assert) {
await render(hbs`
{{#each bb as |crumb|}}
{{crumb.args.crumb.name}}
{{/each}}
`);
assert
.dom('[data-test-crumb]')
.hasText(
'Tomster',
'We can access the registered breadcrumbs in the template'
);
});
});