mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-08 13:06:15 +02:00
69 lines
2.2 KiB
TypeScript
69 lines
2.2 KiB
TypeScript
|
import { test, expect } from './util/test';
|
||
|
import MainScreen from './models/MainScreen';
|
||
|
import SettingsScreen from './models/SettingsScreen';
|
||
|
import AxeBuilder from '@axe-core/playwright';
|
||
|
import { Page } from '@playwright/test';
|
||
|
|
||
|
const createScanner = (page: Page) => {
|
||
|
return new AxeBuilder({ page })
|
||
|
.disableRules(['page-has-heading-one'])
|
||
|
.setLegacyMode(true);
|
||
|
};
|
||
|
|
||
|
// Fade-in transitions can cause color contrast issues if still running
|
||
|
// during a scan.
|
||
|
// See https://github.com/dequelabs/axe-core-npm/issues/952
|
||
|
const waitForAnimationsToEnd = (page: Page) => {
|
||
|
return page.locator('body').evaluate(element => {
|
||
|
const animationPromises = element
|
||
|
.getAnimations({ subtree: true })
|
||
|
.map(animation => animation.finished);
|
||
|
return Promise.all(animationPromises);
|
||
|
});
|
||
|
};
|
||
|
|
||
|
const expectNoViolations = async (page: Page) => {
|
||
|
await waitForAnimationsToEnd(page);
|
||
|
const results = await createScanner(page).analyze();
|
||
|
expect(results.violations).toEqual([]);
|
||
|
};
|
||
|
|
||
|
|
||
|
test.describe('wcag', () => {
|
||
|
for (const tabName of ['General', 'Plugins']) {
|
||
|
test(`should not detect significant issues in the settings screen ${tabName} tab`, async ({ electronApp, mainWindow }) => {
|
||
|
const mainScreen = new MainScreen(mainWindow);
|
||
|
await mainScreen.waitFor();
|
||
|
|
||
|
await mainScreen.openSettings(electronApp);
|
||
|
|
||
|
// Should be on the settings screen
|
||
|
const settingsScreen = new SettingsScreen(mainWindow);
|
||
|
await settingsScreen.waitFor();
|
||
|
|
||
|
const tabLocator = settingsScreen.getTabLocator(tabName);
|
||
|
await tabLocator.click();
|
||
|
await expect(tabLocator).toBeFocused();
|
||
|
|
||
|
await expectNoViolations(mainWindow);
|
||
|
});
|
||
|
}
|
||
|
|
||
|
test('should not detect significant issues in the main screen with an open note', async ({ mainWindow }) => {
|
||
|
const mainScreen = new MainScreen(mainWindow);
|
||
|
await mainScreen.waitFor();
|
||
|
|
||
|
await mainScreen.createNewNote('Test');
|
||
|
|
||
|
// For now, activate all notes to make it active. When inactive, it causes a contrast warning.
|
||
|
// This seems to be allowed under WCAG 2.2 SC 1.4.3 under the "Incidental" exception.
|
||
|
await mainScreen.sidebar.allNotes.click();
|
||
|
|
||
|
// Ensure that `:hover` styling is consistent between tests:
|
||
|
await mainScreen.noteEditor.noteTitleInput.hover();
|
||
|
|
||
|
await expectNoViolations(mainWindow);
|
||
|
});
|
||
|
});
|
||
|
|