UA RU
logo
Досвід      03/04/2023

Гроші — не єдина «приманка»: 5 вигід від впровадження автоматизованих тестів на проєкті

Ілля Книш BLOG

Automation QA Lead в NIX

У першій частині своєї статті на Highload я розповідав про фінансове обґрунтування інвестицій в автотести. Тепер зосередимось на тому, як побудувати процес оцінювання вигоди від автоматизації тестування.

Повірте, зацікавити клієнта в цьому питанні можна не лише економією грошей.

Обґрунтування інвестицій: ваші основні кроки

Разом з проєктним менеджером, QA, розробником продукту та експертом з автоматизації ви маєте пройти кілька етапів. Ось вони.

1Оцінити ситуацію

Передусім треба зрозуміти, чи готовий проєкт до покриття тест-кейсами. На старті це неможливо, але можна на майбутнє передбачити для автоматизації необхідні технічні можливості.

2Визначити технічну складність

У деяких випадках майже неможливо автоматизувати тести (наприклад, для відео). Іноді автоматизація невиправдано складна або дорога (як для тієї ж капчі). Зрозумійте весь обсяг зусиль на впровадження автоматизації.

Для цього розпитайте розробників про технології, які використовуються у застосунку. В ідеалі у вас має бути повноцінний стек.

Варто знати інтерфейси взаємодії із системою та її архітектуру, розуміти, чи реально передбачити очікувану поведінку системи. На основі зібраних даних продумайте варіанти реалізації автотестів. Можна навіть створити Proof of Concept.

3Порахувати ROI

Це основний етап, коли ви матимете прогноз виправдання інвестицій. Говорити про конкретні показники навряд чи варто.

На одному проєкті ви зможете «продати» автоматизовані тести при 3%, а на іншому й 20% буде замало.

Інколи автоматизація тестування має сенс навіть при ROI менше нуля. Просто тут доцільність автотестів вимірюється не у фінансовій площині. Більше про це розповім далі.

Онлайн-курс "Blender" від Skvot.
3D-художники переходять на Blender, а в геймстудіях зростає кількість вакансій. 22 заняття, 4 роботи у портфоліо, фідбек та кар’єрні поради від досвідчених 3D-художників, щоб стартувати в геймдеві впевнено. .
Детальніше

4Підготувати план робіт

Для початку треба відповісти собі на три питання:

  • Тестування чого саме ви автоматизуєте? Це може стосуватися фронтенду, бекенду або їх складових частин
  • Коли хочете впроваджувати автотести? Це можна робити, наприклад, після розробки бекенду, на стабільній GUI або за наявності чернетки тестових сценаріїв тощо.
  • Які тести будуть автоматизовані — інтеграційні, системні чи компонентні на рівні сервісів?

Чим більше ви зможете самі собі пояснити, тим краще вам вдасться розробити тест-план та виділити пріоритетні напрями автоматизації. На основі цих відповідей ви зможете правильно підібрати стек технологій і побудувати роадмап.

А головне — це покаже замовнику ваше розуміння бізнес-цілей, що врешті може позитивно позначитись на обговоренні вашої пропозиції.

Інші вигоди від впровадження автоматизованих тестів

Гроші — не єдина «приманка» інвестицій. Деякі компанії дозволяють собі не економити бюджети. Та загалом будь-які інновації на проєкті клієнти сприймають як ризик. Вони потребують введення у команду нових ролей, складних процесів і потоків даних. Через це прибутковому бізнесу невисокий ROI не завжди цікавий. Для таких замовників треба шукати інші переваги автоматизованого тестування.

Достатньо погуглити, і ви побачите десятки досліджень, які підкреслюють вигоди від такого тестування. Я ж хочу виокремити декілька найбільш значущих, на мій погляд.

Прискорення доставки функціоналу на продакшн

Замовник швидше отримуватиме релізи завдяки тому, що паузи між розробкою, пошуком дефектів та їх усуненням стануть коротшими.

Курс Python developer від Mate academy.
Опануйте Python та отримайте свою першу роботу в IT! Ми навчимо вас усім необхідним навичкам та допоможемо з працевлаштуванням.
Отримати знижку на курс

Автоматизоване тестування триває значно менше у порівнянні з мануальним. При цьому зворотний зв’язок у команді стає більш щільним.

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

Перехід до стратегії Shift-left

Назва цієї моделі означає, що тестування зміщується на часовій шкалі ліворуч. Як приклад, можна згадати підхід Test Driven Development, коли тести пишуться ще до початку розробки функціоналу.

В ідеалі автоматизоване тестування відбувається одразу після написання коду. Наприклад, за наявності smoke-тестівОзначає мінімальний набір тестів на явні помилки. Цей тест зазвичай виконується самим програмістом. Програму, яка не пройшла такий тест, немає сенсу передавати на глибше тестування., які прив’язані до CI/CD, розробник бачить помилки після деплою та по ходу справи виправляє їх. Це також допомагає економити час та гроші на розробку.

Покращення регресійного тестування

З автотестами регресійне тестування можна проводити частіше під час розробки. Самі ж регресії будуть менш «болісними». Адже автоматизоване тестування є стандартизованим і виключає людський фактор. Тож ризики появи помилок та їх повернення значно нижчі, ніж при мануальному тестуванні. До того ж частіші запуски не призведуть до суттєвого підвищення вартості проєкту.

Більш придатний до тестування продукт

Впровадження автоматизації дозволяє розробникам створити інструменти, які спростять тестування.

Завдяки активній взаємодії девелоперів та тестувальників може з’явитися абсолютно новий функціонал для тестування.

Наприклад, айдішники в UI, з якими простіше написати локатори при створенні автотестів. Або ж програми, які створюють сутності в системі, чим зазвичай займаються мануальні QA. Таким чином фахівці можуть зосередитись на інших, складніших задачах. І це знову ж таки дозволить оптимізувати бюджети.

Розвиток команди

З появою автоматизації на проєкті мануальні QA зможуть долучитися до нового виду тестування. Вони познайомляться з новими технологіями та підходами, візьмуться за цікаві для них задачі та розвиватимуться у нових напрямках. При автоматизації рутинних тестів мануальні спеціалісти можуть зосередитися на пошуку незвичайних і дуже дорогих помилок у системі. Тож автоматизація тестів — це ще й простір для розвитку команди.

Онлайн-курс DevOps engineer від Mate academy.
DevOps інженери відповідають за автоматизацію процесів розробки, тестування та випуску продукту. Завдяки цьому курсу ви швидко станете високооплачуваним спеціалістом.
Отримати знижку на курс

Наостанок моя проста порада: будьте чесними. Якщо бачите, що вигода від автоматизованого тестування на проєкті невелика або є ризики — прямо кажіть про це. Клієнти цінують прозорість та чесність.

Ваша відкритість буде кроком до побудови довірливих стосунків із замовником. А це вже основа для довготривалої та плідної співпраці.

Якщо ви знайшли помилку, будь ласка, виділіть фрагмент тексту та натисніть Ctrl+Enter.

Курс QA engineer від Mate academy.
Після навчання на курсі QA engineer ви зможете розробляти плани тестування додатків та сайтів. Працевлаштування гарантовано.
Отримати знижку на курс

Цей матеріал – не редакційний, це – особиста думка його автора. Редакція може не поділяти цю думку.

Топ-5 найпопулярніших блогерів вересня

Recruiter| Talent Acquisition Specialist
Всего просмотровВсього переглядів
45
#1
Всего просмотровВсього переглядів
45
Всего просмотровВсього переглядів
37
#2
Всего просмотровВсього переглядів
37
Всего просмотровВсього переглядів
32
#3
Всего просмотровВсього переглядів
32
Всего просмотровВсього переглядів
24
#4
Всего просмотровВсього переглядів
24
Career Consultant в GoIT
Всего просмотровВсього переглядів
23
#5
Всего просмотровВсього переглядів
23
Рейтинг блогерів

Найбільш обговорювані статті

Топ текстів

Ваша жалоба отправлена модератору

Сообщить об опечатке

Текст, который будет отправлен нашим редакторам: