mirror of
https://github.com/PeWu/topola-viewer.git
synced 2026-05-26 15:16:14 +00:00
30 lines
1.1 KiB
TypeScript
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`);
|
|
});
|
|
}
|
|
});
|