test(ui): add component tests for NameHistoryCard
Some checks failed
CI / Unit & Component Tests (push) Failing after 3s
CI / Backend Unit Tests (push) Failing after 1s
CI / Unit & Component Tests (pull_request) Failing after 2s
CI / Backend Unit Tests (pull_request) Failing after 2s

Verifies alias rendering, empty state, firstName fallback,
and type label display. 5 browser-based Svelte tests.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
Marcel
2026-04-07 13:43:09 +02:00
parent 6d837c518c
commit f0eb3a76be

View File

@@ -0,0 +1,55 @@
import { describe, it, expect } from 'vitest';
import { render } from 'vitest-browser-svelte';
import { page } from 'vitest/browser';
import NameHistoryCard from './NameHistoryCard.svelte';
const aliases = [
{ id: 'a1', lastName: 'de Gruyter', firstName: null, type: 'BIRTH', sortOrder: 0 },
{ id: 'a2', lastName: 'Schmidt', firstName: 'Maria', type: 'WIDOWED', sortOrder: 1 }
];
describe('NameHistoryCard', () => {
it('should render one row per alias', async () => {
render(NameHistoryCard, { aliases, personFirstName: 'Clara' });
await expect.element(page.getByText('de Gruyter')).toBeInTheDocument();
await expect.element(page.getByText('Schmidt')).toBeInTheDocument();
});
it('should show empty state when no aliases', async () => {
render(NameHistoryCard, { aliases: [], personFirstName: 'Clara' });
const emptyText = document.querySelector('.italic');
expect(emptyText).not.toBeNull();
expect(emptyText!.textContent!.length).toBeGreaterThan(0);
});
it('should use personFirstName when alias firstName is null', async () => {
render(NameHistoryCard, {
aliases: [{ id: 'a1', lastName: 'de Gruyter', firstName: null, type: 'BIRTH', sortOrder: 0 }],
personFirstName: 'Clara'
});
await expect.element(page.getByText('Clara')).toBeInTheDocument();
});
it('should use alias firstName when provided', async () => {
render(NameHistoryCard, {
aliases: [
{ id: 'a1', lastName: 'Schmidt', firstName: 'Maria', type: 'WIDOWED', sortOrder: 0 }
],
personFirstName: 'Clara'
});
await expect.element(page.getByText('Maria')).toBeInTheDocument();
});
it('should show type labels', async () => {
render(NameHistoryCard, {
aliases: [{ id: 'a1', lastName: 'de Gruyter', firstName: null, type: 'BIRTH', sortOrder: 0 }],
personFirstName: 'Clara'
});
await expect.element(page.getByText('geborene/r')).toBeInTheDocument();
});
});