Тестировщик программного обеспечения — критично важная роль в индустрии IT. Каждое собеседование на эту должность обычно представляет собой комбинацию технических и теоретических вопросов. Ниже описано 15 самых часто задаваемых вопросов с ответами, которые помогут вам успешно пройти собеседование.
1. Что такое тестирование ПО?
Тестирование ПО — это процесс проверки качества программного обеспечения, цель которого — обнаружить ошибки, убедиться в соответствии продукта требованиям и гарантировать удовлетворение потребностей конечных пользователей.
2. Каковы основные типы тестирования?
Функциональное тестирование: проверка работоспособности программы.
Нефункциональное тестирование: включает тестирование производительности, безопасности, удобства использования и других характеристик.
Ручное тестирование: тестирование без использования автоматизированных инструментов.
Автоматизированное тестирование: выполнение тестов с помощью скриптов и программ.
3. Что такое жизненный цикл дефекта?
Жизненный цикл дефекта — это последовательность этапов, которые проходит дефект от обнаружения до устранения:
Новый (New)
В работе (Assigned)
Исправлен (Fixed)
Проверен (Verified)
Закрыт (Closed) или Отклонён (Rejected).
4. Чем отличается тест-кейс от тест-сценария?
Тест-кейс: документ с подробным описанием шагов, входных данных, ожидаемого результата и состояния теста.
Тест-сценарий: общий набор условий или действий для проверки функционала.
Чуть больше об отличиях тут
5. Что такое регрессионное тестирование?
Это тип тестирования, цель которого — убедиться, что внесенные изменения не нарушили существующую функциональность.
6. Какие инструменты автоматизации тестирования вы знаете?
Некоторые популярные инструменты:
Selenium
JUnit
TestNG
Appium
Postman
JMeter
7. Что такое Smoke Testing и Sanity Testing?
Smoke Testing: поверхностная проверка базовой функциональности системы.
Sanity Testing: проверка отдельных частей системы после внесения изменений.
8. Объясните понятие "чёрного ящика" и "белого ящика".
Чёрный ящик: тестирование без знания внутренней структуры кода.
Белый ящик: тестирование с использованием знаний о внутренней структуре и логике программы.
9. Что такое тестовое покрытие (Test Coverage)?
Это метрика, показывающая степень покрытия кода или функционала тестами.
10. Как вы приоритизируете тест-кейсы?
Приоритизация основывается на риске, критичности функционала и вероятности возникновения ошибок.
11. Что такое Exploratory Testing?
Это исследовательское тестирование без заранее написанных тест-кейсов, где тестировщик изучает систему в реальном времени.
12. Каковы ключевые шаги в написании отчёта о дефекте?
Уникальный ID дефекта.
Описание проблемы.
Шаги для воспроизведения.
Ожидаемый и фактический результат.
Скриншоты или логи.
Приоритет и серьёзность.
13. Что такое Agile и как тестирование вписывается в эту методологию?
Agile — это гибкая методология разработки ПО. Тестирование интегрируется в спринты, а тестировщики активно взаимодействуют с разработчиками.
14. Как вы документируете процесс тестирования?
Документирование включает:
Тест-план.
Тестовые сценарии и тест-кейсы.
Отчёты о дефектах.
Итоговый отчёт о тестировании.
15. Расскажите об успешном проекте, в котором вы участвовали как тестировщик.
Подчеркните свой вклад, например, создание эффективных тест-кейсов, автоматизацию рутинных задач или выявление критических багов, которые могли бы повлиять на конечного пользователя.
16. Какие виды тестирования применяются для мобильных приложений?
Для мобильных приложений применяются:
Тестирование совместимости на разных устройствах и ОС.
Тестирование производительности.
Тестирование безопасности.
Тестирование удобства использования (UX).
17. Как вы проверяете веб-приложения на кроссбраузерную совместимость?
Для проверки веб-приложений используются:
Инструменты, такие как BrowserStack или CrossBrowserTesting.
Ручное тестирование в различных браузерах и их версиях.
Автоматизированные тесты с использованием Selenium.
18. Что такое нагрузочное тестирование?
Нагрузочное тестирование определяет, как система справляется с большим количеством пользователей или транзакций за определённый период времени.
19. Какие показатели являются важными при тестировании производительности?
Ключевые метрики:
Время отклика.
Пропускная способность.
Уровень использования ресурсов (CPU, RAM, диска).
Количество ошибок.
20. Как вы планируете тестирование?
Планирование включает:
Определение целей тестирования.
Подготовку тест-плана.
Создание тест-кейсов.
Оценку ресурсов и времени.
Назначение ответственных за выполнение тестов.
Напишите вопросы, которые вам задавали на собеседовании и я добавлю их в следующую статью. Удачного собеседования всем.
Комментарии (3)
clarifyingman
03.01.2025 19:14И ни одного вопроса про тест-дизайн. Какие техники тест-дизайна известны?
Даже не спросили, что такое дефект/баг. Хотя по ответу на вопрос 12 можно сделать определенные выводы.
Я так понимаю, при заведении бага указывать версию ПО уже не нужно. И это печалит.
Про типы тестирования полная каша. В рамках жизненного цикла ПО есть НФ и Регресс. Где-то там притаилось тестирование требований. А в случае сложных систем еще интеграционным тестированием приходится заниматься.
Для мобилок и браузера неплохо бы еще вспомнить про тестирование api и разницу между фронтом/бэком. И зачем вообще нужно тестирование графического интерфейса.
Если текст этой статьи был сгенерирован нейросетью, то результат нормальный.
А так статья скорее вредная, чем полезная.
hir0kashi
03.01.2025 19:14Исключительное ИМХО, но:
Этот список вопросов в компании от А уровня не задают, если речь идет не о позиции стажера/совсем уж сопливого джуна.
Рынок, как и требования к QA - сильно изменились в строну большей "инженерности". А потому значительная часть вопросов нормальной компании будет нацелена не на сухую ISTQB Basic теорию, а на реальное понимание той области, где предстоит применять навыки: задачи/вопросы по тестированию API, рел/не рел БД. Из теории обычно могу спросить как раз про ТТД, ибо умение на практике их применять косвено говорит о наличии опыта кандидата и его понимании как вообще что делать
Отдельной категорией сейчас всегда идут вопросы по CI/CD, развертыванию и инструментам типо Docker,K8s, GitLab/Jenkins/BitBucket etc. Тут чаще просто закидываюи удочку, насколько кандидат погружался в тему непрерывной интеграции и деплоя. Чаще всего есть на то девопсы, то базу знать - высоко летать.
Ну и автоматизация. Сейчас она пояти на каждой позиции. Чаще всего Java/Python. Иногда есть изврат на JS или там всякие BDD, но эт на любителя.
По ЯП обычно спрашивают core + вопросы по инструментам (appium/restAssured, Selenium/selenide etc)
Вывод:
Знать теорию базовую - это, конечно, нужно. Но, в большинстве нормальных контор мучать вас вопросами по базовой теории никто не станет, ибо важны ваши реальные навыки, а не сухая теория.
Всем добра!
Darth_Anjan
Тест-кейс и тест-сценарий - это одно и то же. Смотрите официальный перевод глоссария istqb.
То, что по ссылке называют сценарием - это похоже на use case (сценарий использования системы)