Разработка Dmitry Kotenko
242

Тестировщик: от самоопределения до первого бага

Находясь в поисках тестировщика, мы сталкивались с тем, что соискатели, претендующие на эту должность, зачастую не понимали, что именно должен знать и уметь этот специалист. Поэтому сегодня рассказываю, с чего начать, если вдруг вы решили вступить в ряды IT именно с этой профессии. Матёрым QA это будет неинтересно, а вот новички — welcome.

В закладки

Как определиться?

Профессию QA-специалиста (Quality Assurance) можно рассматривать как стартовый этап, можно как самодостаточную специальность. Если общих фраз и требований на hh.ru вам недостаточно для того, чтобы понять, увлечет вас тестирование или пройдет мимо — мы вас понимаем. Пообщайтесь с потенциальными коллегами, посмотрите видео на Youtube, можете сходить на митап QA-специалистов. В конце статьи для вас есть пункт, где мы рекомендуем дополнительные материалы — они будут полезны, если вам интересны теоретические основы тестирования (а без них, по факту, тяжеловато).

Собеседование. Чего ждать?

Все зависит от компании, в которую вы планируете собеседоваться. Где-то ручаются всему научить самостоятельно, но в большинстве случаев существует перечень требований к потенциальному QA: с него и начните. А пока что вот вам чек-лист основных понятий, с которых стоит начать:

  • Чем отличаются друг от друга виды тестирования
  • Какая бывает документация и как с ней работать
  • Методы тест-дизайна
  • Принципы написания тест-кейсов

В качестве тренировки попробуйте протестировать первый попавшийся под руку предмет. Из личных качеств вам пригодятся усидчивость, внимательность к деталям, придирчивость, стремление развиваться — все по канону.

Первый рабочий день

Как к начинающему, скорее всего, в курс дела вас будет вводить кто-то из числа опытных коллег, в больших компаниях этим занимается QA-lead. Покажут весь софт, объяснят, как работать с документацией, расскажут парочку кейсов, познакомят со всеми QA и разработчиками, расскажут о компании. Есть организации, в которых новеньким заботливо организовали целый портал, чтобы они познакомились с системой. Не упустите возможность спросить все, что непонятно, интересно и т.д. В Infoshell рабочий день начинается с созвонов с Product Owner’ами. Обсуждаем, что успели вчера, чем будем заняты сегодня, распределяем задачи, обсуждаем то, что непонятно. Также в течение дня всегда можем связаться в Skype или Slack.

Первые кейсы

Пришло время взяться за практику. Сейчас вы протестируете своё первое приложение. Как это проходит?
До того, как тестировать приложение, попробуйте составить чек-лист (список функций, которые нужно проверить). Потом это станет у вас постоянной практикой. Вам расскажут о приложении и выдадут документацию, в которой подробно описан функционал. Уделите время тому, чтобы продумать возможные баги и записать их. Попросите чек-лист у более опытных тестеров, чтобы дополнить свой.

Например, часть общего чек-листа для мобильного приложения:

Дальше приступаем к тестированию приложения. Как правило, оно проходит в несколько этапов:

  • Дымовое тестирование
    Или Smoke-тестирование — проверка основных функций приложения: если в приложении “Велопрокат” некорректно работает функция заказа одного из товаров — приложение не выполняет основные функции. Такие баги проверяют в первую очередь. Идея в том, чтобы на первых шагах выявить очевидно важные баги и не копаться в заведомо нерабочем приложении.
  • Регрессионное тестирование
    Проверяем две вещи:
    - во-первых, найденный баги были исправлены;
    - во-вторых, как повлияли внесенные изменения на работу остальных фич приложения.
  • Полное функциональное тестирование и тестирование пользовательских интерфейсов
    Полностью проверяем приложение на соблюдение всех требований, указанных в спецификации.

Кратко рассказали об этапах тестирования, а теперь о том, как описывать найденные баги.

Первым делом стоит разобраться с типом найденной ошибки. В основном их делят на баги, улучшения и дополнения к функционалу. Баги — нарушения в функционале; улучшения — в целом работает, но можно сделать лучше; дополнения к функционалу — возможности, которые нужно добавить к функционалу. Такая классификация помогает разработчикам расставлять приоритетность выполнения задач.

Далее приступайте к позитивному тестированию — когда вводите заведомо корректные значения, после — к негативному. При негативном тестировании проверяем, что программа не работает там, где не должна.

Итак, разберем составление тест-кейса для бага (описание найденного бага):

  • Порядковый номер
  • Название
    Оно должно быть понятным, отражающим суть, но кратким.
    Лайфхак: название можно строить по принципу чгк (что случилось? на какой странице приложения? после чего это случилось?). Например: на странице “Корзина” после нажатия кнопки “Отправить” появляется сообщение об ошибке.
  • Предварительные шаги
    Сценарий того, как вы пришли к багу. Какие действия выполнили, куда кликали, что вводили и т.д. Все подкрепляется скриншотами.
  • Ожидаемый результат

    Расписываем, что должно было произойти исходя из документации.

  • Полученный результат
    Что произошло по факту. Снова прилагаем скриншот.
  • Приоритет и серьезность
    Выставляя приоритет, говорим, насколько важно прямо сейчас решить эту задачу. Чем больше баг портит основной функционал приложения, чем ближе к его основной задаче, чем чаще используется эта функция — тем приоритетнее баг.

    О серьезности:
    S1(Блокирующая) — одна или несколько функций не работают, приводя систему в нерабочее состояние.
    S2(Критическая) — когда не работает важный функционал, затрагивающий основную бизнес-логику.
    S3(Значительная) — когда не работает не самый важный функционал, бизнес-логика не нарушена или есть возможность осуществить тестируемую функцию корректно, но через другой набор действий.
    S4(Незначительная) — дефект, не относящийся к основному функционалу, возможно, не влияющий на работу приложения: ошибка в интерфейсе, сместившееся поле, проблема сторонних сервисов.
  • Среда
    Указываем, на какой платформе тестировался сервис (браузер, модель телефона, версия Android и т.д.).

Как правило, на тестирование одной версии уходит 3-5 часов.

Часть записи тест-кейса в TFS:

Наш пример — один из самых популярных подходов к описанию багов. Он не универсален для каждой компании, но более-менее общий.

Не первый рабочий день

Немного набравшись опыта, вы сможете “умнее” подходить к тестированию приложения: не просто тыкать на кнопочки и искать то, что не работает — вы будете знать, какие баги искать в первую и последнюю очередь, где они могут быть, начнете учитывать бизнес-логику продукт, будете учиться. Опытных тестировщиков ценят за то, что они повышают качество продукта, а не ищут как можно больше багов.

Приятно, когда тестировщик старается дойти до “корня” проблемы. Пробуйте находить закономерности. Например, при поиске по названию программа при вводе названия пиццы “Пепперони” производит поиск по категории продуктов “Выпечка”. Так происходит со всеми пиццами? Что происходит при поиске выпечки? В каких случаях поиск работает верно? Так вы облегчите работу программистам.

Несколько ресурсов для тех, кому нужно больше информации

1. Для начала, можете посмотреть вот этот плейлист на Youtube. Теоретические основы рассказывают в меру подробно, но этого хватит, чтобы понять, хочется ли двигаться дальше.
2. Рекомендуем книгу Романа Савина “Тестирование dot COM”. Эта книга дает общее понятие о тестировании, рассказывает основы, дает представление о том, чем занимаются тестировщики.
3. “Тестирование программного обеспечения. Базовый курс” Святослава Куликова — полезно начинающим и продолжающим.
4. Полезная статья о том, почему тестирование — не забег на скорость по количеству найденных багов.
5. Здесь разобраны примеры тест-кейсов.
6. Хороший портал, который вам ещё не раз пригодится.

Успехов!

Материал опубликован пользователем. Нажмите кнопку «Написать», чтобы поделиться мнением или рассказать о своём проекте.

Написать
{ "author_name": "Dmitry Kotenko", "author_type": "self", "tags": [], "comments": 0, "likes": 1, "favorites": 7, "is_advertisement": false, "subsite_label": "dev", "id": 59042, "is_wide": false, "is_ugc": true, "date": "Wed, 20 Feb 2019 15:24:10 +0300" }
{ "id": 59042, "author_id": 77560, "diff_limit": 1000, "urls": {"diff":"\/comments\/59042\/get","add":"\/comments\/59042\/add","edit":"\/comments\/edit","remove":"\/admin\/comments\/remove","pin":"\/admin\/comments\/pin","get4edit":"\/comments\/get4edit","complain":"\/comments\/complain","load_more":"\/comments\/loading\/59042"}, "attach_limit": 2, "max_comment_text_length": 5000, "subsite_id": 235819 }

Комментариев нет 0 комм.

Популярные

По порядку

0
{ "page_type": "article" }

Прямой эфир

[ { "id": 1, "label": "100%×150_Branding_desktop", "provider": "adfox", "adaptive": [ "desktop" ], "adfox_method": "createAdaptive", "auto_reload": true, "adfox": { "ownerId": 228129, "params": { "pp": "g", "ps": "bugf", "p2": "ezfl" } } }, { "id": 2, "label": "1200х400", "provider": "adfox", "adaptive": [ "phone" ], "auto_reload": true, "adfox": { "ownerId": 228129, "params": { "pp": "g", "ps": "bugf", "p2": "ezfn" } } }, { "id": 3, "label": "240х200 _ТГБ_desktop", "provider": "adfox", "adaptive": [ "desktop" ], "adfox": { "ownerId": 228129, "params": { "pp": "g", "ps": "bugf", "p2": "fizc" } } }, { "id": 4, "label": "240х200_mobile", "provider": "adfox", "adaptive": [ "phone" ], "adfox": { "ownerId": 228129, "params": { "pp": "g", "ps": "bugf", "p2": "flbq" } } }, { "id": 5, "label": "300x500_desktop", "provider": "adfox", "adaptive": [ "desktop" ], "adfox": { "ownerId": 228129, "params": { "pp": "g", "ps": "bugf", "p2": "ezfk" } } }, { "id": 6, "label": "1180х250_Interpool_баннер над комментариями_Desktop", "provider": "adfox", "adaptive": [ "desktop" ], "adfox": { "ownerId": 228129, "params": { "pp": "h", "ps": "bugf", "p2": "ffyh" } } }, { "id": 7, "label": "Article Footer 100%_desktop_mobile", "provider": "adfox", "adaptive": [ "desktop", "tablet", "phone" ], "adfox": { "ownerId": 228129, "params": { "pp": "g", "ps": "bugf", "p2": "fjxb" } } }, { "id": 8, "label": "Fullscreen Desktop", "provider": "adfox", "adaptive": [ "desktop", "tablet" ], "auto_reload": true, "adfox": { "ownerId": 228129, "params": { "pp": "g", "ps": "bugf", "p2": "fjoh" } } }, { "id": 9, "label": "Fullscreen Mobile", "provider": "adfox", "adaptive": [ "phone" ], "auto_reload": true, "adfox": { "ownerId": 228129, "params": { "pp": "g", "ps": "bugf", "p2": "fjog" } } }, { "id": 10, "disable": true, "label": "Native Partner Desktop", "provider": "adfox", "adaptive": [ "desktop", "tablet" ], "adfox": { "ownerId": 228129, "params": { "pp": "g", "ps": "clmf", "p2": "fmyb" } } }, { "id": 11, "disable": true, "label": "Native Partner Mobile", "provider": "adfox", "adaptive": [ "phone" ], "adfox": { "ownerId": 228129, "params": { "pp": "g", "ps": "clmf", "p2": "fmyc" } } }, { "id": 12, "label": "Кнопка в шапке", "provider": "adfox", "adaptive": [ "desktop" ], "adfox": { "ownerId": 228129, "params": { "p1": "bscsh", "p2": "fdhx" } } }, { "id": 13, "label": "DM InPage Video PartnerCode", "provider": "adfox", "adaptive": [ "desktop", "tablet", "phone" ], "adfox_method": "createAdaptive", "adfox": { "ownerId": 228129, "params": { "pp": "h", "ps": "bugf", "p2": "flvn" } } }, { "id": 14, "label": "Yandex context video banner", "provider": "yandex", "yandex": { "block_id": "VI-223676-0", "render_to": "inpage_VI-223676-0-1104503429", "adfox_url": "//ads.adfox.ru/228129/getCode?pp=h&ps=bugf&p2=fpjw&puid1=&puid2=&puid3=&puid4=&puid8=&puid9=&puid10=&puid21=&puid22=&puid31=&puid32=&puid33=&fmt=1&dl={REFERER}&pr=" } }, { "id": 15, "label": "Плашка на главной", "provider": "adfox", "adaptive": [ "desktop", "tablet", "phone" ], "adfox": { "ownerId": 228129, "params": { "p1": "byudx", "p2": "ftjf" } } }, { "id": 16, "label": "Кнопка в шапке мобайл", "provider": "adfox", "adaptive": [ "tablet", "phone" ], "adfox": { "ownerId": 228129, "params": { "p1": "byzqf", "p2": "ftwx" } } }, { "id": 17, "label": "Stratum Desktop", "provider": "adfox", "adaptive": [ "desktop" ], "auto_reload": true, "adfox": { "ownerId": 228129, "params": { "pp": "g", "ps": "bugf", "p2": "fzvb" } } }, { "id": 18, "label": "Stratum Mobile", "provider": "adfox", "adaptive": [ "tablet", "phone" ], "auto_reload": true, "adfox": { "ownerId": 228129, "params": { "pp": "g", "ps": "bugf", "p2": "fzvc" } } }, { "id": 19, "label": "Тизер на главной", "provider": "adfox", "adaptive": [ "desktop", "tablet", "phone" ], "auto_reload": true, "adfox": { "ownerId": 228129, "params": { "p1": "cbltd", "p2": "gazs" } } } ]
Команда калифорнийского проекта
оказалась нейронной сетью
Подписаться на push-уведомления
{ "page_type": "default" }