Почему лучше искать элементы по role?

ReactJuniorTesting, accessibility and securityПрактикаtestingaccessibility

Что хотят услышать интервьюеры:

Коротко: Поиск по role приближает тест к тому, как assistive technologies видят интерфейс, и проверяет доступность.

Ответ:

Что важно сказать на собеседовании: На собеседовании важно связать эту тему с реальной render-моделью React: где источник данных, что вызывает обновление, какие побочные эффекты допустимы и как это влияет на поддержку интерфейса.

Пример (Testing Library):

expect(screen.getByRole('button', { name: /сохранить/i })).toBeEnabled();
expect(screen.getByRole('textbox', { name: /email/i })).toHaveValue('');

Типичные ошибки: Типичная ошибка — отвечать только синтаксисом и не объяснять, как решение поведёт себя при повторном render, смене props, unmount или росте данных.

Практический контекст: В практике это встречается в формах, списках, dashboards, личных кабинетах и компонентах design-system; сильный ответ показывает не только API, но и границы применения.

Источники

Похожие вопросы