Files
topola-viewer/tests/charts_visual.spec.ts
2026-05-21 00:49:40 +02:00

30 lines
1.1 KiB
TypeScript

import {expect, test} from '@playwright/test';
import {setupGedcomRoute, setupHermeticEnvironment} from './helpers';
test.describe('Core SVG Canvas Layouts @visual', () => {
test.beforeEach(async ({context}) => {
await setupHermeticEnvironment(context);
await setupGedcomRoute(context);
});
const layouts = [
{view: 'hourglass', selector: '#svgContainer', waitTime: 500},
{view: 'relatives', selector: '#svgContainer', waitTime: 500},
{view: 'fancy', selector: '#svgContainer', waitTime: 500},
{view: 'donatso', selector: '#dotatsoSvgContainer', waitTime: 1500},
];
for (const layout of layouts) {
test(`chart-${layout.view}`, async ({page}) => {
await page.goto(
`/#/view?url=https://example.org/family.ged&view=${layout.view}`,
);
const container = page.locator(layout.selector);
await container.waitFor({state: 'visible'});
// Wait for D3 rendering and layout stabilization.
await page.waitForTimeout(layout.waitTime);
await expect(container).toHaveScreenshot(`chart-${layout.view}.png`);
});
}
});