mirror of
https://github.com/freeCodeCamp/freeCodeCamp.git
synced 2026-05-28 18:26:54 +00:00
test(e2e,playwright): shortcuts-modal (#52155)
This commit is contained in:
@@ -0,0 +1,90 @@
|
||||
import { test, expect } from '@playwright/test';
|
||||
|
||||
import translations from '../client/i18n/locales/english/translations.json';
|
||||
|
||||
const course =
|
||||
'/learn/javascript-algorithms-and-data-structures/basic-javascript/comment-your-javascript-code';
|
||||
const editorPaneLabel =
|
||||
'Editor content;Press Alt+F1 for Accessibility Options.';
|
||||
|
||||
test.use({ storageState: 'playwright/.auth/certified-user.json' });
|
||||
|
||||
test.beforeEach(async ({ page, browserName }) => {
|
||||
test.skip(
|
||||
browserName === 'webkit',
|
||||
'Failing on webkit for no apparent reason. Can not reproduce locally.'
|
||||
);
|
||||
|
||||
// Enable keyboard shortcuts
|
||||
await page.goto('/settings');
|
||||
const keyboardShortcutGroup = page.getByRole('group', {
|
||||
name: translations.settings.labels['keyboard-shortcuts']
|
||||
});
|
||||
await keyboardShortcutGroup
|
||||
.getByRole('button', { name: translations.buttons.on, exact: true })
|
||||
.click();
|
||||
|
||||
// Open shortcuts modal
|
||||
await page.goto(course);
|
||||
await page.getByLabel(editorPaneLabel).press('Escape');
|
||||
await page.keyboard.press('Shift+?');
|
||||
});
|
||||
|
||||
test('User can see list of shortcuts by pressing SHIFT + ?', async ({
|
||||
page
|
||||
}) => {
|
||||
await expect(
|
||||
page.getByRole('heading', { name: translations.shortcuts.title })
|
||||
).toBeVisible();
|
||||
|
||||
for (const shortcut of Object.values(translations.shortcuts)) {
|
||||
if (shortcut === translations.shortcuts.title) continue;
|
||||
|
||||
await expect(page.getByText(shortcut)).toBeVisible();
|
||||
}
|
||||
|
||||
await expect(
|
||||
page.getByText(translations.settings.labels['keyboard-shortcuts'])
|
||||
).toHaveCount(2);
|
||||
await expect(
|
||||
page.getByRole('button', { name: translations.buttons.on })
|
||||
).toBeVisible();
|
||||
await expect(
|
||||
page.getByRole('button', { name: translations.buttons.off })
|
||||
).toBeVisible();
|
||||
|
||||
await expect(
|
||||
page.getByRole('button', { name: translations.buttons.close })
|
||||
).toBeVisible();
|
||||
});
|
||||
|
||||
test('User can close the modal by pressing ESC', async ({ page }) => {
|
||||
await expect(
|
||||
page.getByRole('heading', { name: translations.shortcuts.title })
|
||||
).toBeVisible();
|
||||
|
||||
await page.keyboard.press('Escape');
|
||||
await expect(
|
||||
page.getByRole('heading', { name: translations.shortcuts.title })
|
||||
).not.toBeVisible();
|
||||
});
|
||||
|
||||
test('User can disable keyboard shortcuts', async ({ page }) => {
|
||||
await expect(
|
||||
page.getByRole('heading', { name: translations.shortcuts.title })
|
||||
).toBeVisible();
|
||||
|
||||
await page.getByRole('button', { name: translations.buttons.off }).click();
|
||||
await page.getByRole('button', { name: translations.buttons.close }).click();
|
||||
await expect(
|
||||
page.getByRole('heading', { name: translations.shortcuts.title })
|
||||
).not.toBeVisible();
|
||||
await expect(
|
||||
page.getByText(new RegExp(translations.flash['keyboard-shortcut-updated']))
|
||||
).toBeVisible();
|
||||
|
||||
await page.keyboard.press('Shift+?');
|
||||
await expect(
|
||||
page.getByRole('heading', { name: translations.shortcuts.title })
|
||||
).not.toBeVisible();
|
||||
});
|
||||
Reference in New Issue
Block a user