«Не забудь зробити знімок компоненти!». Стисло про Snapshot-тестування на Jest

Сергій Єрьомін

«І не забудьте зробити знімок (Snapshot) компоненти!»

Ви часто можете почути таку фразу від вашого тим-ліда.

Ні, це не фото на пам’ять з вашою компонентою. І точно не JPEG або PNG.

Snapshot у Jest — це механізм для тестування інтерфейсу користувача, який дозволяє зберегти «знімок» вигляду компоненти на певний момент часу. Цей знімок містить рендерену версію компонента. Під час наступних запусків тестів, Jest порівнює актуальний рендер зі збереженим знімком. Якщо є різниця, тест не пройде, що вказує на те, що вигляд або структура компоненти змінилися.

 

Основні моменти про snapshot-тестування:

  • Створення: Коли ви запускаєте тест вперше, Jest створює snapshot і зберігає його у файлі.
  • Порівняння: При наступних запусках тестів Jest порівнює поточний рендер зі збереженим snapshot.
  • Оновлення: Якщо зміни у компоненті були очікуваними, ви можете оновити snapshot до нової версії.

Snapshot-тестування корисне, коли потрібно стежити, чи компоненти рендеряться очікуваним чином. Воно забезпечує додатковий шар захисту від ненавмисних змін у вашому коді.

Чи можу я побачити зміну шрифта за допомогою Snapshot?

Ні, snapshot-тестування в Jest не дозволяє побачити зміни шрифту, або інших стилів, які не відображаються у вихідному HTML-коді компоненти. Snapshots зберігають лише структуру JSX/HTML, яку рендерить компонента, і не включають інформацію про CSS-стилі, такі як колір, розмір шрифту, або інші візуальні властивості.

Сподіваюся, було цікаво. Дякую, що читаєте!

Цей текст з особистого блогу, опублікований з дозволу автора.

Останні статті

Google: невідомі намагались клонувати Gemini, відправивши 100 000 запитів про внутрішню роботу LLM

Google стверджує, що невідомі зловмисники використали понад 100 000 запитів, щоб спробувати клонувати чат-бот Gemini.…

12.02.2026

Найсучасніші функції Claude стали безкоштовними для всіх

Компанія Anthropic розширила функціонал безкоштовної версії свого чат-боту Claude. Відтепер функції створення файлів, конектори та…

12.02.2026

У Google Chrome виявили 287 розширень, які торгують вашою історією браузера

Дослідник під псевдонімом Q Continuum виявив у Google Chrome 287 розширень, які збирають та продають…

12.02.2026

Microsoft випустила бету TypeScript 6.0. Це останній реліз на базі JavaScript

Компанія Microsoft повідомила про реліз бета-версії TypeScript 6.0. Розробники можуть отримати її через npm за…

12.02.2026

Не просто коробка з бантом. Як оригінально подарувати гаджет: 5 незатратних способів

Сам по собі телефон Айфон 17 Про Макс – чудовий подарунок. У нього гарна заводська…

12.02.2026

Пентагон хоче, щоб OpenAI та Anthropic зробили для військових спеціальні версії LLM «без обмежень»

Міністерство оборони США наполягає на тому, щоб провідні компанії з розробки штучного інтелекту, включно з…

12.02.2026