import { expect, fixture, html } from '@open-wc/testing'; import '../../../dist/shoelace.js'; import type SlAvatar from './avatar'; describe('', () => { let el: SlAvatar; describe('when provided no parameters', async () => { before(async () => { el = await fixture(html` `); }); it('passes accessibility test', async () => { await expect(el).to.be.accessible(); }); it('should default to circle styling', async () => { const part = el.shadowRoot?.querySelector('[part="base"]') as HTMLElement; expect(el.getAttribute('shape')).to.eq('circle'); expect(part.classList.value.trim()).to.eq('avatar avatar--circle'); }); }); describe('when provided an image and label parameter', async () => { const image = ''; const label = 'Small transparent square'; before(async () => { el = await fixture(html``); }); it('passes accessibility test', async () => { /** * The image element itself is ancillary, because it's parent container contains the * aria-label which dictates what "sl-avatar" is. This also implies that label text will * resolve to "" when not provided and ignored by readers. This is why we use alt="" on * the image element to pass accessibility. * https://html.spec.whatwg.org/multipage/images.html#ancillary-images */ await expect(el).to.be.accessible(); }); it('renders "image" part, with src and a role of presentation', async () => { const part = el.shadowRoot?.querySelector('[part="image"]') as HTMLImageElement; expect(part.getAttribute('src')).to.eq(image); }); it('renders the label attribute in the "base" part', async () => { const part = el.shadowRoot?.querySelector('[part="base"]') as HTMLElement; expect(part.getAttribute('aria-label')).to.eq(label); }); }); describe('when provided initials parameter', async () => { const initials = 'SL'; before(async () => { el = await fixture(html``); }); it('passes accessibility test', async () => { await expect(el).to.be.accessible(); }); it('renders "initials" part, with initials as the text node', async () => { const part = el.shadowRoot?.querySelector('[part="initials"]') as HTMLImageElement; expect(part.innerText).to.eq(initials); }); }); ['square', 'rounded', 'circle'].forEach(shape => { describe(`when passed a shape attribute ${shape}`, () => { before(async () => { el = await fixture(html``); }); it('passes accessibility test', async () => { await expect(el).to.be.accessible(); }); it('appends the appropriate class on the "base" part', async () => { const part = el.shadowRoot?.querySelector('[part="base"]') as HTMLElement; expect(el.getAttribute('shape')).to.eq(shape); expect(part.classList.value.trim()).to.eq(`avatar avatar--${shape}`); }); }); }); describe('when passed a , on slot "icon"', async () => { before(async () => { el = await fixture(html`random content`); }); it('passes accessibility test', async () => { await expect(el).to.be.accessible(); }); it('should accept as an assigned child in the shadow root', async () => { const slot = el.shadowRoot.querySelector('slot[name=icon]'); const childNodes = slot.assignedNodes({ flatten: true }); expect(childNodes.length).to.eq(1); const span = childNodes[0]; expect(span.innerHTML).to.eq('random content'); }); }); });