AFFiNE/tests/affine-local/e2e/theme.spec.ts

36 lines
1.2 KiB
TypeScript
Raw Normal View History

import { resolve } from 'node:path';
2023-04-28 09:40:44 +03:00
import { test, testResultDir } from '@affine-test/kit/playwright';
import { openHomePage } from '@affine-test/kit/utils/load-page';
import { waitForEditorLoad } from '@affine-test/kit/utils/page-logic';
2023-02-05 13:41:18 +03:00
import { expect } from '@playwright/test';
2023-02-17 10:33:32 +03:00
2023-04-28 09:40:44 +03:00
// default could be anything, according to the system
test('default white', async ({ browser }) => {
const context = await browser.newContext({
colorScheme: 'light',
2022-11-10 15:51:06 +03:00
});
const page = await context.newPage();
await openHomePage(page);
await waitForEditorLoad(page);
const root = page.locator('html');
const themeMode = await root.evaluate(element =>
element.getAttribute('data-theme')
);
expect(themeMode).toBe('light');
2023-04-28 09:40:44 +03:00
await page.screenshot({
path: resolve(testResultDir, 'affine-light-theme.png'),
});
2023-07-31 10:56:51 +03:00
await page.getByTestId('settings-modal-trigger').click();
await page.getByTestId('appearance-panel-trigger').click();
await page.waitForTimeout(50);
2023-07-31 10:56:51 +03:00
await page.getByTestId('dark-theme-trigger').click();
const darkMode = await root.evaluate(element =>
element.getAttribute('data-theme')
);
expect(darkMode).toBe('dark');
2023-04-28 09:40:44 +03:00
await page.screenshot({
path: resolve(testResultDir, 'affine-dark-theme.png'),
});
2022-11-10 15:51:06 +03:00
});