Гид по ручному тестированию приложений: преимущества, этапы и методологии
Время на прочтение
12 мин
Количество просмотров 86K
Детально разбираем то, как проводить ручное тестирование, когда оно лучше автоматизированного, что нужно уметь тестировщику и как он может построить свою карьеру от джуниора до тест- лида. Гид подготовлен совместно с руководителем отдела тестирования компании Agima Дариной Гордеевой.
Привет! Меня зовут Дарина Гордеева. Работаю в компании AGIMA руководителем отдела почти 3 года. В области тестирования и обеспечения качества более 6 лет. За это время прошла путь от джуниора до руководителя отдела, занимаясь тестированием железа, а также мобильных и веб-приложений, автоматизацией и настройкой процессов QA. Сегодня я расскажу вам про особенности, возможности и скрытые проблемы ручного тестирования.
Напомним, что любой читатель, воспользовавшийся промословом “Хабр” может получить скидку в 10 000 рублей на понравившийся курс, а самые усидчивые и внимательные могут собрать себе скидку в 25 000 рублей, разгадывая ребусы из материалов, подготовленных совместно с агентством Agima:
- Как с первого раза попасть в AppStore: пошаговое руководство;
- 8 этапов процесса разработки интерфейса мобильного приложения;
- А/В-тесты не работают. Проверьте, что вы делаете не так.
Оперативность, гибкость, возможность импровизации и другие плюсы
Сегодня есть множество фреймворков для тестирования, поддерживающих практически все существующие языки. Казалось бы — можно брать и автоматизировать. Но даже сейчас ручные тесты важны.
Одно из объяснений их необходимости заключается в том в том, что при ручном тестировании функционала мы можем гораздо быстрее получить информацию о состоянии продукта, который анализируем, о качестве разработки. Кроме того, при автоматизации предварительно разработанные кейсы часто приходится менять и актуализировать, а на написание автотестов требуется определённое время.
При этом в процессе разработки может прийти обратная связь от заказчика, когда он увидит в готовом продукте какую-то функцию, которую решит изменить до релиза — и, если вы уже подготовили для неё программные тесты, их придётся переписать. Обновление кейсов, автотестов и их проверка отнимут ценное время, которое можно было бы использовать на само обновление этой фичи.
Всё это означает, что главная цель ручных тестов — предварительно убедиться в том, что заявленный функционал работоспособен, не имеет ошибок и выдаёт ожидаемые, запланированные результаты. Без них нельзя быть уверенным в том, что можно работать дальше. Особенно это актуально для функций, на реализацию которых завязана последующая разработка. В таком случае возня с созданием автотестов на эти фичи становится блокирующим фактором для всей разработки продукта, сдвигая сроки и срывая дедлайны. Момент, когда кейсы придёт пора автоматизировать, всё равно рано или поздно наступит — но не стоит стремиться приблизить его искусственно в погоне за тотальным исключением ручного труда.
В дополнение к этому, на первых этапах разработки приложения автоматизация может оказаться довольно дорогой. Вам потребуется специалист, обладающий специфической квалификацией (и, возможно, не один). Постоянное поддержание тестов в актуальном состоянии требует затрат ресурсов вплоть до релиза фичи. А месяцы простоя, посвященные вылизыванию автотеста ударят по мотивации команды.
Если вы хотите регулярно добавлять новый функционал и успевать за действиями конкурентов, то перед тем, как создавать автотесты всегда проверяйте возможности продукта вручную. Просто потому что ручное тестирование ускоряет ваши процессы.
Это особенно актуально для мобильной разработки. Большинство таких проектов сегодня разрабатывается короткими спринтами, а значит фичи в них внедряются в ускоренном темпе. В подобных условиях ручное тестирование позволяет максимально оперативно давать команде обратную связь: сообщать о наличии багов — или радовать её тем, что всё окей и можно двигаться дальше. Провести серию автотестов вы сможете позже, покрыв с их помощью большие массивы кода. Ручное тестирование поможет подготовить кейсы для этой проверки.
Автотесты не позволяют проверить удобно ли использовать новые возможности приложения — проверка юзабилити всегда осуществляется вручную.
Skillbox рекомендует: онлайн-курс Fullstack-мобильный разработчик.
В ручных тестах можно импровизировать, создавая безумные сочетания действий, которые никогда не придут в голову пользователю, но могут быть совершены им случайно. Это позволяет создавать новые кейсы.
Новые кейсы появляются еще и потому, что тестировщик постоянно задает себе вопрос «а что, если?». Так он находит оригинальные способы взаимодействия с приложением — даже если их не было в базовых сценариях.
Проблемы ручного тестирования и их решения
Самый большой из недостатков ручного тестирования — человеческий фактор. Он, конечно, влияет на всё, происходящее в команде — и на работу участников, и на события, происходящие на стороне клиента. В случае QA причиной того, что тестировщик будет слабо погружен в процесс и пропустит потенциальную ошибку может стать всё что угодно — недостаток опыта, семейные проблемы или головная боль.
Один и тот же сценарий два тестировщика могут проверить разными способами. Что с этим делать? Важно, чтобы каждый непредусмотренный или отличающийся от ожидаемого результат был зафиксирован в виде кейса. Чтобы любой тестировщик мог проверить его, совершив тот же набор действий. Но и этого может быть мало — если кейс окажется недостаточно подробным, а тестировщик — не разберётся в описании. Гарантировать стопроцентное исключение человеческого фактора, конечно, невозможно — но можно постараться максимально снизить вероятность проблем, которые он вызывает.
Это тоже негативно сказывается на сроках поставки фичи в продакшн и трудозатратах: ведь теперь к периодически проводимым базовым кейсам и регрессии добавляются и “хитрые” кейсы, придуманные тестировщиками в процессе.
Усугубляет ситуацию вероятность того, что часть встреченных багов ещё не будет иметь строгого описания потому что причины их возникновения пока не понятны. Как бороться с такими повторными тестированиями? Либо найти уже источник ошибки и устранить его, либо — всё таки автоматизировать прохождение проблемных кейсов — в этом случае переход к программным тестам будет вполне оправдан как с точки зрения времени, так и финансово. (Нет, это не противоречит вышесказанному — потому что такие ситуации возникают уже в ходе активной разработки и к этому времени вы уже в любом случае развернёте процессы автотестирования).
В любом случае — появление первых кейсов, нуждающихся в регрессивных тестах или релиз второй версии приложения и соответствующее этим событиям масштабирование команды — тот момент, когда автоматизация станет актуальна (но не исключит ручное тестирование новых возможностей). На этом этапе автоматизация уже начнёт экономить время: разработчик сможет сам, ещё до передачи QA-отделу запустить регресс-тесты новой фичи, чтобы убедиться, что она не ломает существующий функционал, а тестировщику не придётся лишний раз проходить по набившим оскомину базовым кейсам. Ещё одно преимущество внедрения автотестов на этом этапе — их можно запускать по определённому расписанию — каждую ночь, в дни окончания спринтов или при публикации новых сборок приложения.
При этом нельзя забывать несколько вещей:
- создание кейсов и написание автотестов будет требовать времени — закладывайте его в спринты;
- убедитесь, что кейс автотеста прописан хорошо и подробно и описывает возможную проблему или существующий сценарий во всей полноте;
- проверьте, правильно ли работает автотест и действительно ли он проверяет то, что нужно и делает это качественно.
Резюмируем: ручное тестирование даёт большое преимущество по скорости и трудозатратам на первых этапах, а по мере разрастания приложения и появления большого количества регрессивных тестов оно переходит в разряд “оперативного тестирования” новых фич в рамках отдельного спринта. Оно будет актуально и при необходимости срочно проверить как приложение отреагирует на изменение операционной системы или обновление окружения.
Этапы тестирования: что, когда и как
Если смотреть на процесс разработки в целом и на тестирование как на одну из его частей, то при грамотном планировании вы всегда будете понимать что и когда будет готово. Это позволит лучше планировать время тех или иных действий — поскольку одни события логично следуют за другими и у вас есть возможность выстраивать их в цепочки на основании своих ожиданий.
Тестировщик появляется в процессе создания приложения уже на ранних этапах. Вот у клиента появляется некая идея, бизнес-аналитики собирают из этого требования — а тестировщики уже в этот момент приступают к работе, проверяя эти требования.
Как это происходит? Они задают вопросы по предполагаемому функционалу. Пытаются представить, как будет выглядеть приложение, когда оно будет реализовано. Если речь идёт о новой фиче в уже существующем продукте — разбираются, как она будет взаимодействовать с существующим функционалом. После того, как разработчики провели оценку трудозатратности идей клиента и определили сколько потребуется времени на их реализацию.
После этого начинается этап проектирования. Здесь появляется необходимость понять, как будут осуществляться переходы между экранами, валидироваться те или иные поля, как приложение или его отдельная функция вообще будет взаимодействовать с конечным пользователем. В случае с фичами важно разобраться и с тем, как они будут входить в архитектуру существующего приложения.
На этапе дизайна, когда создаётся карта переходов между экранами, тестировщик уточняет поведение отдельных элементов из которых они состоят и то, какими визуальными эффектами будут сопровождаться те или иные действия пользователя. Кроме этого тестировщик валидирует макеты на полноту, подтверждая, что они отображают всё, что нужно для реализации задуманного функционала. Нелишней будет и самостоятельная проверка макетов на соответствие гайдлайнам.
Skillbox рекомендует: онлайн-курс Дизайн мобильных приложений
С началом разработки QA-специалисты сразу же приступают к написанию тест-кейсов. На разных этапах разработки они могут обладать различным уровнем детализации, но к её окончанию желательно обеспечить максимальное покрытие кейсами всего продукта, чтобы, получив сборку, можно было приступить к тестированию немедленно.
Первый шаг непосредственно тестирования — смоук-тест: оценка на то, что приложение или его новая часть вообще готовы к проверке. Смоук-тест — это проверка того, запускается ли приложение или конкретная функция в принципе.
Смоук-тест — быстрый способ убедиться, можем ли мы вообще начать функционально тестирование. Термин пришел от создателей плат и микросхем, которые для начала должны были убедиться не сгорит ли новая схема — отсюда и название: задымилась/не задымилась.
Это быстрый способ убедиться в том, что нам действительно сдали задачу и её можно принимать в работу, а не отправлять обратно программистам.
На примере формы авторизации смоук — это оценка того, можно ли залогиниться вообще, без уточнения того, валидны ли данные, вводимые в поля, работают ли дополнительные возможности вроде напоминания пароля и прочего. Если мы смогли авторизоваться в принципе — можно переходить к дальнейшей, углублённой проверке этого модуля: брать негативные кейсы, пограничные значения, оценивать соответствие установленным правилам валидации.
Следующий этап — проведение регресс-тестов. В ручном или автоматическом режиме проводится основной заранее запланированный массив тестов.
Регрессионное тестирование хорошо тем, что оно позволяет найти ошибки даже в тех местах, где раньше всё было в порядке. Это происходит благодаря тому что регресс — это оценка функционала на стандартный набор кейсов при внедрении каждого нового модуля и каждого изменения приложения. Ведь, когда разработчики добавляют новый функционал может быть повреждена текущая версия или новая фича может вступать в конфликт с уже существующими.
Например, добавление новых экранов, а значит и изменение навигации может нарушить функционирование меню или, как минимум — его отображение. С другой стороны неприятные сюрпризы может принести и глобальный рефакторинг кода приложения — после него тоже необходимо проводить регресс-тесты.
Проблемы могут вызвать и обновление используемой приложением библиотеки и изменение среды в которой оно работает. Чем чаще вы обновляете приложение — тем более важную роль играют регрессионные проверки. Не стоит ограничиваться однократной проверкой, проводимой, когда фича уже внедрена — проверяйте все изменения. Здесь вам поможет автоматизация регрессионного тестирования — просто потому что ручное регрессионное тестирование новой фичи, создававшейся всего неделю может занять две, а то и больше и отдел тестирования просто завязнет в этом.
Полная проверка, конечно, осуществляется когда release candidate с одной или несколькими фичами готов выкатываться в продакшн, но применять те или иные соответствующие кейсы на отдельных этапах разработки всё таки необходимо.
Завершается всё тестированием финальной сборки — release candidate. В него входят проверка бета-версии внутренними тестировщиками, бизнес-тестирование — оценка получившегося продукта самим клиентом и получение от него обратной связи, а также предложение определённой группе пользователей познакомиться с предрелизной альфа-версией приложения или его новых возможностей. После этого приложение готово к тому, чтобы его выкатили в продакшн.
Но на этом работа QA-специалиста не заканчивается — ему предстоит тестировать обновления приложения и их совместимость с более ранними версиями, составлять кейсы для проверки нововведений и, в случае необходимости, автоматизировать прохождение этих сценариев.
Параллельно с этим тестировщики участвуют в дальнейшем анализе статистики, собираемой аналитиками, мониторинге поведения приложения и того, как взаимодействуют с ним пользователи. Это позволяет не только увидеть живое использование результатов их работы, но и, порой, открыть для себя новые сценарии и неизвестные баги, вызывающие падения приложения.
Время ребуса: отгадайте его и десятипроцентная скидка на любой из курсов Skillbox ждёт вас прямо сейчас или проявите усидчивость и соберите ответы на все ребусы — эти скидки суммируются между собой (но ни с какими другими скидками на курсы Skillbox).
Однако, слишком медлить не стоит — промо работает до 30 августа 2018 года. Напомним, что тематика загадки — мобайл, а английские слова могут мешаться здесь с русскими, так что будьте внимательны! Отправьте заявку на курс, и когда с вами свяжется менеджер — назовите ему промослово, зашифрованное в ребусе (или — несколько!).
Формализация тестирования: тест-план, формат баг-репортов, отчётность
Для того, чтобы подготовиться к функциональному тестированию QA-инженер составляет тест-план. Это — документация, которая потребуется ему при тестировании продукта, список действий, которые ему нужно будет совершить. В тест-плане обозначаются сроки тестирования, описываются продукт или конкретная задача — для того, чтобы точно определить, что именно надо проверять. Детально описываются все основные тест-кейсы. Перечисляются виды тестирования, которые необходимы: функциональное и, например, нагрузочное. Описывается порядок автоматизации тех или иных кейсов и то, на каких этапах они будут автоматизированы.
Завершается тест-план описанием формата отчёта: нужно заранее объяснить, в каком виде будет предоставлен результат. Наиболее распространённым форматом отчёта является список тест кейсов со статусом их прохождения. Зная, насколько кейсы покрывают весь объём требований и прочитав отчёт, можно будет сделать вывод о текущем состоянии разработки приложения. Для этого достаточно будет посмотреть, сколько из них было успешно пройдено в той или иной сборке.
Финальной отмашкой, свидетельствующей о том, что продукт готов является статус “все требования покрыты кейсами, все кейсы пройдены успешно”.
Кроме того, в тест-плане формализуется формат отчёта по ошибкам. Это может быть баг-лист, список задач в трекере.
Задача тестировщика — предоставить наиболее полную информацию о качестве продукта всем участникам команды.
Что нужно знать и уметь, чтобы стать тестировщиком
В первую очередь тестировщик должен уметь думать и быть внимательным и усидчивым. Важен опыт — он позволяет накопить определённые наработки и закрепить знания процессов тестирования, превратив их в навыки.
Специалист по ручным тестам не обязательно должен уметь писать код и глубоко разбираться в архитектуре. Это никак не помешает ему проверять функционал и на прикладном уровне понимать принципы взаимодействия приложения и сервера.
Специалист по автоматизированному тестированию — это отдельная профессия, с абсолютно другим набором знаний. Качественное автотестирование — это не просто скрипты, но и понимание того, как приложение устроено изнутри, и специфические умения, вроде знания о том, как параллелить тесты или о том, как запускать их в облаке или на нескольких серверах. Только такой пул навыков позволяет с гордостью называть себя “автоматизатором с большой буквы”. Так что без знания языков, их фреймворков, принципов ООП и внимательной слежкой за развитием технологий настоящему автотестеру не обойтись.
Путь каждого тестировщика начинается с освоения теоретического базиса тестирования, получения первичных представлений о том, как приложение взаимодействует с сервером и со средой. Если эти знания есть, а вместе с ними человек обладает и очень серьёзным намерением учиться — он уже может считаться джуниор-тестировщиком. За группой таких новичков с горящими глазами закрепляется старший специалист — либо ведущий тестировщик, либо, если компания может себе это позволить — тренер, целенаправленно прокачивающий своих подопечных. Они объясняют джуниорам непонятные моменты и дают болевые задачи вроде прогонки фич по тест-кейсам. В процессе человек учится читать тест-кейсы и осваивает практические основы функционального тестирования. На этом этапе за джуниорами ещё нужно проверять качество проведённых ими тестов, проходя их вслед за ними.
Следующим шагом становится создание индивидуального (или коллективного, в зависимости от масштабов компании) плана по развитию, согласно которому начинающий тестировщик должен будет развиваться, осваивая новые знания и достигая определённых результатов за отведённые ему на это сроки. Именно это — путь к тому, чтобы стать специалистом миддл-уровня.
Миддл-тестировщик — это человек, который уже способен самостоятельно выполнять поставленные перед ним задачи, находить решения и вообще выполнять свою работу сознательно, а не слепо следуя установленным алгоритмам.
С развитием навыков тест-дизайна, познаний в функциональной и прикладной областях, а также освоении новых методик тестирования — которые теперь уже нужно развивать самостоятельно — происходит постепенная трансформация в ведущего специалиста. Теперь ему могут поручить ведение и поддержку таких же джуниоров, каким он сам раньше был.
Следующий уровень — это тест-лид. Он уже может управлять командой, в которую входят представители всех трёх предыдущих категорий, процессами которых он управляет и временем которых — распоряжается, в том числе участвуя в планировании глобальных процессов разработки, оценке трудозатрат и формировании бюджетов для своих команд.
Дальнейший вертикальный рост тим-лида — руководство отделом или переход в продук-менеджмент. Если же, человек стремится к новым знаниям, а не к новым административным позициям, то он может выбрать разработку, аналитику или такое направление, как DevOps, объединяющее в себе обязанности системного администратора, тестировщика и программиста.
Тестирование — лишь одна из многих областей мобильной разработки, которые мы рассматриваем в рамках курса “Fullstack-мобильный разработчик”. Сотрудничающие с нами профессионалы индустрии будут делиться с вами своим опытом и проверять ваши домашние задания, а итогом обучения может стать принятие на стажировку в крупную компанию. Приходите к нам учиться!
Skillbox рекомендует:
- Управление digital-проектами;
- Анимация интерфейсов;
- UX- дизайн.
From Wikipedia, the free encyclopedia
- Compare with Test automation.
Manual testing is the process of manually testing software for defects. It requires a tester to play the role of an end user where by they use most of the application’s features to ensure correct behaviour. To guarantee completeness of testing, the tester often follows a written test plan that leads them through a set of important test cases.
Overview[edit]
A key step in the process is testing the software for correct behavior prior to release to end users.
For small scale engineering efforts (including prototypes), ad hoc testing may be sufficient. With this informal approach, the tester does not follow any rigorous testing procedure and simply performs testing without planning or documentation. Conversely, exploratory testing, which involves simultaneous learning, test design and test execution, explores the user interface of the application using as many of its features as possible, using information gained in prior tests to intuitively derive additional tests. The success of exploratory manual testing relies heavily on the domain expertise of the tester, because a lack of knowledge will lead to incompleteness in testing. One of the key advantages of an informal approach is to gain an intuitive insight to how it feels to use the application.
Large scale engineering projects that rely on manual software testing follow a more rigorous methodology in order to maximize the number of defects that can be found. A systematic approach focuses on predetermined test cases and generally involves the following steps.[1]
- Choose a high level test plan where a general methodology is chosen, and resources such as people, computers, and software licenses are identified and acquired.
- Write detailed test cases, identifying clear and concise steps to be taken by the tester, with expected outcomes.
- Assign the test cases to testers, who manually follow the steps and record the results.
- Author a test report, detailing the findings of the testers. The report is used by managers to determine whether the software can be released, and if not, it is used by engineers to identify and correct the problems.
A rigorous test case based approach is often traditional for large software engineering projects that follow a Waterfall model.[2] However, at least one recent study did not show a dramatic difference in defect detection efficiency between exploratory testing and test case based testing.[3]
Testing can be through black-, white- or grey-box testing. In white-box testing the tester is concerned with the execution of the statements through the source code. In black-box testing the software is run to check for the defects and is less concerned with how the processing of the input is done. Black-box testers do not have access to the source code. Grey-box testing is concerned with running the software while having an understanding of the source code and algorithms.[4]
Static and dynamic testing approach may also be used. Dynamic testing involves running the software. Static testing includes verifying requirements, syntax of code and any other activities that do not include actually running the code of the program.
Testing can be further divided into functional and non-functional testing. In functional testing the tester would check the calculations, any link on the page, or any other field which on given input, output may be expected. Non-functional testing includes testing performance, compatibility and fitness of the system under test, its security and usability among other things.
Stages[edit]
There are several stages. They are:
- Unit testing
- This initial stage in testing normally carried out by the developer who wrote the code and sometimes by a peer using the white box testing technique.
- Integration testing
- This stage is carried out in two modes, as a complete package or as an increment to the earlier package. Most of the time black box testing technique is used. However, sometimes a combination of Black and White box testing is also used in this stage.
- System testing
- In this stage the software is tested from all possible dimensions for all intended purposes and platforms. In this stage Black box testing technique is normally used.
- User acceptance testing
- This testing stage carried out in order to get customer sign-off of finished product. A ‘pass’ in this stage also ensures that the customer has accepted the software and is ready for their use.
- Release or deployment testing
- Onsite team will go to customer site to install the system in customer configured environment and will check for the following points:
- Whether SetUp.exe is running or not.
- There are easy screens during installation
- How much space is occupied by system on HDD
- Is the system completely uninstalled when opted to uninstall from the system.
Advantages[edit]
- Low-cost operation as no software tools are used
- Most bugs are caught by manual testing
- Humans observe and judge better than the automated tools
Comparison to automated testing[edit]
Test automation may be able to reduce or eliminate the cost of actual testing.[5] A computer can follow a rote sequence of steps more quickly than a person, and it can run the tests overnight to present the results in the morning. However, the labor that is saved in actual testing must be spent instead authoring the test program. Depending on the type of application to be tested, and the automation tools that are chosen, this may require more labor than a manual approach. In addition, some testing tools present a very large amount of data, potentially creating a time consuming task of interpreting the results.
Things such as device drivers and software libraries must be tested using test programs. In addition, testing of large numbers of users (performance testing and load testing) is typically simulated in software rather than performed in practice.
Conversely, graphical user interfaces whose layout changes frequently are very difficult to test automatically. There are test frameworks that can be used for regression testing of user interfaces. They rely on recording of sequences of keystrokes and mouse gestures, then playing them back and observing that the user interface responds in the same way every time. Unfortunately, these recordings may not work properly when a button is moved or relabeled in a subsequent release. An automatic regression test may also be fooled if the program output varies significantly.
See also[edit]
- Test method
- Usability testing
- GUI testing
- Software testing
- Codeless test automation
References[edit]
- ^ ANSI/IEEE 829-1983 IEEE Standard for Software Test Documentation
- ^ Craig, Rick David; Stefan P. Jaskiel (2002). Systematic Software Testing. Artech House. p. 7. ISBN 1-58053-508-9.
- ^ Itkonen, Juha; Mika V. Mäntylä; Casper Lassenius (2007). «Defect Detection Efficiency: Test Case Based vs. Exploratory Testing» (PDF). First International Symposium on Empirical Software Engineering and Measurement (ESEM 2007). pp. 61–70. doi:10.1109/ESEM.2007.56. ISBN 978-0-7695-2886-1. S2CID 5178731. Archived from the original (PDF) on October 13, 2016. Retrieved January 17, 2009.
- ^ Hamilton, Thomas (May 23, 2020). «What is Grey Box Testing? Techniques, Example». www.guru99.com. Retrieved August 7, 2022.
- ^ Atlassian. «Test Automation». Atlassian. Retrieved August 7, 2022.
Создание качественного программного обеспечения – трудная задача. Для ее реализации потребуется не только разработчик, но и другие специалисты. Пример – QA-инженеры. Именно об этом – наша статья. В конце вы поймете, стоит ли интересоваться соответствующим направлением, а также как добиться в нем успехов.
Тестировщик – это кто
Тестировщик программного обеспечения – специалист в сфере IT. Человек, который занимается планированием и выполнением процесса под названием «тестирование». Это проверка написанной утилиты.
Тестировщик:
- проверяет работоспособность контента;
- занимается отладкой программного кода;
- отвечает за улучшение юзабилити.
Это не developer, хотя разработчик может стать тестером.
Иногда к «тестер» добавляют английские буквы Q и A. Это quality assurance. Расшифровывается как «контроль качества».
Так принято называть область разработки, которая осуществляет управление качеством программного обеспечения. QA – объемное понятие, которое реализовывается еще до того, как код начал писаться девелоперами. QA инженеры должны работать над проектом до генерации возможных идей. Если не получается – во время непосредственного изучения рынка и потребностей ЦА.
Ответвление QC
Рассматриваемые сотрудники в широком смысле занимаются еще одним важным делом – QC или quality control. Переводится как «контроль качестве». Такие тестировщики должны контролировать проект во время его разработки и поддержки. Тестирование ПО помогает выяснять, насколько утилита совершенна. Тестировщик будет проверять софт во время организации мероприятий по контролю качества (QC), включенные в комплекс обеспечения качества (QA).
Спектр обязанностей
QA инженеры должны выполнять немало должностных обязанностей. На практике они занимаются такими делами как:
- детализация требований заказчика;
- анализ и расчет времени, необходимого для создания и корректировки контента;
- разработка возможных сценариев тестирования;
- непосредственная организация самого тестирования;
- внесение недочетов в систему трекинга (отслеживания);
- вовлечение всей команды разработчиков для обсуждения возможных путей разрешения ошибки;
- вторичное тестирование обнаруженных багов;
- анализирование полученных в ходе описанных ранее действий результатов;
- обсуждение командной разработки;
- оптимизация процессов разработки программного обеспечения во избежание появления повторных неполадок.
На этапе разработки приложения привлечение QA инженеров (тестировщиков) для работы дает компании огромное преимущество. Он поможет оптимизировать весь процесс, чтобы в конечном итоге выпустить на рынок действительно качественный продукт. Приложение не придется переписывать по несколько раз.
Преимущества и недостатки
Перед тем, как пройти специализированное обучение и выбрать рассматриваемое направление для карьеры, стоит узнать о сильных и слабых ее сторонах. Это поможет избежать ошибок, ведь тестирование софта не всегда простое занятие. А когда речь заходит о контроле за качеством программы – и подавно.
В чем плюсы
QA инженеры – востребованная на современном рынке труда кадры. Профессия, которая будет пользоваться спросом ближайшие десятилетия. У такого тестировщика есть ряд преимуществ:
- на первых порах здесь легко освоиться;
- решать проблемы можно не только логическим путем, но и творческим;
- развитие в выбранной сфере IT бесконечно – всегда есть, куда стремиться;
- предстоит много работать с людьми – tester много коммуницирует с программистами и другими членами команды;
- перспективы понимания бизнес-процессов.
Рядовому пользователю можно продвинуться в выбранной сфере по карьерной лестнице, но придется постараться. Особенно если раньше опыта в тестировании чего-либо не было.
О недостатках
Среди основных недостатков профессии можно выделить такие моменты:
- предстоит выполнять много монотонной работы – тестирование контента не всегда «веселый» процесс;
- в списке ключевых требований к тестировщику – знание английского языка;
- уровень ответственности высок – если аналитик ошибется, это может привести к краху всего проекта;
- сидячий образ работы.
А еще для того, чтобы добиться больших результатов в карьере, предстоит долго практиковаться. Развитие здесь медленное, а уметь нужно многое. Чем больше у тестировщика навыков, тем лучше. Некоторые разработчики со временем могут самостоятельно проводить тестирование ПО.
Краткий гайд по навыкам
QA инженеры должны много чего уметь. Главное определиться с направлением, в котором проходит тестирование. Для каждого варианта тестер должен обладать определенными навыками:
- Функциональное тестирование. Так называют проверку отдельных настроек и возможностей системы. В рамках компетенции тестировщику приходится учить функциональные требования к ПО, а также хорошо владеть спецификациями и стандартами качества.
- Нагрузочное тестирование – testing предназначается для того, чтобы проверить работоспособность программного обеспечения при высокой нагрузке. Позволяет посмотреть, как утилита ведет себя после ошибок и сбоев. QA инженеры должны справляться с определением скоростей выполнения команд, количеством юзеров на платформе, возможности функционирования утилиты при высокой нагрузке.
- Автоматизированное тестирование. Здесь тест отрабатывает самостоятельно. Среди всех остальных видов проверки является одним из самых быстрых. Тестировщики определяют инструментарий и сферы ПО для проверки подобным образом.
- Юзабилити – analyst удобства интерфейса контента. Тестировщик тут должен разбираться в бизнес-процессах, маркетинге, особенностях интерфейсов. Желательно знать ЦА и ее потребности. Здесь для тестирования начинают привлекать «обычных пользователей».
- Конфигурационный тестинг – проверка того, как софт функционирует в разных операционных системах.
- Тестирование безопасности – процесс проверки защищенности проекта от угроз и взлома. Здесь необходимо умение обнаружения уязвимых частей софта. Также QA Engineer должен знать, как их исправлять.
- Игровой тестинг – проверка игр на наличие ошибок. Предстоит тестировать развлекательный контент. Технические навыки здесь не слишком важны – достаточно проходить игры на разных устройствах в различных версиях.
QA Engineer – специалист в сфере тестирований ПО во всех возможных направлениях. После проводимых проверок ему предстоит разработать концепцию внесения корректировок. Все это направлено на то, чтобы создавать софт, который будет максимально удовлетворять пользователей.
Личностные качества
Для того, чтобы быть хорошим тестировщиком, требуется определенный спектр личностных качеств. Они помогут продвигаться по карьерной лестнице.
Для QA Engineer важны следующие качества:
- усидчивость;
- умение общаться с людьми – если аналитик нашел общий язык с командой и заказчиком, удастся быстро добиться достойных результатов;
- повышенная устойчивость к стрессу;
- навыки выполнения монотонной работы на протяжении долгого времени;
- целеустремленность;
- конструктивное восприятие критики и провалов;
- ответственность;
- терпеливость;
- креативное мышление;
- хорошо развитая логика;
- критическое мышление;
- трудолюбие.
Данные качества в тестировании помогут достаточно быстро продвигаться по карьерной лестнице. Но их отсутствие не значит, что не стоит пробовать себя в выбранном направлении.
Знания
В QA тестировании analyst должен обладать определенными знаниями. Без них никакие личностные качества не помогут:
- управление базами данных;
- знание языка программирование;
- умение составлять SQL-запросы;
- понимание бизнес-процессов;
- умения в области менеджмента и маркетинга;
- грамотное составление тестовой документации – навык четко формулировать мысли;
- понимание точных наук – информатики, математики, физики;
- познания в сфере психологии.
Хороший тестировщик также разбирается в специфике программного обеспечения, с которым он будет работать. В его компетенции находится важный момент – улучшение и оптимизация проекта. Поэтому лучше, когда analyst уже имел дело с похожими разработками.
Зарплата
При QA тестировании людей нередко интересует такой вопрос, как зарплата. Данный мануал поможет окончательно понять, насколько востребована изучаемая профессия.
В России новые сотрудники получают около 40-80 тысяч рублей. Многое зависит от опыта работы и профессионализма кадра. В Москве продвинутый QA инженер (тестировщик) может в месяц зарабатывать порядка 400-450 тысяч рублей.
В Америке соответствующая вакансия оценивается лучше. По данным 2021 года средний заработок (месячный) такого специалиста составляет 12 тысяч долларов (примерно 700 000 рублей).
Образование
В компетенции тестировщика находятся достаточно важные моменты, от которых обычно зависит успех продукта. Поэтому соответствующему кадру требуется образование. Оно может быть получено разными способами. Выбрать предлагается оптимальный для себя вариант:
- ВУЗ. Тестировщик может выучиться в университете. Это долгий и дорогой подход. Отнимает 5-8 лет. В результате у выпускника будет опыт работы, а также диплом государственного образца. В России на тестировщика не учат, только на разработчиков. Тоже неплохой вариант для старта.
- Техникумы. Отличное решение для тех, кто планирует в будущем поступление в ВУЗ. Можно отдать предпочтение не QA тестированию (данного направления нет), а программированию или информатике. Результат – диплом о среднем профессиональном образовании, который поможет поступить на 2-3 курс ВУЗа.
- Самообразование. Никаких документов, указывающих на наличие знаний и навыков в тестировании не будет. Зато человек полностью контролирует образовательный процесс. Можно сконцентрироваться лишь на том, что действительно интересует.
А еще для того, чтобы стать тестировщиком, можно пройти онлайн курсы. Это – лучшее решение для современных взрослых людей. Позволяет совмещать обучение с работой и практикой. По выпуску выдается сертификат электронного вида. Ученикам гарантируется обратная связь с опытными кураторами, которые попробовали себя в роли тестировщиков. Направление Manual подойдет и новичкам, и опытным разработчикам.
Почему стоит выбирать курсы
Преимущества подобного обучения:
- доступные цены;
- период учебы – от нескольких месяцев до года;
- возможность собрать портфолио;
- практика;
- кураторство опытными сотрудниками;
- круглосуточная поддержка;
- возможность учиться по индивидуальному графику;
- для работы с курсами достаточно иметь выход в интернет.
Курсы – отличное решение для всех возрастов. При желании можно сконцентрироваться на одном или сразу нескольких направлениях. Это – отличный способ попробовать себя в самых разных сферах IT без серьезных временных затрат.
Важно: данный вариант способен вызвать некие затруднения у людей с плохим самоконтролем.
P. S. Большой выбор курсов по тестированию есть и в Otus. Среди них широко представлено и направление автоматизации. Есть варианты как для продвинутых, так и для начинающих пользователей.
Рассказываем, чем занимается мануальный тестировщик и могут ли его заменить автотесты
Чтобы создавать качественные программы и зарабатывать на них, бизнесу нужны не только разработчики, но и тестировщики. Это хорошая профессия для старта в IT, потому что она востребована на рынке и ей можно относительно быстро обучиться с нуля. Для QA-инженера обучение не заканчивается после курсов. Чтобы получить хорошую работу и расти в профессии, нужно постоянно изучать новые технологии на практике и быть готовым учиться программировать.
Рассказываем о том, что ждет тестировщика на работе, какие основные этапы, методы и виды тестирования нужно понимать, а также стоит ли бояться автотестов.
Чем занимается мануальный тестировщик?
Ручное тестирование — это процесс поиска ошибок в программе без использования специальных ПО, силами человека. Тестировщик имитирует реальные действия пользователя и старается охватить максимум функций продукта и найти ошибки (на языке QA — «баги»). Специалист по QA ищет недоработки в визуале, функционале, логике ПО, проверяет его надежность и удобство. Все найденные ошибки QA фиксирует в баг-репорте — отчете о тестировании, по которому разработчики будут исправлять недочеты.
Из каких шагов состоит ручное тестирование?
- Читаем документацию и работаем с требованиями. Тестировщики узнают, как должно работать ПО, чего от него ждут разработчики и бизнес. На этом этапе QA-инженер может добавить требования, если они неполные, и сократить, если они невыполнимы.
- Планируем тестирование. Определяем объем работы, бюджет, выбираем методы, типы и инструменты.
- Разрабатываем тестовые сценарии. Специалисты создают тест-кейсы — алгоритм проверки ПО, а также чек-листы и готовят среду для выполнения тестов.
- Проводим первое тестирование. Команда выполняет тесты и сообщает разработчикам об ошибках.
- Делаем повторное тестирование. Когда программисты исправили ошибки, тестирование повторяют, чтобы проверить, что после изменений все работает.
- Готовим отчет о результатах. В итоговом документе описывают все тесты, выполненные во время разработки программы.
Какие есть виды ручного тестирования?
Модульное тестирование (Unit-тесты) предполагает проверку отдельных компонентов ПО или частей кода. Это эффективный способ тестирования, если готовое приложение обновляют или дополняют функционалом. Если добавить новые модули, ошибки в них могут повлиять на работу других, уже налаженных и протестированных частей программы. Вместо того чтобы ломать сервис таким образом, можно сначала протестировать модуль отдельно, а потом добавить его в систему.
Интеграционное тестирование (Integration Testing) проверяет, как отдельные части приложения работают вместе. Часто бывает, что страницу авторизации и личный кабинет приложения программируют разные специалисты. Их инструменты и подходы могут отличаться, из-за этого конечный сервис может работать с ошибками. На этом этапе уже не нужно проверять отдельные элементы, например страницу авторизации, — вы уже сделали это unit-тестом. Здесь важно запустить разные элементы в группе и проверить, что они работают корректно. Например, что авторизация запускает процесс создания личного кабинета и все данные пользователя в нем отражаются правильно.
Системное тестирование (System Testing) нужно, чтобы понять, соответствует ли ПО исходным техническим требованиям. Это этап, когда модульные и интеграционные тесты уже прошли. Теперь время смотреть на готовый продукт, кликать по кнопкам, проверять, что все работает как задумано, сервисом удобно и приятно пользоваться.
Приемочное тестирование (Acceptance Testing) проверяет, подходит ли приложение под требования бизнеса. На этом этапе тестировщики исследуют поведение пользователей и производительность системы.
Что такое черный, белый и серый ящики?
Так называются методы тестирования. Они отражают то, сколько знает тестировщик о продукте на старте работы. Разберем каждый подход подробнее.
Тестирование «черного ящика» (Black Box Testing) — метод, в котором тестировщик ничего не знает о коде или структуре продукта. QA работает с программой как конечный пользователь. Этим методом проверяют функциональность: делает ли приложение то, что должно?
Например, в интернет магазине важно проверить поиск товаров, фильтрацию результатов выдачи, возможность добавить продукты в корзину, ввести промокоды и оформить заказ. Иногда функции сервиса выглядят идеально в коде, но не работают на практике. В этом случае тестирование «черного ящика» помогает выявить баги, незаметные при проверке только кодовой части ПО.
Тестирование «белого ящика» (White Box Testing), также известное как glass box или прозрачное тестирование, — это, по сути, проверка исходного кода. Тестировщик анализирует блоки системы по отдельности и ищет проблемы.
Например, прозрачным тестированием можно проверить формы ввода контактов пользователя в интернет-магазине. Со стороны пользователя это выглядит так: вы нажали кнопку, email-адрес отправился в базу подписчиков магазина, вам на почту пришло письмо с промокодом на скидку. Если тестировать эту часть «черным ящиком», вы можете нажать на кнопку и не получить никакого письма. Зафиксировали баг, тест заканчивается. Методом «белого ящика» можно выявить, почему это происходит. QA-специалист смотрит, чтобы на уровне кода форма была надежно защищена от взлома и данные пользователей не утекли в руки мошенников. Также он следит, чтобы адрес почты отправился в базу данных, а дальше запустился процесс автоматической рассылки новостей об акциях и промокодах.
Тестирование «серого ящика» (Grey Box Testing) объединяет методы тестирования «белого» и «черного ящика». Цель этого подхода — найти любые ошибки в пользовательском интерфейсе или в разработке. У тестировщика нет доступа к коду приложения, но он знает общую структуру сервиса и его ограничения.
Для примера вернемся к форме в интернет-магазине. Например, при оформлении заказа нужно ввести имя и фамилию, тестировщику нужно проверить работу текстовых полей. QA знает, что у системы есть ограничение по длине фамилии, например, в 100 символов. Задача тестировщика — найти фамилии длиннее 100 символов (самая длинная в книге рекордов Гиннеса состоит из 700). Также он должен проверить, как будет вести себя система, если ввести в поле больше 100 букв. Приложение должно как минимум не ломаться и выдавать уведомление об ошибке.
Заменят ли мануальных QA автотесты?
Несмотря на то, что работодатели заинтересованы в специалистах, которые умеют автоматизировать процессы, от QA-инженеров по-прежнему ждут опыта в ручном тестировании. Почему этот навык так важен?
Автоматизированные тесты не могут найти абсолютно все баги. Они распознают только те, которые прописаны в их сценариях. Кроме того, сами автотесты могут содержать в себе ошибки кода, они не идеальны. Ручное тестирование в этом плане более гибкое. Живой QA может придумать нестандартные пользовательские сценарии, оценить эстетическую сторону сервиса и сугубо человеческий критерий удобства.
Автотестам можно оставить рутинные операции, поиск типовых ошибок, нагрузочное тестирование. Это избавит QA-инженеров от монотонной работы и ускорит процессы. Ручная проверка подойдет для более креативных и сложных задач, где нужен человеческий взгляд.
Стартовать в профессии QA-инженера с мануального тестирования — это все еще хороший ход. Таким образом вы изучите базовые принципы проверки качества и подготовитесь к тому, чтобы переходить на новый этап карьеры — к автоматизации. Главное — быть готовым постоянно изучать на практике новые инструменты.
Ручное тестирование может быть искусством, но это, конечно, не самая захватывающая задача, которую вы можете получить на работе. Тем не менее у ручного тестирования много преимуществ, даже если вы не считаете себя особенно опытным в тестировании. Если ручные тесты для вас в новинку, найдите время, чтобы узнать, что они из себя представляют и как они выполняются прежде чем приступить к первому заданию. Эта статья расскажет вам об основных процессах ручного тестирования качества, о том, какие инструменты вам следует использовать и о типах тестирования, которые вы можете выполнять в рамках своих должностных обязанностей.
Основные процессы ручного тестирования
Если вы делаете свою работу правильно, не существует такой вещи, как стандартная рабочая процедура. Тем не менее, есть некоторые распространенные методы, о которых важно знать каждому тестировщику и руководителю группы тестирования. Как минимум, тестировщики должны знать об этих процедурах, чтобы не отставать от отраслевых стандартов и соответствующим образом улучшать свои собственные процессы.
Помните: лучший способ учиться — это делать. Применение этих процессов на практике поможет вам стать экспертом в ручном тестировании, поэтому используйте их как можно чаще. Вот несколько примеров стандартных процедур и инструментов, с которыми должны быть знакомы все тестировщики.
Каковы основные процедуры обеспечения качества при ручном тестировании?
Чтобы понять, какое ручное тестирование следует провести для вашего приложения, вам сначала нужно узнать о его назначении. Но прежде чем мы углубимся в ручное тестирование, давайте проясним, что оно не полностью автоматизировано. Эти процедуры проводятся тестировщиками вручную и с помощью собственных устройств.
Существуют различные типы тестирования программного обеспечения, такие как тестирование установки, интеграционное тестирование и функциональное тестирование, и каждое ручное тестирование имеет свои конкретные цели и задачи. Одной из этих целей может быть проверка того, работает ли приложение должным образом на разных поддерживаемых платформах, и выявление любых ошибок до того, как оно попадет в руки конечного пользователя.
Основными задачами на этапе подготовки будут:
- Знакомство со спецификациями.
- Понимание разработанного функционала.
- Определение тестов, которые будут выполнены. Обычно тестирование начинается с функциональности, а затем распространяется на остальное (пользовательский интерфейс, стресс, негатив, граница, нагрузка и другие).
- Написание тест-кейсов.
- Подготовка тестируемых устройств. Знание поддерживаемых устройств и платформ имеет решающее значение, поэтому вам не нужно выполнять дополнительные ненужные тесты. В то же время убедитесь, что вы охватываете нужные платформы и устройства.
Наиболее распространенные ручные инструменты контроля качества
Надежная библиотека инструментов тестирования доступна для ручного тестирования качества. Однако многие из этих инструментов перекрывают друг друга в том смысле, что они выполняют схожие функции немного по-разному. Например, как инструменты записи/воспроизведения, так и инструменты тестовых сценариев позволяют вам вводить список шагов или команд, которые должны быть выполнены в тестируемом приложении (AUT). Это полезно знать на будущее, но в качестве базового набора ручных инструментов вы можете использовать такие простые инструменты, как Google Docs или документ Word! Однако гораздо проще использовать инструмент, специально разработанный для документирования и запуска тест-кейсов.
Вот несколько таких инструментов:
— TestRail. Это инструмент, используемый для написания, хранения, группировки и запуска тестовых случаев. Проще говоря, TestRail — это библиотека тестовых сценариев, которую обслуживает и управляет тестер. Вы можете добавить столько тестов, сколько хотите, и запускать их столько раз, сколько пожелаете. TestRail — это программное обеспечение, предназначенное для организации ваших тестов и записей. Это платное программное обеспечение, поэтому ваша компания обычно получает пакет для всей команды тестировщиков.
— Jira или аналогичный инструмент для отслеживания ошибок. Как только вы обнаружите ошибку в тестируемом ПО, вам необходимо отправить разработчику тикет с описанием и скриншотами. Конечно, вы можете просто рассказать ему о том, что только что видели, но это не лучший способ, если вы тестировщик программного обеспечения.
QA-тестеры используют инструмент, специально разработанный для этой цели. Это называется «инструментом отслеживания ошибок». Это может быть Jira или любой подобный инструмент, но все они будут схожи по своему функционалу и будут иметь одну и ту же конечную цель. Ваша компания может решить использовать Jira, потому что это наиболее распространенный вариант, или же они могут обратиться к любому аналогичному инструменту. Для вас, как для тестировщика, особой разницы нет. Как уже упоминалось, все инструменты служат одной цели и работают одинаково. Если вы знаете, как использовать один, вы можете легко использовать другие.
— Rundeck. Это инструмент, который в основном используется для запуска различных скриптов в ручном и автоматизированном тестировании. Rundeck упрощает развертывание нового кода для тестирования без необходимости ждать, пока это сделает DevOps. Также с помощью этого инструмента можно выполнять множество задач по моделированию тестов. Например, вы можете запустить сценарий для имитации местоположения вашего устройства или сети для выполнения необходимых тестов. Единственное, что нужно иметь в виду, это то, что прежде чем вы сможете использовать Rundeck для вашей повседневной деятельности, вам потребуются системные инженеры или DevOps, чтобы настроить его для вас. Сначала необходимо написать сценарии, а затем интегрировать их в Rundeck. После того, как это будет сделано, вы можете начать использовать его и изменять сценарии по своему усмотрению.
Распространенные проблемы при ручном тестировании
Ручные тестировщики, особенно с небольшим опытом, нередко недооценивают, сколько часов занимает тестирование. Проекты часто выходят за рамки бюджета, потому что люди думают, что могут протестировать сайт всего за один или два дня! Хотя вы можете протестировать продукт за пару дней, этого времени точно не хватит для повторного тестирования всех исправлений и ошибок, которые вы найдете. Поэтому, когда дело доходит до проверки оценок, подготовьтесь к нескольким раундам тестов, и всегда полезно поговорить с вашим лидом или менеджером, если вы не уверены.
Обычно ваш лид должен будет оценить время и количество тестов, прежде чем вы действительно начнете тестирование. При их оценке будет учитываться множество факторов, и она будет основываться не только на объеме работы, но и на желаемом тестовом покрытии, количестве тестируемых устройств и дате выпуска.
Вы также можете столкнуться с проблемами, связанными с плохой коммуникацией и непониманием требований как с вашей стороны, так и со стороны других лиц, участвующих в реализации вашего проекта. Кроме того, конфликты с другими заинтересованными сторонами, такими как разработчики, являются обычным явлением, поскольку все работают над поиском решений.
Чтобы избежать этих проблем, лучше убедиться, что все участники четко понимают, каковы их цели. А это означает, что нужно находить время для ежедневных стендапов или ретроспектив.
Основная цель любой команды QA — понять требования к продукту и убедиться, что он поставлен так, как задумано.
Как подготовиться перед тем, как приступить к ручным задачам контроля качества
Запомните эти три вопроса, прежде чем приступать к выполнению любых задач по контролю качества вручную:
Актуально ли это?
Могу ли я добавить ценность?
Могу ли я сделать это хорошо?
Любая ручная задача, которую вы выполняете, должна отвечать на эти и другие вопросы. Ваши ответы дадут вам более полное представление о вашей работе и о том, что необходимо как со стратегической, так и с тактической точек зрения.
Например, некоторые задачи слишком широки, чтобы ручной контроль качества был эффективным. Другие могут быть выполнены лучше другими людьми или с помощью автоматизации. Вы также можете обнаружить, что некоторые действия больше не имеют смысла или могут быть полностью исключены, как только вы начнете смотреть на вещи через эту призму.
Хорошо структурированная стратегия тестирования может помочь вам избежать этих ошибок, гарантируя, что у всех участников есть четкие ожидания относительно их работы и того, как она вписывается в более широкие цели.
При правильном выполнении ручные тесты контроля качества могут принести большую пользу вашей команде. Но не каждую задачу стоит выполнять только из-за ее достоинств. Чтобы убедиться, что ваше время и усилия реально влияют на ваш проект, подходите к каждому новому ручному тесту целенаправленно и внимательно.
А если вы в чем-то не уверены, не бойтесь спрашивать! Помните, важно делать свою работу правильно, а не просто быстро!
Запись на курс Manual QA